From 1483ed119b8c7f86b04b990b4960da007d166882 Mon Sep 17 00:00:00 2001 From: Conner Fromknecht Date: Thu, 10 Dec 2020 15:05:22 -0800 Subject: [PATCH 1/5] make: use low-scrypt to speed up unit-race This predominately affects the lnwallet unit tests which are the bulk of the execution time. --- lnwallet/btcwallet/btcwallet_rpctest.go | 2 +- make/testing_flags.mk | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lnwallet/btcwallet/btcwallet_rpctest.go b/lnwallet/btcwallet/btcwallet_rpctest.go index 7139e4cc..28dd35a7 100644 --- a/lnwallet/btcwallet/btcwallet_rpctest.go +++ b/lnwallet/btcwallet/btcwallet_rpctest.go @@ -1,4 +1,4 @@ -// +build rpctest +// +build rpctest lowscrypt package btcwallet diff --git a/make/testing_flags.mk b/make/testing_flags.mk index da5cbeb1..88287f84 100644 --- a/make/testing_flags.mk +++ b/make/testing_flags.mk @@ -86,7 +86,7 @@ UNIT_TARGETED ?= no # targeted case. Otherwise, default to running all tests. ifeq ($(UNIT_TARGETED), yes) UNIT := $(GOTEST) -tags="$(DEV_TAGS) $(LOG_TAGS)" $(TEST_FLAGS) $(UNITPKG) -UNIT_RACE := $(GOTEST) -tags="$(DEV_TAGS) $(LOG_TAGS)" $(TEST_FLAGS) -race $(UNITPKG) +UNIT_RACE := $(GOTEST) -tags="$(DEV_TAGS) $(LOG_TAGS) lowscrypt" $(TEST_FLAGS) -race $(UNITPKG) endif ifeq ($(UNIT_TARGETED), no) From 87787ce771cf7d0a2952e5a1841c8610a589f141 Mon Sep 17 00:00:00 2001 From: Conner Fromknecht Date: Thu, 10 Dec 2020 15:20:15 -0800 Subject: [PATCH 2/5] lnwallet: move interface_test.go to it's own package --- lnwallet/{ => test}/interface_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename lnwallet/{ => test}/interface_test.go (99%) diff --git a/lnwallet/interface_test.go b/lnwallet/test/interface_test.go similarity index 99% rename from lnwallet/interface_test.go rename to lnwallet/test/interface_test.go index c37464ce..771c1692 100644 --- a/lnwallet/interface_test.go +++ b/lnwallet/test/interface_test.go @@ -1,4 +1,4 @@ -package lnwallet_test +package lnwallettest_test import ( "bytes" From 0d57ff2432eb4839684d857057f596208812fdda Mon Sep 17 00:00:00 2001 From: Conner Fromknecht Date: Thu, 10 Dec 2020 15:51:41 -0800 Subject: [PATCH 3/5] lnwallet/test: execute ifacet tests for each backend in parallel --- lnwallet/test/bitcoind/bitcoind_test.go | 13 +++++++++++++ lnwallet/test/btcd/btcd_test.go | 13 +++++++++++++ lnwallet/test/neutrino/neutrino_test.go | 13 +++++++++++++ .../test/{interface_test.go => test_interface.go} | 8 ++++++-- 4 files changed, 45 insertions(+), 2 deletions(-) create mode 100644 lnwallet/test/bitcoind/bitcoind_test.go create mode 100644 lnwallet/test/btcd/btcd_test.go create mode 100644 lnwallet/test/neutrino/neutrino_test.go rename lnwallet/test/{interface_test.go => test_interface.go} (99%) diff --git a/lnwallet/test/bitcoind/bitcoind_test.go b/lnwallet/test/bitcoind/bitcoind_test.go new file mode 100644 index 00000000..a5df2528 --- /dev/null +++ b/lnwallet/test/bitcoind/bitcoind_test.go @@ -0,0 +1,13 @@ +package bitcoind_test + +import ( + "testing" + + lnwallettest "github.com/lightningnetwork/lnd/lnwallet/test" +) + +// TestLightningWallet tests LightningWallet powered by bitcoind against our +// suite of interface tests. +func TestLightningWallet(t *testing.T) { + lnwallettest.TestLightningWallet(t, "bitcoind") +} diff --git a/lnwallet/test/btcd/btcd_test.go b/lnwallet/test/btcd/btcd_test.go new file mode 100644 index 00000000..c18b0e5f --- /dev/null +++ b/lnwallet/test/btcd/btcd_test.go @@ -0,0 +1,13 @@ +package btcd_test + +import ( + "testing" + + lnwallettest "github.com/lightningnetwork/lnd/lnwallet/test" +) + +// TestLightningWallet tests LightningWallet powered by btcd against our suite +// of interface tests. +func TestLightningWallet(t *testing.T) { + lnwallettest.TestLightningWallet(t, "btcd") +} diff --git a/lnwallet/test/neutrino/neutrino_test.go b/lnwallet/test/neutrino/neutrino_test.go new file mode 100644 index 00000000..c3631c83 --- /dev/null +++ b/lnwallet/test/neutrino/neutrino_test.go @@ -0,0 +1,13 @@ +package neutrino_test + +import ( + "testing" + + lnwallettest "github.com/lightningnetwork/lnd/lnwallet/test" +) + +// TestLightningWallet tests LightningWallet powered by neutrino against our +// suite of interface tests. +func TestLightningWallet(t *testing.T) { + lnwallettest.TestLightningWallet(t, "neutrino") +} diff --git a/lnwallet/test/interface_test.go b/lnwallet/test/test_interface.go similarity index 99% rename from lnwallet/test/interface_test.go rename to lnwallet/test/test_interface.go index 771c1692..52c9522a 100644 --- a/lnwallet/test/interface_test.go +++ b/lnwallet/test/test_interface.go @@ -1,4 +1,4 @@ -package lnwallettest_test +package lnwallettest import ( "bytes" @@ -3086,7 +3086,7 @@ func testSingleFunderExternalFundingTx(miner *rpctest.Harness, // below needs to be added which properly initializes the interface. // // TODO(roasbeef): purge bobNode in favor of dual lnwallet's -func TestLightningWallet(t *testing.T) { +func TestLightningWallet(t *testing.T, targetBackEnd string) { t.Parallel() // Initialize the harness around a btcd node which will serve as our @@ -3140,6 +3140,10 @@ func TestLightningWallet(t *testing.T) { for _, walletDriver := range lnwallet.RegisteredWallets() { for _, backEnd := range walletDriver.BackEnds() { + if backEnd != targetBackEnd { + continue + } + if !runTests(t, walletDriver, backEnd, miningNode, rpcConfig, chainNotifier) { return From ea8d02eb68796b4827be6fd1abfeb498f491ad2c Mon Sep 17 00:00:00 2001 From: Conner Fromknecht Date: Thu, 10 Dec 2020 20:56:10 -0800 Subject: [PATCH 4/5] chainntnfs/test: parallelize iface tests by backend --- chainntnfs/test/bitcoind/bitcoind_test.go | 15 +++++++++++++++ chainntnfs/test/btcd/btcd_test.go | 15 +++++++++++++++ chainntnfs/test/neutrino/neutrino_test.go | 15 +++++++++++++++ .../{interface_test.go => test/test_interface.go} | 14 +++++++++----- 4 files changed, 54 insertions(+), 5 deletions(-) create mode 100644 chainntnfs/test/bitcoind/bitcoind_test.go create mode 100644 chainntnfs/test/btcd/btcd_test.go create mode 100644 chainntnfs/test/neutrino/neutrino_test.go rename chainntnfs/{interface_test.go => test/test_interface.go} (99%) diff --git a/chainntnfs/test/bitcoind/bitcoind_test.go b/chainntnfs/test/bitcoind/bitcoind_test.go new file mode 100644 index 00000000..df9d3853 --- /dev/null +++ b/chainntnfs/test/bitcoind/bitcoind_test.go @@ -0,0 +1,15 @@ +// +build dev + +package bitcoind_test + +import ( + "testing" + + chainntnfstest "github.com/lightningnetwork/lnd/chainntnfs/test" +) + +// TestInterfaces executes the generic notifier test suite against a bitcoind +// powered chain notifier. +func TestInterfaces(t *testing.T) { + chainntnfstest.TestInterfaces(t, "bitcoind") +} diff --git a/chainntnfs/test/btcd/btcd_test.go b/chainntnfs/test/btcd/btcd_test.go new file mode 100644 index 00000000..320d6d8a --- /dev/null +++ b/chainntnfs/test/btcd/btcd_test.go @@ -0,0 +1,15 @@ +// +build dev + +package btcd_test + +import ( + "testing" + + chainntnfstest "github.com/lightningnetwork/lnd/chainntnfs/test" +) + +// TestInterfaces executes the generic notifier test suite against a btcd +// powered chain notifier. +func TestInterfaces(t *testing.T) { + chainntnfstest.TestInterfaces(t, "btcd") +} diff --git a/chainntnfs/test/neutrino/neutrino_test.go b/chainntnfs/test/neutrino/neutrino_test.go new file mode 100644 index 00000000..ac6a09cf --- /dev/null +++ b/chainntnfs/test/neutrino/neutrino_test.go @@ -0,0 +1,15 @@ +// +build dev + +package neutrino_test + +import ( + "testing" + + chainntnfstest "github.com/lightningnetwork/lnd/chainntnfs/test" +) + +// TestInterfaces executes the generic notifier test suite against a neutrino +// powered chain notifier. +func TestInterfaces(t *testing.T) { + chainntnfstest.TestInterfaces(t, "neutrino") +} diff --git a/chainntnfs/interface_test.go b/chainntnfs/test/test_interface.go similarity index 99% rename from chainntnfs/interface_test.go rename to chainntnfs/test/test_interface.go index 70c4432e..c38ac65e 100644 --- a/chainntnfs/interface_test.go +++ b/chainntnfs/test/test_interface.go @@ -1,6 +1,6 @@ // +build dev -package chainntnfs_test +package chainntnfstest import ( "bytes" @@ -1893,7 +1893,7 @@ var blockCatchupTests = []blockCatchupTestCase{ // import should trigger an init() method within the package which registers // the interface. Second, an additional case in the switch within the main loop // below needs to be added which properly initializes the interface. -func TestInterfaces(t *testing.T) { +func TestInterfaces(t *testing.T, targetBackEnd string) { // Initialize the harness around a btcd node which will serve as our // dedicated miner to generate blocks, cause re-orgs, etc. We'll set up // this node with a chain length of 125, so we have plenty of BTC to @@ -1908,6 +1908,11 @@ func TestInterfaces(t *testing.T) { 2*len(txNtfnTests)+len(blockNtfnTests)+len(blockCatchupTests)) for _, notifierDriver := range chainntnfs.RegisteredNotifiers() { + notifierType := notifierDriver.NotifierType + if notifierType != targetBackEnd { + continue + } + // Initialize a height hint cache for each notifier. tempDir, err := ioutil.TempDir("", "channeldb") if err != nil { @@ -1926,9 +1931,8 @@ func TestInterfaces(t *testing.T) { } var ( - cleanUp func() - newNotifier func() (chainntnfs.TestChainNotifier, error) - notifierType = notifierDriver.NotifierType + cleanUp func() + newNotifier func() (chainntnfs.TestChainNotifier, error) ) switch notifierType { From c2c520e43140e494ff85f9befd0178c6f01f4ff2 Mon Sep 17 00:00:00 2001 From: Conner Fromknecht Date: Thu, 10 Dec 2020 22:08:44 -0800 Subject: [PATCH 5/5] make: pass dev tag to go-acc Previously we were excluding non-dev test files from our coverage report, which included interface_test.go as well as the bitcoindnotify and btcdnotify dev tests. --- make/testing_flags.mk | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/make/testing_flags.mk b/make/testing_flags.mk index 88287f84..cdfc4d6f 100644 --- a/make/testing_flags.mk +++ b/make/testing_flags.mk @@ -4,7 +4,7 @@ LOG_TAGS = TEST_FLAGS = ITEST_FLAGS = EXEC_SUFFIX = -COVER_PKG = $$(go list -deps ./... | grep '$(PKG)' | grep -v lnrpc) +COVER_PKG = $$(go list -deps -tags="$(DEV_TAGS)" ./... | grep '$(PKG)' | grep -v lnrpc) NUM_ITEST_TRANCHES = 4 ITEST_PARALLELISM = $(NUM_ITEST_TRANCHES)