2019-10-03 15:53:21 -03:00
|
|
|
#!/usr/bin/env python3
|
2021-07-28 07:57:16 -04:00
|
|
|
# Copyright (c) 2017-2021 The Bitcoin Core developers
|
2019-10-03 15:53:21 -03:00
|
|
|
# Distributed under the MIT software license, see the accompanying
|
|
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
"""Test loadblock option
|
|
|
|
|
|
|
|
Test the option to start a node with the option loadblock which loads
|
|
|
|
a serialized blockchain from a file (usually called bootstrap.dat).
|
|
|
|
To generate that file this test uses the helper scripts available
|
|
|
|
in contrib/linearize.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
import sys
|
|
|
|
import tempfile
|
|
|
|
import urllib
|
|
|
|
|
2021-05-17 10:38:19 -04:00
|
|
|
from test_framework.blocktools import COINBASE_MATURITY
|
2020-05-04 20:06:38 -04:00
|
|
|
from test_framework.test_framework import BitcoinTestFramework
|
|
|
|
from test_framework.util import assert_equal
|
2019-10-03 15:53:21 -03:00
|
|
|
|
|
|
|
|
|
|
|
class LoadblockTest(BitcoinTestFramework):
|
|
|
|
def set_test_params(self):
|
|
|
|
self.setup_clean_chain = True
|
|
|
|
self.num_nodes = 2
|
2019-12-06 11:37:49 -03:00
|
|
|
self.supports_cli = False
|
2019-10-03 15:53:21 -03:00
|
|
|
|
|
|
|
def run_test(self):
|
|
|
|
self.nodes[1].setnetworkactive(state=False)
|
2020-11-10 14:02:31 -03:00
|
|
|
self.generate(self.nodes[0], COINBASE_MATURITY, sync_fun=self.no_op)
|
2019-10-03 15:53:21 -03:00
|
|
|
|
|
|
|
# Parsing the url of our node to get settings for config file
|
|
|
|
data_dir = self.nodes[0].datadir
|
|
|
|
node_url = urllib.parse.urlparse(self.nodes[0].url)
|
|
|
|
cfg_file = os.path.join(data_dir, "linearize.cfg")
|
|
|
|
bootstrap_file = os.path.join(self.options.tmpdir, "bootstrap.dat")
|
|
|
|
genesis_block = self.nodes[0].getblockhash(0)
|
2023-06-14 07:00:11 -04:00
|
|
|
blocks_dir = self.nodes[0].chain_path / "blocks"
|
2019-10-03 15:53:21 -03:00
|
|
|
hash_list = tempfile.NamedTemporaryFile(dir=data_dir,
|
|
|
|
mode='w',
|
|
|
|
delete=False,
|
|
|
|
encoding="utf-8")
|
|
|
|
|
|
|
|
self.log.info("Create linearization config file")
|
|
|
|
with open(cfg_file, "a", encoding="utf-8") as cfg:
|
2021-06-11 02:33:32 -04:00
|
|
|
cfg.write(f"datadir={data_dir}\n")
|
|
|
|
cfg.write(f"rpcuser={node_url.username}\n")
|
|
|
|
cfg.write(f"rpcpassword={node_url.password}\n")
|
|
|
|
cfg.write(f"port={node_url.port}\n")
|
|
|
|
cfg.write(f"host={node_url.hostname}\n")
|
|
|
|
cfg.write(f"output_file={bootstrap_file}\n")
|
|
|
|
cfg.write(f"max_height=100\n")
|
|
|
|
cfg.write(f"netmagic=fabfb5da\n")
|
|
|
|
cfg.write(f"input={blocks_dir}\n")
|
|
|
|
cfg.write(f"genesis={genesis_block}\n")
|
|
|
|
cfg.write(f"hashlist={hash_list.name}\n")
|
2019-10-03 15:53:21 -03:00
|
|
|
|
|
|
|
base_dir = self.config["environment"]["SRCDIR"]
|
|
|
|
linearize_dir = os.path.join(base_dir, "contrib", "linearize")
|
|
|
|
|
|
|
|
self.log.info("Run linearization of block hashes")
|
|
|
|
linearize_hashes_file = os.path.join(linearize_dir, "linearize-hashes.py")
|
|
|
|
subprocess.run([sys.executable, linearize_hashes_file, cfg_file],
|
|
|
|
stdout=hash_list,
|
|
|
|
check=True)
|
|
|
|
|
|
|
|
self.log.info("Run linearization of block data")
|
|
|
|
linearize_data_file = os.path.join(linearize_dir, "linearize-data.py")
|
|
|
|
subprocess.run([sys.executable, linearize_data_file, cfg_file],
|
|
|
|
check=True)
|
|
|
|
|
|
|
|
self.log.info("Restart second, unsynced node with bootstrap file")
|
2021-06-11 02:33:32 -04:00
|
|
|
self.restart_node(1, extra_args=[f"-loadblock={bootstrap_file}"])
|
2020-05-04 20:06:38 -04:00
|
|
|
assert_equal(self.nodes[1].getblockcount(), 100) # start_node is blocking on all block files being imported
|
2019-10-03 15:53:21 -03:00
|
|
|
|
|
|
|
assert_equal(self.nodes[1].getblockchaininfo()['blocks'], 100)
|
|
|
|
assert_equal(self.nodes[0].getbestblockhash(), self.nodes[1].getbestblockhash())
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
LoadblockTest().main()
|