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:
Olaoluwa Osuntokun 2017-08-22 00:34:11 -07:00
parent 65526ba071
commit 08d22f8bb4
No known key found for this signature in database
GPG Key ID: 9CC5B105D03521A2

@ -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,