|
|
|
@ -13,8 +13,12 @@
|
|
|
|
|
available, but that the unconfirmed transaction has been zapped.
|
|
|
|
|
"""
|
|
|
|
|
from test_framework.test_framework import BitcoinTestFramework
|
|
|
|
|
from test_framework.util import *
|
|
|
|
|
|
|
|
|
|
from test_framework.util import (assert_equal,
|
|
|
|
|
assert_raises,
|
|
|
|
|
bitcoind_processes,
|
|
|
|
|
connect_nodes_bi,
|
|
|
|
|
JSONRPCException,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
class ZapWalletTXesTest (BitcoinTestFramework):
|
|
|
|
|
|
|
|
|
@ -25,56 +29,56 @@ class ZapWalletTXesTest (BitcoinTestFramework):
|
|
|
|
|
|
|
|
|
|
def setup_network(self):
|
|
|
|
|
super().setup_network()
|
|
|
|
|
connect_nodes_bi(self.nodes,0,2)
|
|
|
|
|
connect_nodes_bi(self.nodes, 0, 2)
|
|
|
|
|
|
|
|
|
|
def run_test (self):
|
|
|
|
|
def run_test(self):
|
|
|
|
|
self.log.info("Mining blocks...")
|
|
|
|
|
self.nodes[0].generate(1)
|
|
|
|
|
self.sync_all()
|
|
|
|
|
self.nodes[1].generate(101)
|
|
|
|
|
self.sync_all()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assert_equal(self.nodes[0].getbalance(), 50)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
txid0 = self.nodes[0].sendtoaddress(self.nodes[2].getnewaddress(), 11)
|
|
|
|
|
txid1 = self.nodes[0].sendtoaddress(self.nodes[2].getnewaddress(), 10)
|
|
|
|
|
self.sync_all()
|
|
|
|
|
self.nodes[0].generate(1)
|
|
|
|
|
self.sync_all()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
txid2 = self.nodes[0].sendtoaddress(self.nodes[2].getnewaddress(), 11)
|
|
|
|
|
txid3 = self.nodes[0].sendtoaddress(self.nodes[2].getnewaddress(), 10)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tx0 = self.nodes[0].gettransaction(txid0)
|
|
|
|
|
assert_equal(tx0['txid'], txid0) #tx0 must be available (confirmed)
|
|
|
|
|
|
|
|
|
|
assert_equal(tx0['txid'], txid0) # tx0 must be available (confirmed)
|
|
|
|
|
|
|
|
|
|
tx1 = self.nodes[0].gettransaction(txid1)
|
|
|
|
|
assert_equal(tx1['txid'], txid1) #tx1 must be available (confirmed)
|
|
|
|
|
|
|
|
|
|
assert_equal(tx1['txid'], txid1) # tx1 must be available (confirmed)
|
|
|
|
|
|
|
|
|
|
tx2 = self.nodes[0].gettransaction(txid2)
|
|
|
|
|
assert_equal(tx2['txid'], txid2) #tx2 must be available (unconfirmed)
|
|
|
|
|
|
|
|
|
|
assert_equal(tx2['txid'], txid2) # tx2 must be available (unconfirmed)
|
|
|
|
|
|
|
|
|
|
tx3 = self.nodes[0].gettransaction(txid3)
|
|
|
|
|
assert_equal(tx3['txid'], txid3) #tx3 must be available (unconfirmed)
|
|
|
|
|
|
|
|
|
|
assert_equal(tx3['txid'], txid3) # tx3 must be available (unconfirmed)
|
|
|
|
|
|
|
|
|
|
#restart bitcoind
|
|
|
|
|
self.stop_node(0)
|
|
|
|
|
self.nodes[0] = self.start_node(0,self.options.tmpdir)
|
|
|
|
|
|
|
|
|
|
tx3 = self.nodes[0].gettransaction(txid3)
|
|
|
|
|
assert_equal(tx3['txid'], txid3) #tx must be available (unconfirmed)
|
|
|
|
|
|
|
|
|
|
assert_equal(tx3['txid'], txid3) # tx must be available (unconfirmed)
|
|
|
|
|
|
|
|
|
|
self.stop_node(0)
|
|
|
|
|
|
|
|
|
|
#restart bitcoind with zapwallettxes
|
|
|
|
|
self.nodes[0] = self.start_node(0,self.options.tmpdir, ["-zapwallettxes=1"])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assert_raises(JSONRPCException, self.nodes[0].gettransaction, [txid3])
|
|
|
|
|
#there must be an exception because the unconfirmed wallettx0 must be gone by now
|
|
|
|
|
# there must be an exception because the unconfirmed wallettx0 must be gone by now
|
|
|
|
|
|
|
|
|
|
tx0 = self.nodes[0].gettransaction(txid0)
|
|
|
|
|
assert_equal(tx0['txid'], txid0) #tx0 (confirmed) must still be available because it was confirmed
|
|
|
|
|
assert_equal(tx0['txid'], txid0) # tx0 (confirmed) must still be available because it was confirmed
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
|
ZapWalletTXesTest ().main ()
|
|
|
|
|
ZapWalletTXesTest().main()
|
|
|
|
|