lnd: add integration test checks unavailability to pay same preimage

This commit is contained in:
Vadym Popov 2018-08-12 16:23:08 +03:00 committed by Conner Fromknecht
parent 033fd3c83d
commit 76dbe670cb
No known key found for this signature in database
GPG Key ID: E7D737B67FA592C7

@ -450,6 +450,17 @@ func completePaymentRequests(ctx context.Context, client lnrpc.LightningClient,
return nil return nil
} }
// makeFakePayHash creates random pre image hash
func makeFakePayHash(t *harnessTest) []byte {
randBuf := make([]byte, 32)
if _, err := rand.Read(randBuf); err != nil {
t.Fatalf("internal error, cannot generate random string: %v", err)
}
return randBuf
}
const ( const (
AddrTypeWitnessPubkeyHash = lnrpc.NewAddressRequest_WITNESS_PUBKEY_HASH AddrTypeWitnessPubkeyHash = lnrpc.NewAddressRequest_WITNESS_PUBKEY_HASH
AddrTypeNestedPubkeyHash = lnrpc.NewAddressRequest_NESTED_PUBKEY_HASH AddrTypeNestedPubkeyHash = lnrpc.NewAddressRequest_NESTED_PUBKEY_HASH
@ -1825,13 +1836,13 @@ func testChannelForceClosure(net *lntest.NetworkHarness, t *harnessTest) {
if err != nil { if err != nil {
t.Fatalf("unable to create payment stream for alice: %v", err) t.Fatalf("unable to create payment stream for alice: %v", err)
} }
carolPubKey := carol.PubKey[:] carolPubKey := carol.PubKey[:]
payHash := bytes.Repeat([]byte{2}, 32)
for i := 0; i < numInvoices; i++ { for i := 0; i < numInvoices; i++ {
err = alicePayStream.Send(&lnrpc.SendRequest{ err = alicePayStream.Send(&lnrpc.SendRequest{
Dest: carolPubKey, Dest: carolPubKey,
Amt: int64(paymentAmt), Amt: int64(paymentAmt),
PaymentHash: payHash, PaymentHash: makeFakePayHash(t),
FinalCltvDelta: defaultBitcoinTimeLockDelta, FinalCltvDelta: defaultBitcoinTimeLockDelta,
}) })
if err != nil { if err != nil {
@ -3825,8 +3836,15 @@ func testPrivateChannels(net *lntest.NetworkHarness, t *harnessTest) {
const paymentAmt = 70000 const paymentAmt = 70000
payReqs := make([]string, numPayments) payReqs := make([]string, numPayments)
for i := 0; i < numPayments; i++ { for i := 0; i < numPayments; i++ {
preimage := make([]byte, 32)
_, err := rand.Read(preimage)
if err != nil {
t.Fatalf("unable to generate preimage: %v", err)
}
invoice := &lnrpc.Invoice{ invoice := &lnrpc.Invoice{
Memo: "testing", Memo: "testing",
RPreimage: preimage,
Value: paymentAmt, Value: paymentAmt,
} }
resp, err := net.Bob.AddInvoice(ctxb, invoice) resp, err := net.Bob.AddInvoice(ctxb, invoice)
@ -3888,8 +3906,15 @@ func testPrivateChannels(net *lntest.NetworkHarness, t *harnessTest) {
const paymentAmt60k = 60000 const paymentAmt60k = 60000
payReqs = make([]string, numPayments) payReqs = make([]string, numPayments)
for i := 0; i < numPayments; i++ { for i := 0; i < numPayments; i++ {
preimage := make([]byte, 32)
_, err := rand.Read(preimage)
if err != nil {
t.Fatalf("unable to generate preimage: %v", err)
}
invoice := &lnrpc.Invoice{ invoice := &lnrpc.Invoice{
Memo: "testing", Memo: "testing",
RPreimage: preimage,
Value: paymentAmt60k, Value: paymentAmt60k,
} }
resp, err := carol.AddInvoice(ctxb, invoice) resp, err := carol.AddInvoice(ctxb, invoice)
@ -4376,10 +4401,9 @@ func testInvoiceSubscriptions(net *lntest.NetworkHarness, t *harnessTest) {
// TODO(roasbeef): make global list of invoices for each node to re-use // TODO(roasbeef): make global list of invoices for each node to re-use
// and avoid collisions // and avoid collisions
const paymentAmt = 1000 const paymentAmt = 1000
preimage := bytes.Repeat([]byte{byte(90)}, 32)
invoice := &lnrpc.Invoice{ invoice := &lnrpc.Invoice{
Memo: "testing", Memo: "testing",
RPreimage: preimage, RPreimage: makeFakePayHash(t),
Value: paymentAmt, Value: paymentAmt,
} }
invoiceResp, err := net.Bob.AddInvoice(ctxb, invoice) invoiceResp, err := net.Bob.AddInvoice(ctxb, invoice)
@ -6607,7 +6631,7 @@ out:
// stream on payment error. // stream on payment error.
ctxt, _ = context.WithTimeout(ctxb, timeout) ctxt, _ = context.WithTimeout(ctxb, timeout)
sendReq := &lnrpc.SendRequest{ sendReq := &lnrpc.SendRequest{
PaymentHashString: hex.EncodeToString(bytes.Repeat([]byte("Z"), 32)), PaymentHashString: hex.EncodeToString(makeFakePayHash(t)),
DestString: hex.EncodeToString(carol.PubKey[:]), DestString: hex.EncodeToString(carol.PubKey[:]),
Amt: payAmt, Amt: payAmt,
} }
@ -6736,6 +6760,12 @@ out:
"instead: %v", resp.PaymentError) "instead: %v", resp.PaymentError)
} }
// Generate new invoice to not pay same invoice twice.
carolInvoice, err = carol.AddInvoice(ctxb, invoiceReq)
if err != nil {
t.Fatalf("unable to generate carol invoice: %v", err)
}
// For our final test, we'll ensure that if a target link isn't // For our final test, we'll ensure that if a target link isn't
// available for what ever reason then the payment fails accordingly. // available for what ever reason then the payment fails accordingly.
// //
@ -7833,8 +7863,8 @@ func testMultiHopHtlcLocalTimeout(net *lntest.NetworkHarness, t *harnessTest) {
// We'll create two random payment hashes unknown to carol, then send // We'll create two random payment hashes unknown to carol, then send
// each of them by manually specifying the HTLC details. // each of them by manually specifying the HTLC details.
carolPubKey := carol.PubKey[:] carolPubKey := carol.PubKey[:]
dustPayHash := bytes.Repeat([]byte{1}, 32) dustPayHash := makeFakePayHash(t)
payHash := bytes.Repeat([]byte{2}, 32) payHash := makeFakePayHash(t)
err = alicePayStream.Send(&lnrpc.SendRequest{ err = alicePayStream.Send(&lnrpc.SendRequest{
Dest: carolPubKey, Dest: carolPubKey,
Amt: int64(dustHtlcAmt), Amt: int64(dustHtlcAmt),
@ -8292,7 +8322,7 @@ func testMultiHopLocalForceCloseOnChainHtlcTimeout(net *lntest.NetworkHarness,
// We'll now send a single HTLC across our multi-hop network. // We'll now send a single HTLC across our multi-hop network.
carolPubKey := carol.PubKey[:] carolPubKey := carol.PubKey[:]
payHash := bytes.Repeat([]byte{2}, 32) payHash := makeFakePayHash(t)
err = alicePayStream.Send(&lnrpc.SendRequest{ err = alicePayStream.Send(&lnrpc.SendRequest{
Dest: carolPubKey, Dest: carolPubKey,
Amt: int64(htlcAmt), Amt: int64(htlcAmt),
@ -8549,7 +8579,7 @@ func testMultiHopRemoteForceCloseOnChainHtlcTimeout(net *lntest.NetworkHarness,
// We'll now send a single HTLC across our multi-hop network. // We'll now send a single HTLC across our multi-hop network.
carolPubKey := carol.PubKey[:] carolPubKey := carol.PubKey[:]
payHash := bytes.Repeat([]byte{2}, 32) payHash := makeFakePayHash(t)
err = alicePayStream.Send(&lnrpc.SendRequest{ err = alicePayStream.Send(&lnrpc.SendRequest{
Dest: carolPubKey, Dest: carolPubKey,
Amt: int64(htlcAmt), Amt: int64(htlcAmt),