From d0abb8219cd00d91c7f821b82690a631413ec446 Mon Sep 17 00:00:00 2001 From: Olaoluwa Osuntokun Date: Mon, 22 Jan 2018 21:06:27 -0800 Subject: [PATCH] test: wrap assertion in WaitPredicate in testMultiHopReceiverChainClaim --- lnd_test.go | 26 ++++++++++++++++++++------ 1 file changed, 20 insertions(+), 6 deletions(-) diff --git a/lnd_test.go b/lnd_test.go index c4867b47..dae6dbc1 100644 --- a/lnd_test.go +++ b/lnd_test.go @@ -5467,13 +5467,22 @@ func testMultiHopReceiverChainClaim(net *lntest.NetworkHarness, t *harnessTest) if _, err := net.Miner.Node.Generate(1); err != nil { t.Fatalf("unable to mine block: %v", err) } - pendingChanResp, err = carol.PendingChannels(ctxb, pendingChansRequest) + err = lntest.WaitPredicate(func() bool { + pendingChanResp, err = carol.PendingChannels(ctxb, pendingChansRequest) + if err != nil { + predErr = fmt.Errorf("unable to query for pending channels: %v", err) + return false + } + if len(pendingChanResp.PendingForceClosingChannels) != 0 { + predErr = fmt.Error("carol still has pending channels: %v", + spew.Sdump(pendingChanResp)) + return false + } + + return true + }, time.Second*15) if err != nil { - t.Fatalf("unable to query for pending channels: %v", err) - } - if len(pendingChanResp.PendingForceClosingChannels) != 0 { - t.Fatalf("carol still has pending channels: %v", - spew.Sdump(pendingChanResp)) + t.Fatalf(predErr.Error()) } // We'll close out the channel between Alice and Bob, then shutdown @@ -6067,6 +6076,11 @@ func testMultiHopHtlcLocalChainClaim(net *lntest.NetworkHarness, t *harnessTest) t.Fatalf("unable to generate block: %v", err) } + _, err = waitForTxInMempool(net.Miner.Node, time.Second*10) + if err != nil { + t.Fatalf("unable to find bob's sweeping transaction") + } + // At this point, Bob should detect that he has no pending channels // anymore, as this just resolved it by the confirmation of the sweep // transaction we detected above.