lnd/lntest
yyforyongyu 2bc6aabf96
itest: fix make lint
This commit fixes the issues reported by the linter.
2023-02-23 21:56:10 +08:00
..
channels lntest/channels: introduce subpackage to deduplicate static structs 2021-01-25 14:04:39 -05:00
mock walletrpc+lnwallet: possibility to define an address type for changes in FundPsbt 2023-02-08 12:35:44 +01:00
node itest: fix make lint 2023-02-23 21:56:10 +08:00
rpc itest+lntest: migrate lntemp to lntest 2023-02-23 21:56:09 +08:00
wait itest: fix test async_bidirectional_payments 2023-02-23 21:56:09 +08:00
bitcoind_common.go itest+lntest: migrate lntemp to lntest 2023-02-23 21:56:09 +08:00
bitcoind_notxindex.go multi: new bitcoind rpcpolling backend for itests 2022-05-11 09:02:13 +02:00
bitcoind_rpcpolling.go multi: new bitcoind rpcpolling backend for itests 2022-05-11 09:02:13 +02:00
bitcoind.go multi: new bitcoind rpcpolling backend for itests 2022-05-11 09:02:13 +02:00
btcd.go itest: fix make lint 2023-02-23 21:56:10 +08:00
doc.go lntest: Add doc.go with package documentation. 2017-12-14 20:06:23 -08:00
fee_service.go itest: fix make lint 2023-02-23 21:56:10 +08:00
harness_assertion.go itest: fix make lint 2023-02-23 21:56:10 +08:00
harness_miner.go itest: fix make lint 2023-02-23 21:56:10 +08:00
harness_node_manager.go itest: fix make lint 2023-02-23 21:56:10 +08:00
harness_setup.go itest+lntest: migrate lntemp to lntest 2023-02-23 21:56:09 +08:00
harness.go itest: fix make lint 2023-02-23 21:56:10 +08:00
neutrino.go itest+lntest: migrate lntemp to lntest 2023-02-23 21:56:09 +08:00
README.md itest+lntest: migrate lntemp to lntest 2023-02-23 21:56:09 +08:00
utils.go itest: fix make lint 2023-02-23 21:56:10 +08:00

lntest

lntest is a package which holds the components used for the lnds integration tests. It is responsible for managing lnd nodes, chain backends and miners, advancing nodes states and providing assertions.

Quick Start

A simple example to run the integration test.

func TestFoo(t *testing.T) {
	// Get the binary path and setup the harness test.
	//
	// TODO: define the binary path to lnd and the name of the database
	// backend.
	harnessTest := lntemp.SetupHarness(t, binary, *dbBackendFlag)
	defer harnessTest.Stop()

	// Setup standby nodes, Alice and Bob, which will be alive and shared
	// among all the test cases.
	harnessTest.SetupStandbyNodes()

	// Run the subset of the test cases selected in this tranche.
	//
	// TODO: define your own testCases.
	for _, tc := range testCases {
		tc := tc

		t.Run(tc.Name, func(st *testing.T) {
			// Create a separate harness test for the testcase to
			// avoid overwriting the external harness test that is
			// tied to the parent test.
			ht := harnessTest.Subtest(st)

			// Run the test cases.
			ht.RunTestCase(tc)
		})
	}
}

Package Structure

This package has four major components, HarnessTest, HarnessMiner, node.HarnessNode and rpc.HarnessRPC, with the following architecture,

+----------------------------------------------------------+
|                                                          |
|                        HarnessTest                       |
|                                                          |
| +----------------+  +----------------+  +--------------+ |
| |   HarnessNode  |  |   HarnessNode  |  | HarnessMiner | |
| |                |  |                |  +--------------+ |
| | +------------+ |  | +------------+ |                   |
| | | HarnessRPC | |  | | HarnessRPC | |  +--------------+ |
| | +------------+ |  | +------------+ |  | HarnessMiner | |
| +----------------+  +----------------+  +--------------+ |
+----------------------------------------------------------+
  • HarnessRPC holds all the RPC clients and adds a layer over all the RPC methods to assert no error happened at the RPC level.

  • HarnessNode builds on top of the HarnessRPC. It is responsible for managing the lnd node, including start and stop pf the lnd process, authentication of the gRPC connection, topology subscription(NodeWatcher) and maintains an internal state(NodeState).

  • HarnessMiner builds on top of btcds rcptest.Harness and is responsilbe for managing blocks and the mempool.

  • HarnessTest builds on top of testing.T and can be viewed as the assertion machine. It provides multiple ways to initialize a node, such as with/without seed, backups, etc. It also handles interactions between nodes like connecting nodes and opening/closing channels so its easier to acquire or validate a desired test states such as nodes balance, mempool condition, etc.

Standby Nodes

Standby nodes are HarnessNodes created when initializing the integration test and stay alive across all the test cases. Creating a new node is not without a cost. With block height increasing, it takes significantly longer to initialize a new node and wait for it to be synced. Standby nodes, however, dont have this problem as they are digesting blocks all the time. Thus its encouraged to use standby nodes wherever possible.

Currently there are two standby nodes, Alice and Bob. Their internal states are recorded and taken into account when HarnessTest makes assertions. When making a new test case using Subtest, theres a cleanup function which further validates the current test case has no dangling uncleaned states, such as transactions left in mempool, open channels, etc.