lnd: modify htlc error integration tests to account for max payment size
This commit modifies the HTLC integration tests to be mindful of the max payment size. Rather than sending the payment in one large batch, we instead now send it in chunks of the max payment size.
This commit is contained in:
parent
65526ba071
commit
08d22f8bb4
48
lnd_test.go
48
lnd_test.go
@ -2138,23 +2138,39 @@ out:
|
|||||||
|
|
||||||
// To do so, we'll push most of the funds in the channel over to
|
// To do so, we'll push most of the funds in the channel over to
|
||||||
// Alice's side, leaving on 10k satoshis of available balance for bob.
|
// Alice's side, leaving on 10k satoshis of available balance for bob.
|
||||||
invoiceReq = &lnrpc.Invoice{
|
// There's a max payment amount, so we'll have to do this
|
||||||
Value: int64(chanAmt) - 10000,
|
// incrementally.
|
||||||
}
|
amtToSend := int64(chanAmt) - 10000
|
||||||
carolInvoice2, err := carol.AddInvoice(ctxb, invoiceReq)
|
amtSent := int64(0)
|
||||||
if err != nil {
|
for amtSent != amtToSend {
|
||||||
t.Fatalf("unable to generate carol invoice: %v", err)
|
// We'll send in chunks of the max payment amount. If we're
|
||||||
}
|
// about to send too much, then we'll only send the amount
|
||||||
if err := bobPayStream.Send(&lnrpc.SendRequest{
|
// remaining.
|
||||||
PaymentRequest: carolInvoice2.PaymentRequest,
|
toSend := int64(maxPaymentMSat.ToSatoshis())
|
||||||
}); err != nil {
|
if toSend+amtSent > amtToSend {
|
||||||
t.Fatalf("unable to send payment: %v", err)
|
toSend = amtToSend - amtSent
|
||||||
}
|
}
|
||||||
|
|
||||||
if resp, err := bobPayStream.Recv(); err != nil {
|
invoiceReq = &lnrpc.Invoice{
|
||||||
t.Fatalf("payment stream has been closed: %v", err)
|
Value: toSend,
|
||||||
} else if resp.PaymentError != "" {
|
}
|
||||||
t.Fatalf("bob's payment failed: %v", err)
|
carolInvoice2, err := carol.AddInvoice(ctxb, invoiceReq)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unable to generate carol invoice: %v", err)
|
||||||
|
}
|
||||||
|
if err := bobPayStream.Send(&lnrpc.SendRequest{
|
||||||
|
PaymentRequest: carolInvoice2.PaymentRequest,
|
||||||
|
}); err != nil {
|
||||||
|
t.Fatalf("unable to send payment: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if resp, err := bobPayStream.Recv(); err != nil {
|
||||||
|
t.Fatalf("payment stream has been closed: %v", err)
|
||||||
|
} else if resp.PaymentError != "" {
|
||||||
|
t.Fatalf("bob's payment failed: %v", resp.PaymentError)
|
||||||
|
}
|
||||||
|
|
||||||
|
amtSent += toSend
|
||||||
}
|
}
|
||||||
|
|
||||||
// At this point, Alice has 50mil satoshis on her side of the channel,
|
// At this point, Alice has 50mil satoshis on her side of the channel,
|
||||||
|
Loading…
Reference in New Issue
Block a user