2022-08-12 11:03:44 +02:00
|
|
|
package lntest
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/btcsuite/btcd/integration/rpctest"
|
2024-05-01 12:20:21 +02:00
|
|
|
"github.com/lightningnetwork/lnd/lntest/miner"
|
2022-08-12 11:03:44 +02:00
|
|
|
"github.com/lightningnetwork/lnd/lntest/node"
|
2024-03-15 12:54:41 +01:00
|
|
|
"github.com/lightningnetwork/lnd/lntest/wait"
|
2022-07-22 14:57:23 +02:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SetupHarness creates a new HarnessTest with a series of setups such that the
|
|
|
|
// instance is ready for usage. The setups are,
|
|
|
|
// 1. create the directories to hold lnd files.
|
|
|
|
// 2. start a btcd miner.
|
|
|
|
// 3. start a chain backend(btcd, bitcoind, or neutrino).
|
|
|
|
// 4. connect the miner and the chain backend.
|
|
|
|
// 5. start the HarnessTest.
|
2022-08-16 11:31:20 +02:00
|
|
|
func SetupHarness(t *testing.T, binaryPath, dbBackendName string,
|
2023-12-12 14:50:15 +01:00
|
|
|
nativeSQL bool, feeService WebFeeService) *HarnessTest {
|
2022-08-16 11:31:20 +02:00
|
|
|
|
2022-07-22 14:57:23 +02:00
|
|
|
t.Log("Setting up HarnessTest...")
|
|
|
|
|
|
|
|
// Parse testing flags that influence our test execution.
|
2022-08-12 07:07:16 +02:00
|
|
|
logDir := node.GetLogDir()
|
2022-07-22 14:57:23 +02:00
|
|
|
require.NoError(t, os.MkdirAll(logDir, 0700), "create log dir failed")
|
|
|
|
|
|
|
|
// Parse database backend
|
2023-01-31 17:32:03 +01:00
|
|
|
dbBackend := prepareDBBackend(t, dbBackendName)
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
// Create a new HarnessTest.
|
2023-12-12 14:50:15 +01:00
|
|
|
ht := NewHarnessTest(t, binaryPath, feeService, dbBackend, nativeSQL)
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
// Init the miner.
|
|
|
|
t.Log("Prepare the miner and mine blocks to activate segwit...")
|
|
|
|
miner := prepareMiner(ht.runCtx, ht.T)
|
|
|
|
|
|
|
|
// Start a chain backend.
|
|
|
|
chainBackend, cleanUp := prepareChainBackend(t, miner.P2PAddress())
|
|
|
|
ht.stopChainBackend = cleanUp
|
|
|
|
|
|
|
|
// Connect our chainBackend to our miner.
|
2024-03-15 12:54:41 +01:00
|
|
|
t.Logf("Connecting the miner at %v with the chain backend...",
|
|
|
|
miner.P2PAddress())
|
|
|
|
|
|
|
|
// Give the chain backend some time to fully start up, re-trying if any
|
|
|
|
// errors in connecting to the miner are encountered.
|
|
|
|
err := wait.NoError(func() error {
|
|
|
|
return chainBackend.ConnectMiner()
|
|
|
|
}, DefaultTimeout)
|
|
|
|
require.NoError(t, err, "connect miner")
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
// Start the HarnessTest with the chainBackend and miner.
|
|
|
|
ht.Start(chainBackend, miner)
|
|
|
|
|
|
|
|
return ht
|
|
|
|
}
|
|
|
|
|
|
|
|
// prepareMiner creates an instance of the btcd's rpctest.Harness that will act
|
|
|
|
// as the miner for all tests. This will be used to fund the wallets of the
|
|
|
|
// nodes within the test network and to drive blockchain related events within
|
|
|
|
// the network. Revert the default setting of accepting non-standard
|
|
|
|
// transactions on simnet to reject them. Transactions on the lightning network
|
|
|
|
// should always be standard to get better guarantees of getting included in to
|
|
|
|
// blocks.
|
2024-05-01 12:20:21 +02:00
|
|
|
func prepareMiner(ctxt context.Context, t *testing.T) *miner.HarnessMiner {
|
|
|
|
m := miner.NewMiner(ctxt, t)
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
// Before we start anything, we want to overwrite some of the
|
|
|
|
// connection settings to make the tests more robust. We might need to
|
|
|
|
// restart the miner while there are already blocks present, which will
|
|
|
|
// take a bit longer than the 1 second the default settings amount to.
|
|
|
|
// Doubling both values will give us retries up to 4 seconds.
|
2024-05-01 12:20:21 +02:00
|
|
|
m.MaxConnRetries = rpctest.DefaultMaxConnectionRetries * 2
|
|
|
|
m.ConnectionRetryTimeout = rpctest.DefaultConnectionRetryTimeout * 2
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
// Set up miner and connect chain backend to it.
|
2024-05-01 12:20:21 +02:00
|
|
|
require.NoError(t, m.SetUp(true, 50))
|
|
|
|
require.NoError(t, m.Client.NotifyNewTransactions(false))
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
// Next mine enough blocks in order for segwit and the CSV package
|
|
|
|
// soft-fork to activate on SimNet.
|
2024-05-01 12:20:21 +02:00
|
|
|
numBlocks := miner.HarnessNetParams.MinerConfirmationWindow * 2
|
|
|
|
m.GenerateBlocks(numBlocks)
|
2022-07-22 14:57:23 +02:00
|
|
|
|
2024-05-01 12:20:21 +02:00
|
|
|
return m
|
2022-07-22 14:57:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// prepareChainBackend creates a new chain backend.
|
|
|
|
func prepareChainBackend(t *testing.T,
|
2022-08-12 07:07:16 +02:00
|
|
|
minerAddr string) (node.BackendConfig, func()) {
|
2022-07-22 14:57:23 +02:00
|
|
|
|
2022-08-12 11:03:44 +02:00
|
|
|
chainBackend, cleanUp, err := NewBackend(
|
2024-05-01 12:20:21 +02:00
|
|
|
minerAddr, miner.HarnessNetParams,
|
2022-07-22 14:57:23 +02:00
|
|
|
)
|
|
|
|
require.NoError(t, err, "new backend")
|
|
|
|
|
|
|
|
return chainBackend, func() {
|
|
|
|
require.NoError(t, cleanUp(), "cleanup")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-31 17:32:03 +01:00
|
|
|
// prepareDBBackend parses a DatabaseBackend based on the name given.
|
|
|
|
func prepareDBBackend(t *testing.T,
|
2022-08-12 07:07:16 +02:00
|
|
|
dbBackendName string) node.DatabaseBackend {
|
2022-07-22 14:57:23 +02:00
|
|
|
|
2022-08-12 07:07:16 +02:00
|
|
|
var dbBackend node.DatabaseBackend
|
2022-07-22 14:57:23 +02:00
|
|
|
switch dbBackendName {
|
|
|
|
case "bbolt":
|
2022-08-12 07:07:16 +02:00
|
|
|
dbBackend = node.BackendBbolt
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
case "etcd":
|
2022-08-12 07:07:16 +02:00
|
|
|
dbBackend = node.BackendEtcd
|
2022-07-22 14:57:23 +02:00
|
|
|
|
|
|
|
case "postgres":
|
2022-08-12 07:07:16 +02:00
|
|
|
dbBackend = node.BackendPostgres
|
2022-07-22 14:57:23 +02:00
|
|
|
|
2022-12-14 10:54:47 +01:00
|
|
|
case "sqlite":
|
2022-08-12 07:07:16 +02:00
|
|
|
dbBackend = node.BackendSqlite
|
2022-12-14 10:54:47 +01:00
|
|
|
|
2022-07-22 14:57:23 +02:00
|
|
|
default:
|
|
|
|
require.Fail(t, "unknown db backend")
|
|
|
|
}
|
|
|
|
|
|
|
|
return dbBackend
|
|
|
|
}
|