lnd: add integration test checks unavailability to pay same preimage
This commit is contained in:
parent
033fd3c83d
commit
76dbe670cb
48
lnd_test.go
48
lnd_test.go
@ -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),
|
||||||
|
Loading…
Reference in New Issue
Block a user