From f829d33d6fd51e2a6d607dc651edbe3f9ea05416 Mon Sep 17 00:00:00 2001 From: "Johan T. Halseth" Date: Tue, 28 May 2019 11:03:14 +0200 Subject: [PATCH 1/2] route: return 0 fee from TotalFees for empty route. Otherwise we would crash calling the method on empty routes. --- routing/route/route.go | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/routing/route/route.go b/routing/route/route.go index 9b010e77..2cd04684 100644 --- a/routing/route/route.go +++ b/routing/route/route.go @@ -103,6 +103,10 @@ func (r *Route) HopFee(hopIndex int) lnwire.MilliSatoshi { // the case of a one-hop payment, this value will be zero as we don't need to // pay a fee to ourself. func (r *Route) TotalFees() lnwire.MilliSatoshi { + if len(r.Hops) == 0 { + return 0 + } + return r.TotalAmount - r.Hops[len(r.Hops)-1].AmtToForward } From 5882e54bf3cf7ed7895fda34f7a11bc53de624d9 Mon Sep 17 00:00:00 2001 From: "Johan T. Halseth" Date: Tue, 28 May 2019 11:03:48 +0200 Subject: [PATCH 2/2] route test: add a simple unit test for the TotalFees method Checks fees on 0, 1, and 2-hop routes. --- routing/route/route_test.go | 58 +++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 routing/route/route_test.go diff --git a/routing/route/route_test.go b/routing/route/route_test.go new file mode 100644 index 00000000..92b0ee0d --- /dev/null +++ b/routing/route/route_test.go @@ -0,0 +1,58 @@ +package route + +import ( + "testing" + + "github.com/lightningnetwork/lnd/lnwire" +) + +// TestRouteTotalFees checks that a route reports the expected total fee. +func TestRouteTotalFees(t *testing.T) { + t.Parallel() + + // Make sure empty route returns a 0 fee. + r := &Route{} + if r.TotalFees() != 0 { + t.Fatalf("expected 0 fees, got %v", r.TotalFees()) + } + + // For one-hop routes the fee should be 0, since the last node will + // receive the full amount. + amt := lnwire.MilliSatoshi(1000) + hops := []*Hop{ + { + PubKeyBytes: Vertex{}, + ChannelID: 1, + OutgoingTimeLock: 44, + AmtToForward: amt, + }, + } + r, err := NewRouteFromHops(amt, 100, Vertex{}, hops) + if err != nil { + t.Fatal(err) + } + + if r.TotalFees() != 0 { + t.Fatalf("expected 0 fees, got %v", r.TotalFees()) + } + + // Append the route with a node, making the first one take a fee. + fee := lnwire.MilliSatoshi(100) + hops = append(hops, &Hop{ + PubKeyBytes: Vertex{}, + ChannelID: 2, + OutgoingTimeLock: 33, + AmtToForward: amt - fee, + }, + ) + + r, err = NewRouteFromHops(amt, 100, Vertex{}, hops) + if err != nil { + t.Fatal(err) + } + + if r.TotalFees() != fee { + t.Fatalf("expected %v fees, got %v", fee, r.TotalFees()) + } + +}