From a926665358b259113e936481dbda18a12090f3cb Mon Sep 17 00:00:00 2001 From: "Johan T. Halseth" Date: Tue, 11 Sep 2018 10:25:48 +0200 Subject: [PATCH 1/2] lnd_test: make sure we stay disconnected using WaitInvariant in testGarbageCollectLinkNodes --- lnd_test.go | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/lnd_test.go b/lnd_test.go index 24079bf3..9cd55213 100644 --- a/lnd_test.go +++ b/lnd_test.go @@ -5663,6 +5663,12 @@ func testGarbageCollectLinkNodes(net *lntest.NetworkHarness, t *harnessTest) { if err != nil { t.Fatalf("alice did not reconnect to carol") } + err = lntest.WaitPredicate(func() bool { + return isConnected(dave.PubKeyStr) + }, 15*time.Second) + if err != nil { + t.Fatalf("alice did not reconnect to dave") + } // testReconnection is a helper closure that restarts the nodes at both // ends of a channel to ensure they do not reconnect after restarting. @@ -5674,9 +5680,9 @@ func testGarbageCollectLinkNodes(net *lntest.NetworkHarness, t *harnessTest) { t.Fatalf("unable to restart %v's node: %v", node.Name(), err) } - err = lntest.WaitPredicate(func() bool { + err = lntest.WaitInvariant(func() bool { return !isConnected(node.PubKeyStr) - }, 20*time.Second) + }, 5*time.Second) if err != nil { t.Fatalf("alice reconnected to %v", node.Name()) } @@ -5685,11 +5691,15 @@ func testGarbageCollectLinkNodes(net *lntest.NetworkHarness, t *harnessTest) { t.Fatalf("unable to restart alice's node: %v", err) } err = lntest.WaitPredicate(func() bool { - if !isConnected(dave.PubKeyStr) { - return false - } - return !isConnected(node.PubKeyStr) + return isConnected(dave.PubKeyStr) }, 20*time.Second) + if err != nil { + t.Fatalf("alice didn't reconnect to Dave") + } + + err = lntest.WaitInvariant(func() bool { + return !isConnected(node.PubKeyStr) + }, 5*time.Second) if err != nil { t.Fatalf("alice reconnected to %v", node.Name()) } From 598904fbb9e292f30d49d7953c65b82ac41e89c4 Mon Sep 17 00:00:00 2001 From: "Johan T. Halseth" Date: Tue, 11 Sep 2018 10:25:48 +0200 Subject: [PATCH 2/2] lnd_test: restart nodes twice to trigger pruning logic --- lnd_test.go | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/lnd_test.go b/lnd_test.go index 9cd55213..acf8610e 100644 --- a/lnd_test.go +++ b/lnd_test.go @@ -5676,6 +5676,17 @@ func testGarbageCollectLinkNodes(net *lntest.NetworkHarness, t *harnessTest) { // reestablished her connection with Dave, as they still have an open // channel together. testReconnection := func(node *lntest.HarnessNode) { + // Restart both nodes, to trigger the pruning logic. + if err := net.RestartNode(node, nil); err != nil { + t.Fatalf("unable to restart %v's node: %v", + node.Name(), err) + } + + if err := net.RestartNode(net.Alice, nil); err != nil { + t.Fatalf("unable to restart alice's node: %v", err) + } + + // Now restart both nodes and make sure they don't reconnect. if err := net.RestartNode(node, nil); err != nil { t.Fatalf("unable to restart %v's node: %v", node.Name(), err)