Skip to content

Commit 16d4b3f

Browse files
committed
test: mempool.dat compatibility between versions
1 parent f8364df commit 16d4b3f

File tree

2 files changed

+79
-0
lines changed

2 files changed

+79
-0
lines changed
Lines changed: 78 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,78 @@
1+
#!/usr/bin/env python3
2+
# Copyright (c) 2017-2020 The Bitcoin Core developers
3+
# Distributed under the MIT software license, see the accompanying
4+
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
5+
"""Test that mempool.dat is both backward and forward compatible between versions
6+
7+
NOTE: The test is designed to prevent cases when compatibility is broken accidentally.
8+
In case we need to break mempool compatibility we can continue to use the test by just bumping the version number.
9+
10+
Download node binaries:
11+
contrib/devtools/previous_release.sh -b v0.19.1 v0.18.1 v0.17.1 v0.16.3 v0.15.2
12+
13+
Only v0.15.2 is required by this test. The rest is used in other backwards compatibility tests.
14+
"""
15+
16+
import os
17+
18+
from test_framework.test_framework import BitcoinTestFramework
19+
from test_framework.util import (
20+
adjust_bitcoin_conf_for_pre_17
21+
)
22+
23+
class MempoolCompatibilityTest(BitcoinTestFramework):
24+
def set_test_params(self):
25+
self.num_nodes = 2
26+
27+
def skip_test_if_missing_module(self):
28+
self.skip_if_no_wallet()
29+
self.skip_if_no_previous_releases()
30+
31+
def setup_network(self):
32+
self.add_nodes(self.num_nodes, versions=[
33+
150200, # oldest version supported by the test framework
34+
None,
35+
])
36+
adjust_bitcoin_conf_for_pre_17(self.nodes[0].bitcoinconf)
37+
self.start_nodes()
38+
self.import_deterministic_coinbase_privkeys()
39+
40+
def run_test(self):
41+
self.log.info("Test that mempool.dat is compatible between versions")
42+
43+
old_node = self.nodes[0]
44+
new_node = self.nodes[1]
45+
recipient = old_node.getnewaddress()
46+
self.stop_node(1)
47+
48+
self.log.info("Add a transaction to mempool on old node and shutdown")
49+
old_tx_hash = old_node.sendtoaddress(recipient, 0.0001)
50+
assert old_tx_hash in old_node.getrawmempool()
51+
self.stop_node(0)
52+
53+
self.log.info("Move mempool.dat from old to new node")
54+
old_node_mempool = os.path.join(old_node.datadir, self.chain, 'mempool.dat')
55+
new_node_mempool = os.path.join(new_node.datadir, self.chain, 'mempool.dat')
56+
os.rename(old_node_mempool, new_node_mempool)
57+
58+
self.log.info("Start new node and verify mempool contains the tx")
59+
self.start_node(1)
60+
assert old_tx_hash in new_node.getrawmempool()
61+
62+
self.log.info("Add unbroadcasted tx to mempool on new node and shutdown")
63+
unbroadcasted_tx_hash = new_node.sendtoaddress(recipient, 0.0001)
64+
assert unbroadcasted_tx_hash in new_node.getrawmempool()
65+
mempool = new_node.getrawmempool(True)
66+
assert mempool[unbroadcasted_tx_hash]['unbroadcast']
67+
self.stop_node(1)
68+
69+
self.log.info("Move mempool.dat from new to old node")
70+
os.rename(new_node_mempool, old_node_mempool)
71+
72+
self.log.info("Start old node again and verify mempool contains both txs")
73+
self.start_node(0, ['-nowallet'])
74+
assert old_tx_hash in old_node.getrawmempool()
75+
assert unbroadcasted_tx_hash in old_node.getrawmempool()
76+
77+
if __name__ == "__main__":
78+
MempoolCompatibilityTest().main()

test/functional/test_runner.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -232,6 +232,7 @@
232232
'feature_includeconf.py',
233233
'feature_asmap.py',
234234
'mempool_unbroadcast.py',
235+
'mempool_compatibility.py',
235236
'rpc_deriveaddresses.py',
236237
'rpc_deriveaddresses.py --usecli',
237238
'rpc_scantxoutset.py',

0 commit comments

Comments
 (0)