itest/test: add settle/canceled assertions for subscribe single

This commit is contained in:
carla 2021-04-14 09:19:22 +02:00
parent 7f1e0a4d7b
commit 0686329062
No known key found for this signature in database
GPG Key ID: 4CA7FE54A6213C91

@ -14,6 +14,7 @@ import (
"github.com/lightningnetwork/lnd/lntest" "github.com/lightningnetwork/lnd/lntest"
"github.com/lightningnetwork/lnd/lntest/wait" "github.com/lightningnetwork/lnd/lntest/wait"
"github.com/lightningnetwork/lnd/lntypes" "github.com/lightningnetwork/lnd/lntypes"
"github.com/stretchr/testify/require"
) )
// testHoldInvoicePersistence tests that a sender to a hold-invoice, can be // testHoldInvoicePersistence tests that a sender to a hold-invoice, can be
@ -302,22 +303,33 @@ func testHoldInvoicePersistence(net *lntest.NetworkHarness, t *harnessTest) {
// Settle invoices half the invoices, cancel the rest. // Settle invoices half the invoices, cancel the rest.
for i, preimage := range preimages { for i, preimage := range preimages {
var expectedState lnrpc.Invoice_InvoiceState
ctxt, _ = context.WithTimeout(ctxb, defaultTimeout) ctxt, _ = context.WithTimeout(ctxb, defaultTimeout)
if i%2 == 0 { if i%2 == 0 {
settle := &invoicesrpc.SettleInvoiceMsg{ settle := &invoicesrpc.SettleInvoiceMsg{
Preimage: preimage[:], Preimage: preimage[:],
} }
_, err = carol.SettleInvoice(ctxt, settle) _, err = carol.SettleInvoice(ctxt, settle)
expectedState = lnrpc.Invoice_SETTLED
} else { } else {
hash := preimage.Hash() hash := preimage.Hash()
settle := &invoicesrpc.CancelInvoiceMsg{ settle := &invoicesrpc.CancelInvoiceMsg{
PaymentHash: hash[:], PaymentHash: hash[:],
} }
_, err = carol.CancelInvoice(ctxt, settle) _, err = carol.CancelInvoice(ctxt, settle)
expectedState = lnrpc.Invoice_CANCELED
} }
if err != nil { if err != nil {
t.Fatalf("unable to cancel/settle invoice: %v", err) t.Fatalf("unable to cancel/settle invoice: %v", err)
} }
stream := invoiceStreams[i]
invoice, err := stream.Recv()
require.NoError(t.t, err)
require.Equal(t.t, expectedState, invoice.State)
} }
// Make sure we get the expected status update. // Make sure we get the expected status update.