htlcswitch/test: test additional forwarding scenarios

This commit is contained in:
Joost Jager 2019-10-09 17:06:33 +02:00
parent 4ea8927845
commit e1b7cfe2e5
No known key found for this signature in database
GPG Key ID: A61B9D4C393C59C7

@ -1287,10 +1287,69 @@ func TestSwitchForwardCircuitPersistence(t *testing.T) {
} }
} }
type multiHopFwdTest struct {
name string
eligible1, eligible2 bool
failure1, failure2 lnwire.FailureMessage
expectedReply lnwire.FailCode
}
// TestSkipIneligibleLinksMultiHopForward tests that if a multi-hop HTLC comes // TestSkipIneligibleLinksMultiHopForward tests that if a multi-hop HTLC comes
// along, then we won't attempt to froward it down al ink that isn't yet able // along, then we won't attempt to froward it down al ink that isn't yet able
// to forward any HTLC's. // to forward any HTLC's.
func TestSkipIneligibleLinksMultiHopForward(t *testing.T) { func TestSkipIneligibleLinksMultiHopForward(t *testing.T) {
tests := []multiHopFwdTest{
// None of the channels is eligible or has enough bandwidth.
{
name: "not eligible",
expectedReply: lnwire.CodeTemporaryChannelFailure,
},
// Channel one has a policy failure and the other channel isn't
// available.
{
name: "policy fail",
eligible1: true,
failure1: lnwire.NewFinalIncorrectCltvExpiry(0),
expectedReply: lnwire.CodeFinalIncorrectCltvExpiry,
},
// The requested channel is not eligible or has insufficient
// bandwidth, but the packet is forwarded through the other
// channel.
{
name: "non-strict success",
eligible2: true,
expectedReply: lnwire.CodeNone,
},
// The requested channel is not eligible or has insufficient
// bandwidth and the other channel's policy isn't satisfied.
//
// NOTE: We expect a temporary channel failure here, but don't
// receive it!
{
name: "non-strict policy fail",
eligible2: true,
failure2: lnwire.NewFinalIncorrectCltvExpiry(0),
expectedReply: lnwire.CodeUnknownNextPeer,
},
}
for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
testSkipIneligibleLinksMultiHopForward(t, &test)
})
}
}
// testSkipIneligibleLinksMultiHopForward tests that if a multi-hop HTLC comes
// along, then we won't attempt to froward it down al ink that isn't yet able
// to forward any HTLC's.
func testSkipIneligibleLinksMultiHopForward(t *testing.T,
testCase *multiHopFwdTest) {
t.Parallel() t.Parallel()
var packet *htlcPacket var packet *htlcPacket
@ -1313,22 +1372,32 @@ func TestSkipIneligibleLinksMultiHopForward(t *testing.T) {
} }
defer s.Stop() defer s.Stop()
chanID1, chanID2, aliceChanID, bobChanID := genIDs() chanID1, aliceChanID := genID()
aliceChannelLink := newMockChannelLink( aliceChannelLink := newMockChannelLink(
s, chanID1, aliceChanID, alicePeer, true, s, chanID1, aliceChanID, alicePeer, true,
) )
// We'll create a link for Bob, but mark the link as unable to forward // We'll create a link for Bob, but mark the link as unable to forward
// any new outgoing HTLC's. // any new outgoing HTLC's.
bobChannelLink := newMockChannelLink( chanID2, bobChanID2 := genID()
s, chanID2, bobChanID, bobPeer, false, bobChannelLink1 := newMockChannelLink(
s, chanID2, bobChanID2, bobPeer, testCase.eligible1,
) )
bobChannelLink1.checkHtlcForwardResult = testCase.failure1
chanID3, bobChanID3 := genID()
bobChannelLink2 := newMockChannelLink(
s, chanID3, bobChanID3, bobPeer, testCase.eligible2,
)
bobChannelLink2.checkHtlcForwardResult = testCase.failure2
if err := s.AddLink(aliceChannelLink); err != nil { if err := s.AddLink(aliceChannelLink); err != nil {
t.Fatalf("unable to add alice link: %v", err) t.Fatalf("unable to add alice link: %v", err)
} }
if err := s.AddLink(bobChannelLink); err != nil { if err := s.AddLink(bobChannelLink1); err != nil {
t.Fatalf("unable to add bob link: %v", err)
}
if err := s.AddLink(bobChannelLink2); err != nil {
t.Fatalf("unable to add bob link: %v", err) t.Fatalf("unable to add bob link: %v", err)
} }
@ -1340,7 +1409,7 @@ func TestSkipIneligibleLinksMultiHopForward(t *testing.T) {
packet = &htlcPacket{ packet = &htlcPacket{
incomingChanID: aliceChannelLink.ShortChanID(), incomingChanID: aliceChannelLink.ShortChanID(),
incomingHTLCID: 0, incomingHTLCID: 0,
outgoingChanID: bobChannelLink.ShortChanID(), outgoingChanID: bobChannelLink1.ShortChanID(),
htlc: &lnwire.UpdateAddHTLC{ htlc: &lnwire.UpdateAddHTLC{
PaymentHash: rhash, PaymentHash: rhash,
Amount: 1, Amount: 1,
@ -1350,14 +1419,24 @@ func TestSkipIneligibleLinksMultiHopForward(t *testing.T) {
// The request to forward should fail as // The request to forward should fail as
err = s.forward(packet) err = s.forward(packet)
if err == nil {
t.Fatalf("forwarding should have failed due to inactive link")
}
failure := obfuscator.(*mockObfuscator).failure failure := obfuscator.(*mockObfuscator).failure
if _, ok := failure.(*lnwire.FailTemporaryChannelFailure); !ok { if testCase.expectedReply == lnwire.CodeNone {
if err != nil {
t.Fatalf("forwarding should have succeeded")
}
if failure != nil {
t.Fatalf("unexpected failure %T", failure) t.Fatalf("unexpected failure %T", failure)
} }
} else {
if err == nil {
t.Fatalf("forwarding should have failed due to " +
"inactive link")
}
if failure.Code() != testCase.expectedReply {
t.Fatalf("unexpected failure %T", failure)
}
}
if s.circuits.NumOpen() != 0 { if s.circuits.NumOpen() != 0 {
t.Fatal("wrong amount of circuits") t.Fatal("wrong amount of circuits")