htlcswitch: only error in closeCircuit if the htlc was failed
This commit changes the switch to only log an error if update_fail_htlc comes in and closeCircuit returns ErrUnknownCircuit. Rationale being that only settles should hit this code path, anything else is a result of a link flap and should be treated as an error.
This commit is contained in:
parent
4fe174ba4e
commit
8c0c53eac3
@ -1164,6 +1164,12 @@ func (s *Switch) handlePacketForward(packet *htlcPacket) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// closeCircuit returns a nil circuit when a settle packet returns an
|
||||||
|
// ErrUnknownCircuit error upon the inner call to CloseCircuit.
|
||||||
|
if circuit == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
fail, isFail := htlc.(*lnwire.UpdateFailHTLC)
|
fail, isFail := htlc.(*lnwire.UpdateFailHTLC)
|
||||||
if isFail && !packet.hasSource {
|
if isFail && !packet.hasSource {
|
||||||
switch {
|
switch {
|
||||||
@ -1394,19 +1400,28 @@ func (s *Switch) closeCircuit(pkt *htlcPacket) (*PaymentCircuit, error) {
|
|||||||
// Failed to close circuit because it does not exist. This is likely
|
// Failed to close circuit because it does not exist. This is likely
|
||||||
// because the circuit was already successfully closed.
|
// because the circuit was already successfully closed.
|
||||||
case ErrUnknownCircuit:
|
case ErrUnknownCircuit:
|
||||||
err := fmt.Errorf("Unable to find target channel "+
|
|
||||||
"for HTLC settle/fail: channel ID = %s, "+
|
|
||||||
"HTLC ID = %d", pkt.outgoingChanID,
|
|
||||||
pkt.outgoingHTLCID)
|
|
||||||
log.Error(err)
|
|
||||||
|
|
||||||
if pkt.destRef != nil {
|
if pkt.destRef != nil {
|
||||||
// Add this SettleFailRef to the set of pending settle/fail entries
|
// Add this SettleFailRef to the set of pending settle/fail entries
|
||||||
// awaiting acknowledgement.
|
// awaiting acknowledgement.
|
||||||
s.pendingSettleFails = append(s.pendingSettleFails, *pkt.destRef)
|
s.pendingSettleFails = append(s.pendingSettleFails, *pkt.destRef)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If this is a settle, we will not log an error message as settles
|
||||||
|
// are expected to hit the ErrUnknownCircuit case. The only way fails
|
||||||
|
// can hit this case if the link restarts after having just sent a fail
|
||||||
|
// to the switch.
|
||||||
|
_, isSettle := pkt.htlc.(*lnwire.UpdateFulfillHTLC)
|
||||||
|
if !isSettle {
|
||||||
|
err := fmt.Errorf("unable to find target channel "+
|
||||||
|
"for HTLC fail: channel ID = %s, "+
|
||||||
|
"HTLC ID = %d", pkt.outgoingChanID,
|
||||||
|
pkt.outgoingHTLCID)
|
||||||
|
log.Error(err)
|
||||||
|
|
||||||
return nil, err
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil, nil
|
||||||
|
|
||||||
// Unexpected error.
|
// Unexpected error.
|
||||||
default:
|
default:
|
||||||
|
@ -761,8 +761,8 @@ func TestSwitchForwardSettleAfterFullAdd(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Send the settle packet again, which should fail.
|
// Send the settle packet again, which should fail.
|
||||||
if err := s2.forward(settle); err == nil {
|
if err := s2.forward(settle); err != nil {
|
||||||
t.Fatalf("expected failure when sending duplicate settle " +
|
t.Fatalf("expected success when sending duplicate settle " +
|
||||||
"with no pending circuit")
|
"with no pending circuit")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user