mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-08-27 14:11:04 +02:00
itest: add payment test with max htlc restriction
This commit is contained in:
@@ -238,6 +238,10 @@ var allTestCases = []*lntest.TestCase{
|
|||||||
Name: "wumbo channels",
|
Name: "wumbo channels",
|
||||||
TestFunc: testWumboChannels,
|
TestFunc: testWumboChannels,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Name: "max htlc path payment",
|
||||||
|
TestFunc: testMaxHtlcPathPayment,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
Name: "max htlc pathfind",
|
Name: "max htlc pathfind",
|
||||||
TestFunc: testMaxHtlcPathfind,
|
TestFunc: testMaxHtlcPathfind,
|
||||||
|
74
itest/lnd_max_htlc_path_test.go
Normal file
74
itest/lnd_max_htlc_path_test.go
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
package itest
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/lightningnetwork/lnd/lnrpc"
|
||||||
|
"github.com/lightningnetwork/lnd/lnrpc/routerrpc"
|
||||||
|
"github.com/lightningnetwork/lnd/lntest"
|
||||||
|
)
|
||||||
|
|
||||||
|
// testMaxHtlcPathPayment tests that when a payment is attempted, the path
|
||||||
|
// finding logic correctly takes into account the max_htlc value of the first
|
||||||
|
// channel.
|
||||||
|
func testMaxHtlcPathPayment(ht *lntest.HarnessTest) {
|
||||||
|
// Create a channel Alice->Bob.
|
||||||
|
chanPoints, nodes := ht.CreateSimpleNetwork(
|
||||||
|
[][]string{nil, nil}, lntest.OpenChannelParams{
|
||||||
|
Amt: 1000000,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
alice, bob := nodes[0], nodes[1]
|
||||||
|
chanPoint := chanPoints[0]
|
||||||
|
|
||||||
|
// Alice and Bob should have one channel open with each other now.
|
||||||
|
ht.AssertNodeNumChannels(alice, 1)
|
||||||
|
ht.AssertNodeNumChannels(bob, 1)
|
||||||
|
|
||||||
|
// Define a max_htlc value that is lower than the default.
|
||||||
|
const (
|
||||||
|
maxHtlcMsat = 50000000
|
||||||
|
minHtlcMsat = 1000
|
||||||
|
timeLockDelta = 80
|
||||||
|
baseFeeMsat = 0
|
||||||
|
feeRate = 0
|
||||||
|
)
|
||||||
|
|
||||||
|
// Update Alice's channel policy to set the new max_htlc value.
|
||||||
|
req := &lnrpc.PolicyUpdateRequest{
|
||||||
|
Scope: &lnrpc.PolicyUpdateRequest_ChanPoint{
|
||||||
|
ChanPoint: chanPoint,
|
||||||
|
},
|
||||||
|
MaxHtlcMsat: maxHtlcMsat,
|
||||||
|
MinHtlcMsat: minHtlcMsat,
|
||||||
|
BaseFeeMsat: baseFeeMsat,
|
||||||
|
FeeRate: feeRate,
|
||||||
|
TimeLockDelta: timeLockDelta,
|
||||||
|
}
|
||||||
|
alice.RPC.UpdateChannelPolicy(req)
|
||||||
|
|
||||||
|
expectedPolicy := &lnrpc.RoutingPolicy{
|
||||||
|
FeeBaseMsat: baseFeeMsat,
|
||||||
|
FeeRateMilliMsat: feeRate,
|
||||||
|
TimeLockDelta: timeLockDelta,
|
||||||
|
MinHtlc: minHtlcMsat,
|
||||||
|
MaxHtlcMsat: maxHtlcMsat,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wait for the policy update to propagate to Bob.
|
||||||
|
ht.AssertChannelPolicyUpdate(
|
||||||
|
bob, alice, expectedPolicy, chanPoint, false,
|
||||||
|
)
|
||||||
|
|
||||||
|
// Create an invoice for an amount greater than the max htlc value.
|
||||||
|
invoiceAmt := int64(maxHtlcMsat + 10_000_000)
|
||||||
|
invoice := &lnrpc.Invoice{ValueMsat: invoiceAmt}
|
||||||
|
resp := bob.RPC.AddInvoice(invoice)
|
||||||
|
|
||||||
|
// Attempt to pay the invoice from Alice. The payment should be
|
||||||
|
// splitted into two parts, one for the max_htlc value and one for the
|
||||||
|
// remaining amount and succeed.
|
||||||
|
payReq := &routerrpc.SendPaymentRequest{
|
||||||
|
PaymentRequest: resp.PaymentRequest,
|
||||||
|
FeeLimitMsat: noFeeLimitMsat,
|
||||||
|
}
|
||||||
|
ht.SendPaymentAssertSettled(alice, payReq)
|
||||||
|
}
|
Reference in New Issue
Block a user