mirror of
https://github.com/dashpay/dash.git
synced 2024-12-25 12:02:48 +01:00
speed up wallet_hd.py and clarify/augment checks
This commit is contained in:
parent
3cf76c23fb
commit
6cba60ace2
@ -48,8 +48,8 @@ class WalletHDTest(BitcoinTestFramework):
|
|||||||
# Also send funds to each add
|
# Also send funds to each add
|
||||||
self.nodes[0].generate(101)
|
self.nodes[0].generate(101)
|
||||||
hd_add = None
|
hd_add = None
|
||||||
num_hd_adds = 300
|
NUM_HD_ADDS = 10
|
||||||
for i in range(num_hd_adds):
|
for i in range(NUM_HD_ADDS):
|
||||||
hd_add = self.nodes[1].getnewaddress()
|
hd_add = self.nodes[1].getnewaddress()
|
||||||
hd_info = self.nodes[1].getaddressinfo(hd_add)
|
hd_info = self.nodes[1].getaddressinfo(hd_add)
|
||||||
assert_equal(hd_info["hdkeypath"], "m/0'/0'/"+str(i)+"'")
|
assert_equal(hd_info["hdkeypath"], "m/0'/0'/"+str(i)+"'")
|
||||||
@ -65,7 +65,7 @@ class WalletHDTest(BitcoinTestFramework):
|
|||||||
assert_equal(change_addrV["hdkeypath"], "m/0'/1'/1'") #second internal child key
|
assert_equal(change_addrV["hdkeypath"], "m/0'/1'/1'") #second internal child key
|
||||||
|
|
||||||
self.sync_all()
|
self.sync_all()
|
||||||
assert_equal(self.nodes[1].getbalance(), num_hd_adds + 1)
|
assert_equal(self.nodes[1].getbalance(), NUM_HD_ADDS + 1)
|
||||||
|
|
||||||
self.log.info("Restore backup ...")
|
self.log.info("Restore backup ...")
|
||||||
self.stop_node(1)
|
self.stop_node(1)
|
||||||
@ -78,10 +78,10 @@ class WalletHDTest(BitcoinTestFramework):
|
|||||||
|
|
||||||
# Assert that derivation is deterministic
|
# Assert that derivation is deterministic
|
||||||
hd_add_2 = None
|
hd_add_2 = None
|
||||||
for _ in range(num_hd_adds):
|
for i in range(NUM_HD_ADDS):
|
||||||
hd_add_2 = self.nodes[1].getnewaddress()
|
hd_add_2 = self.nodes[1].getnewaddress()
|
||||||
hd_info_2 = self.nodes[1].getaddressinfo(hd_add_2)
|
hd_info_2 = self.nodes[1].getaddressinfo(hd_add_2)
|
||||||
assert_equal(hd_info_2["hdkeypath"], "m/0'/0'/"+str(_)+"'")
|
assert_equal(hd_info_2["hdkeypath"], "m/0'/0'/"+str(i)+"'")
|
||||||
assert_equal(hd_info_2["hdmasterkeyid"], masterkeyid)
|
assert_equal(hd_info_2["hdmasterkeyid"], masterkeyid)
|
||||||
assert_equal(hd_add, hd_add_2)
|
assert_equal(hd_add, hd_add_2)
|
||||||
connect_nodes_bi(self.nodes, 0, 1)
|
connect_nodes_bi(self.nodes, 0, 1)
|
||||||
@ -90,7 +90,7 @@ class WalletHDTest(BitcoinTestFramework):
|
|||||||
# Needs rescan
|
# Needs rescan
|
||||||
self.stop_node(1)
|
self.stop_node(1)
|
||||||
self.start_node(1, extra_args=self.extra_args[1] + ['-rescan'])
|
self.start_node(1, extra_args=self.extra_args[1] + ['-rescan'])
|
||||||
assert_equal(self.nodes[1].getbalance(), num_hd_adds + 1)
|
assert_equal(self.nodes[1].getbalance(), NUM_HD_ADDS + 1)
|
||||||
|
|
||||||
# Try a RPC based rescan
|
# Try a RPC based rescan
|
||||||
self.stop_node(1)
|
self.stop_node(1)
|
||||||
@ -100,13 +100,15 @@ class WalletHDTest(BitcoinTestFramework):
|
|||||||
self.start_node(1, extra_args=self.extra_args[1])
|
self.start_node(1, extra_args=self.extra_args[1])
|
||||||
connect_nodes_bi(self.nodes, 0, 1)
|
connect_nodes_bi(self.nodes, 0, 1)
|
||||||
self.sync_all()
|
self.sync_all()
|
||||||
|
# Wallet automatically scans blocks older than key on startup
|
||||||
|
assert_equal(self.nodes[1].getbalance(), NUM_HD_ADDS + 1)
|
||||||
out = self.nodes[1].rescanblockchain(0, 1)
|
out = self.nodes[1].rescanblockchain(0, 1)
|
||||||
assert_equal(out['start_height'], 0)
|
assert_equal(out['start_height'], 0)
|
||||||
assert_equal(out['stop_height'], 1)
|
assert_equal(out['stop_height'], 1)
|
||||||
out = self.nodes[1].rescanblockchain()
|
out = self.nodes[1].rescanblockchain()
|
||||||
assert_equal(out['start_height'], 0)
|
assert_equal(out['start_height'], 0)
|
||||||
assert_equal(out['stop_height'], self.nodes[1].getblockcount())
|
assert_equal(out['stop_height'], self.nodes[1].getblockcount())
|
||||||
assert_equal(self.nodes[1].getbalance(), num_hd_adds + 1)
|
assert_equal(self.nodes[1].getbalance(), NUM_HD_ADDS + 1)
|
||||||
|
|
||||||
# send a tx and make sure its using the internal chain for the changeoutput
|
# send a tx and make sure its using the internal chain for the changeoutput
|
||||||
txid = self.nodes[1].sendtoaddress(self.nodes[0].getnewaddress(), 1)
|
txid = self.nodes[1].sendtoaddress(self.nodes[0].getnewaddress(), 1)
|
||||||
|
Loading…
Reference in New Issue
Block a user