Merge #14101: qa: Use named args in validation acceptance tests
fa782a308d
qa: Use named args in some tests (MarcoFalke)b4d3309673
scripted-diff: Use named arguments in feature_block (MarcoFalke)749ba35e7c
scripted-diff: Pass node into p2p_segwit acceptance tests (MarcoFalke) Pull request description: It is confusing to use a list of arguments such as `False, False, 16, ...` where it is unclear what each of them means. Run some scripted diffs to put meaning to them. Tree-SHA512: d768df2375ea3c77145ebb1bf4c2d690581a379031449ded7ae160022d975eb13890aa8c6a44a5eebda8791cb2910a599326e431af76ed9e60afe1d182ada65c
This commit is contained in:
commit
104aad1567
5 changed files with 158 additions and 158 deletions
|
@ -169,7 +169,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.log.info("Reject a block where the miner creates too much coinbase reward")
|
self.log.info("Reject a block where the miner creates too much coinbase reward")
|
||||||
self.move_tip(6)
|
self.move_tip(6)
|
||||||
b9 = self.next_block(9, spend=out[4], additional_coinbase_value=1)
|
b9 = self.next_block(9, spend=out[4], additional_coinbase_value=1)
|
||||||
self.sync_blocks([b9], False, 16, b'bad-cb-amount', reconnect=True)
|
self.sync_blocks([b9], success=False, reject_code=16, reject_reason=b'bad-cb-amount', reconnect=True)
|
||||||
|
|
||||||
# Create a fork that ends in a block with too much fee (the one that causes the reorg)
|
# Create a fork that ends in a block with too much fee (the one that causes the reorg)
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -181,7 +181,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.sync_blocks([b10], False)
|
self.sync_blocks([b10], False)
|
||||||
|
|
||||||
b11 = self.next_block(11, spend=out[4], additional_coinbase_value=1)
|
b11 = self.next_block(11, spend=out[4], additional_coinbase_value=1)
|
||||||
self.sync_blocks([b11], False, 16, b'bad-cb-amount', reconnect=True)
|
self.sync_blocks([b11], success=False, reject_code=16, reject_reason=b'bad-cb-amount', reconnect=True)
|
||||||
|
|
||||||
# Try again, but with a valid fork first
|
# Try again, but with a valid fork first
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -194,7 +194,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b13 = self.next_block(13, spend=out[4])
|
b13 = self.next_block(13, spend=out[4])
|
||||||
self.save_spendable_output()
|
self.save_spendable_output()
|
||||||
b14 = self.next_block(14, spend=out[5], additional_coinbase_value=1)
|
b14 = self.next_block(14, spend=out[5], additional_coinbase_value=1)
|
||||||
self.sync_blocks([b12, b13, b14], False, 16, b'bad-cb-amount', reconnect=True)
|
self.sync_blocks([b12, b13, b14], success=False, reject_code=16, reject_reason=b'bad-cb-amount', reconnect=True)
|
||||||
|
|
||||||
# New tip should be b13.
|
# New tip should be b13.
|
||||||
assert_equal(node.getbestblockhash(), b13.hash)
|
assert_equal(node.getbestblockhash(), b13.hash)
|
||||||
|
@ -213,7 +213,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.log.info("Reject a block with too many checksigs")
|
self.log.info("Reject a block with too many checksigs")
|
||||||
too_many_checksigs = CScript([OP_CHECKSIG] * (MAX_BLOCK_SIGOPS))
|
too_many_checksigs = CScript([OP_CHECKSIG] * (MAX_BLOCK_SIGOPS))
|
||||||
b16 = self.next_block(16, spend=out[6], script=too_many_checksigs)
|
b16 = self.next_block(16, spend=out[6], script=too_many_checksigs)
|
||||||
self.sync_blocks([b16], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b16], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
# Attempt to spend a transaction created on a different fork
|
# Attempt to spend a transaction created on a different fork
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -222,7 +222,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.log.info("Reject a block with a spend from a re-org'ed out tx")
|
self.log.info("Reject a block with a spend from a re-org'ed out tx")
|
||||||
self.move_tip(15)
|
self.move_tip(15)
|
||||||
b17 = self.next_block(17, spend=txout_b3)
|
b17 = self.next_block(17, spend=txout_b3)
|
||||||
self.sync_blocks([b17], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b17], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# Attempt to spend a transaction created on a different fork (on a fork this time)
|
# Attempt to spend a transaction created on a different fork (on a fork this time)
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -235,7 +235,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.sync_blocks([b18], False)
|
self.sync_blocks([b18], False)
|
||||||
|
|
||||||
b19 = self.next_block(19, spend=out[6])
|
b19 = self.next_block(19, spend=out[6])
|
||||||
self.sync_blocks([b19], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b19], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# Attempt to spend a coinbase at depth too low
|
# Attempt to spend a coinbase at depth too low
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -244,7 +244,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.log.info("Reject a block spending an immature coinbase.")
|
self.log.info("Reject a block spending an immature coinbase.")
|
||||||
self.move_tip(15)
|
self.move_tip(15)
|
||||||
b20 = self.next_block(20, spend=out[7])
|
b20 = self.next_block(20, spend=out[7])
|
||||||
self.sync_blocks([b20], False, 16, b'bad-txns-premature-spend-of-coinbase')
|
self.sync_blocks([b20], success=False, reject_code=16, reject_reason=b'bad-txns-premature-spend-of-coinbase')
|
||||||
|
|
||||||
# Attempt to spend a coinbase at depth too low (on a fork this time)
|
# Attempt to spend a coinbase at depth too low (on a fork this time)
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -257,7 +257,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.sync_blocks([b21], False)
|
self.sync_blocks([b21], False)
|
||||||
|
|
||||||
b22 = self.next_block(22, spend=out[5])
|
b22 = self.next_block(22, spend=out[5])
|
||||||
self.sync_blocks([b22], False, 16, b'bad-txns-premature-spend-of-coinbase')
|
self.sync_blocks([b22], success=False, reject_code=16, reject_reason=b'bad-txns-premature-spend-of-coinbase')
|
||||||
|
|
||||||
# Create a block on either side of MAX_BLOCK_BASE_SIZE and make sure its accepted/rejected
|
# Create a block on either side of MAX_BLOCK_BASE_SIZE and make sure its accepted/rejected
|
||||||
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
# genesis -> b1 (0) -> b2 (1) -> b5 (2) -> b6 (3)
|
||||||
|
@ -286,7 +286,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx.vout = [CTxOut(0, script_output)]
|
tx.vout = [CTxOut(0, script_output)]
|
||||||
b24 = self.update_block(24, [tx])
|
b24 = self.update_block(24, [tx])
|
||||||
assert_equal(len(b24.serialize()), MAX_BLOCK_BASE_SIZE + 1)
|
assert_equal(len(b24.serialize()), MAX_BLOCK_BASE_SIZE + 1)
|
||||||
self.sync_blocks([b24], False, 16, b'bad-blk-length', reconnect=True)
|
self.sync_blocks([b24], success=False, reject_code=16, reject_reason=b'bad-blk-length', reconnect=True)
|
||||||
|
|
||||||
b25 = self.next_block(25, spend=out[7])
|
b25 = self.next_block(25, spend=out[7])
|
||||||
self.sync_blocks([b25], False)
|
self.sync_blocks([b25], False)
|
||||||
|
@ -304,7 +304,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
# update_block causes the merkle root to get updated, even with no new
|
# update_block causes the merkle root to get updated, even with no new
|
||||||
# transactions, and updates the required state.
|
# transactions, and updates the required state.
|
||||||
b26 = self.update_block(26, [])
|
b26 = self.update_block(26, [])
|
||||||
self.sync_blocks([b26], False, 16, b'bad-cb-length', reconnect=True)
|
self.sync_blocks([b26], success=False, reject_code=16, reject_reason=b'bad-cb-length', reconnect=True)
|
||||||
|
|
||||||
# Extend the b26 chain to make sure bitcoind isn't accepting b26
|
# Extend the b26 chain to make sure bitcoind isn't accepting b26
|
||||||
b27 = self.next_block(27, spend=out[7])
|
b27 = self.next_block(27, spend=out[7])
|
||||||
|
@ -316,7 +316,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b28.vtx[0].vin[0].scriptSig = b'\x00' * 101
|
b28.vtx[0].vin[0].scriptSig = b'\x00' * 101
|
||||||
b28.vtx[0].rehash()
|
b28.vtx[0].rehash()
|
||||||
b28 = self.update_block(28, [])
|
b28 = self.update_block(28, [])
|
||||||
self.sync_blocks([b28], False, 16, b'bad-cb-length', reconnect=True)
|
self.sync_blocks([b28], success=False, reject_code=16, reject_reason=b'bad-cb-length', reconnect=True)
|
||||||
|
|
||||||
# Extend the b28 chain to make sure bitcoind isn't accepting b28
|
# Extend the b28 chain to make sure bitcoind isn't accepting b28
|
||||||
b29 = self.next_block(29, spend=out[7])
|
b29 = self.next_block(29, spend=out[7])
|
||||||
|
@ -352,7 +352,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
too_many_multisigs = CScript([OP_CHECKMULTISIG] * (MAX_BLOCK_SIGOPS // 20))
|
too_many_multisigs = CScript([OP_CHECKMULTISIG] * (MAX_BLOCK_SIGOPS // 20))
|
||||||
b32 = self.next_block(32, spend=out[9], script=too_many_multisigs)
|
b32 = self.next_block(32, spend=out[9], script=too_many_multisigs)
|
||||||
assert_equal(get_legacy_sigopcount_block(b32), MAX_BLOCK_SIGOPS + 1)
|
assert_equal(get_legacy_sigopcount_block(b32), MAX_BLOCK_SIGOPS + 1)
|
||||||
self.sync_blocks([b32], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b32], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
# CHECKMULTISIGVERIFY
|
# CHECKMULTISIGVERIFY
|
||||||
self.log.info("Accept a block with the max number of OP_CHECKMULTISIGVERIFY sigops")
|
self.log.info("Accept a block with the max number of OP_CHECKMULTISIGVERIFY sigops")
|
||||||
|
@ -365,7 +365,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.log.info("Reject a block with too many OP_CHECKMULTISIGVERIFY sigops")
|
self.log.info("Reject a block with too many OP_CHECKMULTISIGVERIFY sigops")
|
||||||
too_many_multisigs = CScript([OP_CHECKMULTISIGVERIFY] * (MAX_BLOCK_SIGOPS // 20))
|
too_many_multisigs = CScript([OP_CHECKMULTISIGVERIFY] * (MAX_BLOCK_SIGOPS // 20))
|
||||||
b34 = self.next_block(34, spend=out[10], script=too_many_multisigs)
|
b34 = self.next_block(34, spend=out[10], script=too_many_multisigs)
|
||||||
self.sync_blocks([b34], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b34], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
# CHECKSIGVERIFY
|
# CHECKSIGVERIFY
|
||||||
self.log.info("Accept a block with the max number of OP_CHECKSIGVERIFY sigops")
|
self.log.info("Accept a block with the max number of OP_CHECKSIGVERIFY sigops")
|
||||||
|
@ -378,7 +378,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.log.info("Reject a block with too many OP_CHECKSIGVERIFY sigops")
|
self.log.info("Reject a block with too many OP_CHECKSIGVERIFY sigops")
|
||||||
too_many_checksigs = CScript([OP_CHECKSIGVERIFY] * (MAX_BLOCK_SIGOPS))
|
too_many_checksigs = CScript([OP_CHECKSIGVERIFY] * (MAX_BLOCK_SIGOPS))
|
||||||
b36 = self.next_block(36, spend=out[11], script=too_many_checksigs)
|
b36 = self.next_block(36, spend=out[11], script=too_many_checksigs)
|
||||||
self.sync_blocks([b36], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b36], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
# Check spending of a transaction in a block which failed to connect
|
# Check spending of a transaction in a block which failed to connect
|
||||||
#
|
#
|
||||||
|
@ -395,12 +395,12 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
txout_b37 = b37.vtx[1]
|
txout_b37 = b37.vtx[1]
|
||||||
tx = self.create_and_sign_transaction(out[11], 0)
|
tx = self.create_and_sign_transaction(out[11], 0)
|
||||||
b37 = self.update_block(37, [tx])
|
b37 = self.update_block(37, [tx])
|
||||||
self.sync_blocks([b37], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b37], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# attempt to spend b37's first non-coinbase tx, at which point b37 was still considered valid
|
# attempt to spend b37's first non-coinbase tx, at which point b37 was still considered valid
|
||||||
self.move_tip(35)
|
self.move_tip(35)
|
||||||
b38 = self.next_block(38, spend=txout_b37)
|
b38 = self.next_block(38, spend=txout_b37)
|
||||||
self.sync_blocks([b38], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b38], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# Check P2SH SigOp counting
|
# Check P2SH SigOp counting
|
||||||
#
|
#
|
||||||
|
@ -492,7 +492,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
new_txs.append(tx)
|
new_txs.append(tx)
|
||||||
self.update_block(40, new_txs)
|
self.update_block(40, new_txs)
|
||||||
self.sync_blocks([b40], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b40], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
# same as b40, but one less sigop
|
# same as b40, but one less sigop
|
||||||
self.log.info("Accept a block with the max number of P2SH sigops")
|
self.log.info("Accept a block with the max number of P2SH sigops")
|
||||||
|
@ -555,7 +555,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.block_heights[b45.sha256] = self.block_heights[self.tip.sha256] + 1
|
self.block_heights[b45.sha256] = self.block_heights[self.tip.sha256] + 1
|
||||||
self.tip = b45
|
self.tip = b45
|
||||||
self.blocks[45] = b45
|
self.blocks[45] = b45
|
||||||
self.sync_blocks([b45], False, 16, b'bad-cb-missing', reconnect=True)
|
self.sync_blocks([b45], success=False, reject_code=16, reject_reason=b'bad-cb-missing', reconnect=True)
|
||||||
|
|
||||||
self.log.info("Reject a block with no transactions")
|
self.log.info("Reject a block with no transactions")
|
||||||
self.move_tip(44)
|
self.move_tip(44)
|
||||||
|
@ -570,7 +570,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
self.tip = b46
|
self.tip = b46
|
||||||
assert 46 not in self.blocks
|
assert 46 not in self.blocks
|
||||||
self.blocks[46] = b46
|
self.blocks[46] = b46
|
||||||
self.sync_blocks([b46], False, 16, b'bad-blk-length', reconnect=True)
|
self.sync_blocks([b46], success=False, reject_code=16, reject_reason=b'bad-blk-length', reconnect=True)
|
||||||
|
|
||||||
self.log.info("Reject a block with invalid work")
|
self.log.info("Reject a block with invalid work")
|
||||||
self.move_tip(44)
|
self.move_tip(44)
|
||||||
|
@ -593,7 +593,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b49 = self.next_block(49)
|
b49 = self.next_block(49)
|
||||||
b49.hashMerkleRoot += 1
|
b49.hashMerkleRoot += 1
|
||||||
b49.solve()
|
b49.solve()
|
||||||
self.sync_blocks([b49], False, 16, b'bad-txnmrklroot', reconnect=True)
|
self.sync_blocks([b49], success=False, reject_code=16, reject_reason=b'bad-txnmrklroot', reconnect=True)
|
||||||
|
|
||||||
self.log.info("Reject a block with incorrect POW limit")
|
self.log.info("Reject a block with incorrect POW limit")
|
||||||
self.move_tip(44)
|
self.move_tip(44)
|
||||||
|
@ -607,7 +607,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b51 = self.next_block(51)
|
b51 = self.next_block(51)
|
||||||
cb2 = create_coinbase(51, self.coinbase_pubkey)
|
cb2 = create_coinbase(51, self.coinbase_pubkey)
|
||||||
b51 = self.update_block(51, [cb2])
|
b51 = self.update_block(51, [cb2])
|
||||||
self.sync_blocks([b51], False, 16, b'bad-cb-multiple', reconnect=True)
|
self.sync_blocks([b51], success=False, reject_code=16, reject_reason=b'bad-cb-multiple', reconnect=True)
|
||||||
|
|
||||||
self.log.info("Reject a block with duplicate transactions")
|
self.log.info("Reject a block with duplicate transactions")
|
||||||
# Note: txns have to be in the right position in the merkle tree to trigger this error
|
# Note: txns have to be in the right position in the merkle tree to trigger this error
|
||||||
|
@ -615,7 +615,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b52 = self.next_block(52, spend=out[15])
|
b52 = self.next_block(52, spend=out[15])
|
||||||
tx = self.create_tx(b52.vtx[1], 0, 1)
|
tx = self.create_tx(b52.vtx[1], 0, 1)
|
||||||
b52 = self.update_block(52, [tx, tx])
|
b52 = self.update_block(52, [tx, tx])
|
||||||
self.sync_blocks([b52], False, 16, b'bad-txns-duplicate', reconnect=True)
|
self.sync_blocks([b52], success=False, reject_code=16, reject_reason=b'bad-txns-duplicate', reconnect=True)
|
||||||
|
|
||||||
# Test block timestamps
|
# Test block timestamps
|
||||||
# -> b31 (8) -> b33 (9) -> b35 (10) -> b39 (11) -> b42 (12) -> b43 (13) -> b53 (14) -> b55 (15)
|
# -> b31 (8) -> b33 (9) -> b35 (10) -> b39 (11) -> b42 (12) -> b43 (13) -> b53 (14) -> b55 (15)
|
||||||
|
@ -682,7 +682,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
assert_equal(len(b56.vtx), 3)
|
assert_equal(len(b56.vtx), 3)
|
||||||
b56 = self.update_block(56, [tx1])
|
b56 = self.update_block(56, [tx1])
|
||||||
assert_equal(b56.hash, b57.hash)
|
assert_equal(b56.hash, b57.hash)
|
||||||
self.sync_blocks([b56], False, 16, b'bad-txns-duplicate', reconnect=True)
|
self.sync_blocks([b56], success=False, reject_code=16, reject_reason=b'bad-txns-duplicate', reconnect=True)
|
||||||
|
|
||||||
# b57p2 - a good block with 6 tx'es, don't submit until end
|
# b57p2 - a good block with 6 tx'es, don't submit until end
|
||||||
self.move_tip(55)
|
self.move_tip(55)
|
||||||
|
@ -702,7 +702,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
assert_equal(b56p2.hash, b57p2.hash)
|
assert_equal(b56p2.hash, b57p2.hash)
|
||||||
assert_equal(len(b56p2.vtx), 6)
|
assert_equal(len(b56p2.vtx), 6)
|
||||||
b56p2 = self.update_block("b56p2", [tx3, tx4])
|
b56p2 = self.update_block("b56p2", [tx3, tx4])
|
||||||
self.sync_blocks([b56p2], False, 16, b'bad-txns-duplicate', reconnect=True)
|
self.sync_blocks([b56p2], success=False, reject_code=16, reject_reason=b'bad-txns-duplicate', reconnect=True)
|
||||||
|
|
||||||
self.move_tip("57p2")
|
self.move_tip("57p2")
|
||||||
self.sync_blocks([b57p2], True)
|
self.sync_blocks([b57p2], True)
|
||||||
|
@ -727,7 +727,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx.vout.append(CTxOut(0, b""))
|
tx.vout.append(CTxOut(0, b""))
|
||||||
tx.calc_sha256()
|
tx.calc_sha256()
|
||||||
b58 = self.update_block(58, [tx])
|
b58 = self.update_block(58, [tx])
|
||||||
self.sync_blocks([b58], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b58], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# tx with output value > input value
|
# tx with output value > input value
|
||||||
self.log.info("Reject a block with a transaction with outputs > inputs")
|
self.log.info("Reject a block with a transaction with outputs > inputs")
|
||||||
|
@ -735,7 +735,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b59 = self.next_block(59)
|
b59 = self.next_block(59)
|
||||||
tx = self.create_and_sign_transaction(out[17], 51 * COIN)
|
tx = self.create_and_sign_transaction(out[17], 51 * COIN)
|
||||||
b59 = self.update_block(59, [tx])
|
b59 = self.update_block(59, [tx])
|
||||||
self.sync_blocks([b59], False, 16, b'bad-txns-in-belowout', reconnect=True)
|
self.sync_blocks([b59], success=False, reject_code=16, reject_reason=b'bad-txns-in-belowout', reconnect=True)
|
||||||
|
|
||||||
# reset to good chain
|
# reset to good chain
|
||||||
self.move_tip(57)
|
self.move_tip(57)
|
||||||
|
@ -759,7 +759,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b61.vtx[0].rehash()
|
b61.vtx[0].rehash()
|
||||||
b61 = self.update_block(61, [])
|
b61 = self.update_block(61, [])
|
||||||
assert_equal(b60.vtx[0].serialize(), b61.vtx[0].serialize())
|
assert_equal(b60.vtx[0].serialize(), b61.vtx[0].serialize())
|
||||||
self.sync_blocks([b61], False, 16, b'bad-txns-BIP30', reconnect=True)
|
self.sync_blocks([b61], success=False, reject_code=16, reject_reason=b'bad-txns-BIP30', reconnect=True)
|
||||||
|
|
||||||
# Test tx.isFinal is properly rejected (not an exhaustive tx.isFinal test, that should be in data-driven transaction tests)
|
# Test tx.isFinal is properly rejected (not an exhaustive tx.isFinal test, that should be in data-driven transaction tests)
|
||||||
#
|
#
|
||||||
|
@ -776,7 +776,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
assert(tx.vin[0].nSequence < 0xffffffff)
|
assert(tx.vin[0].nSequence < 0xffffffff)
|
||||||
tx.calc_sha256()
|
tx.calc_sha256()
|
||||||
b62 = self.update_block(62, [tx])
|
b62 = self.update_block(62, [tx])
|
||||||
self.sync_blocks([b62], False, 16, b'bad-txns-nonfinal')
|
self.sync_blocks([b62], success=False, reject_code=16, reject_reason=b'bad-txns-nonfinal')
|
||||||
|
|
||||||
# Test a non-final coinbase is also rejected
|
# Test a non-final coinbase is also rejected
|
||||||
#
|
#
|
||||||
|
@ -790,7 +790,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b63.vtx[0].vin[0].nSequence = 0xDEADBEEF
|
b63.vtx[0].vin[0].nSequence = 0xDEADBEEF
|
||||||
b63.vtx[0].rehash()
|
b63.vtx[0].rehash()
|
||||||
b63 = self.update_block(63, [])
|
b63 = self.update_block(63, [])
|
||||||
self.sync_blocks([b63], False, 16, b'bad-txns-nonfinal')
|
self.sync_blocks([b63], success=False, reject_code=16, reject_reason=b'bad-txns-nonfinal')
|
||||||
|
|
||||||
# This checks that a block with a bloated VARINT between the block_header and the array of tx such that
|
# This checks that a block with a bloated VARINT between the block_header and the array of tx such that
|
||||||
# the block is > MAX_BLOCK_BASE_SIZE with the bloated varint, but <= MAX_BLOCK_BASE_SIZE without the bloated varint,
|
# the block is > MAX_BLOCK_BASE_SIZE with the bloated varint, but <= MAX_BLOCK_BASE_SIZE without the bloated varint,
|
||||||
|
@ -824,7 +824,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx.vin.append(CTxIn(COutPoint(b64a.vtx[1].sha256, 0)))
|
tx.vin.append(CTxIn(COutPoint(b64a.vtx[1].sha256, 0)))
|
||||||
b64a = self.update_block("64a", [tx])
|
b64a = self.update_block("64a", [tx])
|
||||||
assert_equal(len(b64a.serialize()), MAX_BLOCK_BASE_SIZE + 8)
|
assert_equal(len(b64a.serialize()), MAX_BLOCK_BASE_SIZE + 8)
|
||||||
self.sync_blocks([b64a], False, 1, b'error parsing message')
|
self.sync_blocks([b64a], success=False, reject_code=1, reject_reason=b'error parsing message')
|
||||||
|
|
||||||
# bitcoind doesn't disconnect us for sending a bloated block, but if we subsequently
|
# bitcoind doesn't disconnect us for sending a bloated block, but if we subsequently
|
||||||
# resend the header message, it won't send us the getdata message again. Just
|
# resend the header message, it won't send us the getdata message again. Just
|
||||||
|
@ -866,7 +866,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx1 = self.create_and_sign_transaction(out[20], out[20].vout[0].nValue)
|
tx1 = self.create_and_sign_transaction(out[20], out[20].vout[0].nValue)
|
||||||
tx2 = self.create_and_sign_transaction(tx1, 1)
|
tx2 = self.create_and_sign_transaction(tx1, 1)
|
||||||
b66 = self.update_block(66, [tx2, tx1])
|
b66 = self.update_block(66, [tx2, tx1])
|
||||||
self.sync_blocks([b66], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b66], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# Attempt to double-spend a transaction created in a block
|
# Attempt to double-spend a transaction created in a block
|
||||||
#
|
#
|
||||||
|
@ -881,7 +881,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx2 = self.create_and_sign_transaction(tx1, 1)
|
tx2 = self.create_and_sign_transaction(tx1, 1)
|
||||||
tx3 = self.create_and_sign_transaction(tx1, 2)
|
tx3 = self.create_and_sign_transaction(tx1, 2)
|
||||||
b67 = self.update_block(67, [tx1, tx2, tx3])
|
b67 = self.update_block(67, [tx1, tx2, tx3])
|
||||||
self.sync_blocks([b67], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b67], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# More tests of block subsidy
|
# More tests of block subsidy
|
||||||
#
|
#
|
||||||
|
@ -900,7 +900,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b68 = self.next_block(68, additional_coinbase_value=10)
|
b68 = self.next_block(68, additional_coinbase_value=10)
|
||||||
tx = self.create_and_sign_transaction(out[20], out[20].vout[0].nValue - 9)
|
tx = self.create_and_sign_transaction(out[20], out[20].vout[0].nValue - 9)
|
||||||
b68 = self.update_block(68, [tx])
|
b68 = self.update_block(68, [tx])
|
||||||
self.sync_blocks([b68], False, 16, b'bad-cb-amount', reconnect=True)
|
self.sync_blocks([b68], success=False, reject_code=16, reject_reason=b'bad-cb-amount', reconnect=True)
|
||||||
|
|
||||||
self.log.info("Accept a block claiming the correct subsidy in the coinbase transaction")
|
self.log.info("Accept a block claiming the correct subsidy in the coinbase transaction")
|
||||||
self.move_tip(65)
|
self.move_tip(65)
|
||||||
|
@ -924,7 +924,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx.vin.append(CTxIn(COutPoint(bogus_tx.sha256, 0), b"", 0xffffffff))
|
tx.vin.append(CTxIn(COutPoint(bogus_tx.sha256, 0), b"", 0xffffffff))
|
||||||
tx.vout.append(CTxOut(1, b""))
|
tx.vout.append(CTxOut(1, b""))
|
||||||
b70 = self.update_block(70, [tx])
|
b70 = self.update_block(70, [tx])
|
||||||
self.sync_blocks([b70], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b70], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
# Test accepting an invalid block which has the same hash as a valid one (via merkle tree tricks)
|
# Test accepting an invalid block which has the same hash as a valid one (via merkle tree tricks)
|
||||||
#
|
#
|
||||||
|
@ -949,7 +949,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
assert_equal(b72.sha256, b71.sha256)
|
assert_equal(b72.sha256, b71.sha256)
|
||||||
|
|
||||||
self.move_tip(71)
|
self.move_tip(71)
|
||||||
self.sync_blocks([b71], False, 16, b'bad-txns-duplicate', reconnect=True)
|
self.sync_blocks([b71], success=False, reject_code=16, reject_reason=b'bad-txns-duplicate', reconnect=True)
|
||||||
|
|
||||||
self.move_tip(72)
|
self.move_tip(72)
|
||||||
self.sync_blocks([b72], True)
|
self.sync_blocks([b72], True)
|
||||||
|
@ -987,7 +987,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
tx = self.create_and_sign_transaction(out[22], 1, CScript(a))
|
tx = self.create_and_sign_transaction(out[22], 1, CScript(a))
|
||||||
b73 = self.update_block(73, [tx])
|
b73 = self.update_block(73, [tx])
|
||||||
assert_equal(get_legacy_sigopcount_block(b73), MAX_BLOCK_SIGOPS + 1)
|
assert_equal(get_legacy_sigopcount_block(b73), MAX_BLOCK_SIGOPS + 1)
|
||||||
self.sync_blocks([b73], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b73], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
# b74/75 - if we push an invalid script element, all prevous sigops are counted,
|
# b74/75 - if we push an invalid script element, all prevous sigops are counted,
|
||||||
# but sigops after the element are not counted.
|
# but sigops after the element are not counted.
|
||||||
|
@ -1011,7 +1011,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
a[MAX_BLOCK_SIGOPS + 4] = 0xff
|
a[MAX_BLOCK_SIGOPS + 4] = 0xff
|
||||||
tx = self.create_and_sign_transaction(out[22], 1, CScript(a))
|
tx = self.create_and_sign_transaction(out[22], 1, CScript(a))
|
||||||
b74 = self.update_block(74, [tx])
|
b74 = self.update_block(74, [tx])
|
||||||
self.sync_blocks([b74], False, 16, b'bad-blk-sigops', reconnect=True)
|
self.sync_blocks([b74], success=False, reject_code=16, reject_reason=b'bad-blk-sigops', reconnect=True)
|
||||||
|
|
||||||
self.move_tip(72)
|
self.move_tip(72)
|
||||||
b75 = self.next_block(75)
|
b75 = self.next_block(75)
|
||||||
|
@ -1160,7 +1160,7 @@ class FullBlockTest(BitcoinTestFramework):
|
||||||
b89a = self.next_block("89a", spend=out[32])
|
b89a = self.next_block("89a", spend=out[32])
|
||||||
tx = self.create_tx(tx1, 0, 0, CScript([OP_TRUE]))
|
tx = self.create_tx(tx1, 0, 0, CScript([OP_TRUE]))
|
||||||
b89a = self.update_block("89a", [tx])
|
b89a = self.update_block("89a", [tx])
|
||||||
self.sync_blocks([b89a], False, 16, b'bad-txns-inputs-missingorspent', reconnect=True)
|
self.sync_blocks([b89a], success=False, reject_code=16, reject_reason=b'bad-txns-inputs-missingorspent', reconnect=True)
|
||||||
|
|
||||||
self.log.info("Test a re-org of one week's worth of blocks (1088 blocks)")
|
self.log.info("Test a re-org of one week's worth of blocks (1088 blocks)")
|
||||||
|
|
||||||
|
|
|
@ -188,7 +188,7 @@ class MiningTest(BitcoinTestFramework):
|
||||||
# Should ask for the block from a p2p node, if they announce the header as well:
|
# Should ask for the block from a p2p node, if they announce the header as well:
|
||||||
node.add_p2p_connection(P2PDataStore())
|
node.add_p2p_connection(P2PDataStore())
|
||||||
node.p2p.wait_for_getheaders(timeout=5) # Drop the first getheaders
|
node.p2p.wait_for_getheaders(timeout=5) # Drop the first getheaders
|
||||||
node.p2p.send_blocks_and_test(blocks=[block], rpc=node)
|
node.p2p.send_blocks_and_test(blocks=[block], node=node)
|
||||||
# Must be active now:
|
# Must be active now:
|
||||||
assert chain_tip(block.hash, status='active', branchlen=0) in node.getchaintips()
|
assert chain_tip(block.hash, status='active', branchlen=0) in node.getchaintips()
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ class InvalidBlockRequestTest(BitcoinTestFramework):
|
||||||
# Save the coinbase for later
|
# Save the coinbase for later
|
||||||
block1 = block
|
block1 = block
|
||||||
tip = block.sha256
|
tip = block.sha256
|
||||||
node.p2p.send_blocks_and_test([block1], node, True)
|
node.p2p.send_blocks_and_test([block1], node, success=True)
|
||||||
|
|
||||||
self.log.info("Mature the block.")
|
self.log.info("Mature the block.")
|
||||||
node.generate(100)
|
node.generate(100)
|
||||||
|
@ -79,7 +79,7 @@ class InvalidBlockRequestTest(BitcoinTestFramework):
|
||||||
assert_equal(orig_hash, block2.rehash())
|
assert_equal(orig_hash, block2.rehash())
|
||||||
assert(block2_orig.vtx != block2.vtx)
|
assert(block2_orig.vtx != block2.vtx)
|
||||||
|
|
||||||
node.p2p.send_blocks_and_test([block2], node, False, False, 16, b'bad-txns-duplicate')
|
node.p2p.send_blocks_and_test([block2], node, success=False, request_block=False, reject_code=16, reject_reason=b'bad-txns-duplicate')
|
||||||
|
|
||||||
self.log.info("Test very broken block.")
|
self.log.info("Test very broken block.")
|
||||||
|
|
||||||
|
@ -92,7 +92,7 @@ class InvalidBlockRequestTest(BitcoinTestFramework):
|
||||||
block3.rehash()
|
block3.rehash()
|
||||||
block3.solve()
|
block3.solve()
|
||||||
|
|
||||||
node.p2p.send_blocks_and_test([block3], node, False, False, 16, b'bad-cb-amount')
|
node.p2p.send_blocks_and_test([block3], node, success=False, request_block=False, reject_code=16, reject_reason=b'bad-cb-amount')
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
InvalidBlockRequestTest().main()
|
InvalidBlockRequestTest().main()
|
||||||
|
|
|
@ -119,7 +119,7 @@ def get_virtual_size(witness_block):
|
||||||
vsize = int((3 * base_size + total_size + 3) / 4)
|
vsize = int((3 * base_size + total_size + 3) / 4)
|
||||||
return vsize
|
return vsize
|
||||||
|
|
||||||
def test_transaction_acceptance(rpc, p2p, tx, with_witness, accepted, reason=None):
|
def test_transaction_acceptance(node, p2p, tx, with_witness, accepted, reason=None):
|
||||||
"""Send a transaction to the node and check that it's accepted to the mempool
|
"""Send a transaction to the node and check that it's accepted to the mempool
|
||||||
|
|
||||||
- Submit the transaction over the p2p interface
|
- Submit the transaction over the p2p interface
|
||||||
|
@ -129,13 +129,13 @@ def test_transaction_acceptance(rpc, p2p, tx, with_witness, accepted, reason=Non
|
||||||
tx_message = msg_witness_tx(tx)
|
tx_message = msg_witness_tx(tx)
|
||||||
p2p.send_message(tx_message)
|
p2p.send_message(tx_message)
|
||||||
p2p.sync_with_ping()
|
p2p.sync_with_ping()
|
||||||
assert_equal(tx.hash in rpc.getrawmempool(), accepted)
|
assert_equal(tx.hash in node.getrawmempool(), accepted)
|
||||||
if (reason is not None and not accepted):
|
if (reason is not None and not accepted):
|
||||||
# Check the rejection reason as well.
|
# Check the rejection reason as well.
|
||||||
with mininode_lock:
|
with mininode_lock:
|
||||||
assert_equal(p2p.last_message["reject"].reason, reason)
|
assert_equal(p2p.last_message["reject"].reason, reason)
|
||||||
|
|
||||||
def test_witness_block(rpc, p2p, block, accepted, with_witness=True, reason=None):
|
def test_witness_block(node, p2p, block, accepted, with_witness=True, reason=None):
|
||||||
"""Send a block to the node and check that it's accepted
|
"""Send a block to the node and check that it's accepted
|
||||||
|
|
||||||
- Submit the block over the p2p interface
|
- Submit the block over the p2p interface
|
||||||
|
@ -145,7 +145,7 @@ def test_witness_block(rpc, p2p, block, accepted, with_witness=True, reason=None
|
||||||
else:
|
else:
|
||||||
p2p.send_message(msg_block(block))
|
p2p.send_message(msg_block(block))
|
||||||
p2p.sync_with_ping()
|
p2p.sync_with_ping()
|
||||||
assert_equal(rpc.getbestblockhash() == block.hash, accepted)
|
assert_equal(node.getbestblockhash() == block.hash, accepted)
|
||||||
if (reason is not None and not accepted):
|
if (reason is not None and not accepted):
|
||||||
# Check the rejection reason as well.
|
# Check the rejection reason as well.
|
||||||
with mininode_lock:
|
with mininode_lock:
|
||||||
|
@ -349,7 +349,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
# Sending witness data before activation is not allowed (anti-spam
|
# Sending witness data before activation is not allowed (anti-spam
|
||||||
# rule).
|
# rule).
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
wait_until(lambda: 'reject' in self.test_node.last_message and self.test_node.last_message["reject"].reason == b"unexpected-witness")
|
wait_until(lambda: 'reject' in self.test_node.last_message and self.test_node.last_message["reject"].reason == b"unexpected-witness")
|
||||||
|
|
||||||
# But it should not be permanently marked bad...
|
# But it should not be permanently marked bad...
|
||||||
|
@ -380,20 +380,20 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
self.test_node.announce_block_and_wait_for_getdata(block1, use_header=False)
|
self.test_node.announce_block_and_wait_for_getdata(block1, use_header=False)
|
||||||
assert(self.test_node.last_message["getdata"].inv[0].type == blocktype)
|
assert(self.test_node.last_message["getdata"].inv[0].type == blocktype)
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block1, True)
|
test_witness_block(self.nodes[0], self.test_node, block1, True)
|
||||||
|
|
||||||
block2 = self.build_next_block(version=4)
|
block2 = self.build_next_block(version=4)
|
||||||
block2.solve()
|
block2.solve()
|
||||||
|
|
||||||
self.test_node.announce_block_and_wait_for_getdata(block2, use_header=True)
|
self.test_node.announce_block_and_wait_for_getdata(block2, use_header=True)
|
||||||
assert(self.test_node.last_message["getdata"].inv[0].type == blocktype)
|
assert(self.test_node.last_message["getdata"].inv[0].type == blocktype)
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block2, True)
|
test_witness_block(self.nodes[0], self.test_node, block2, True)
|
||||||
|
|
||||||
block3 = self.build_next_block(version=(VB_TOP_BITS | (1 << 15)))
|
block3 = self.build_next_block(version=(VB_TOP_BITS | (1 << 15)))
|
||||||
block3.solve()
|
block3.solve()
|
||||||
self.test_node.announce_block_and_wait_for_getdata(block3, use_header=True)
|
self.test_node.announce_block_and_wait_for_getdata(block3, use_header=True)
|
||||||
assert(self.test_node.last_message["getdata"].inv[0].type == blocktype)
|
assert(self.test_node.last_message["getdata"].inv[0].type == blocktype)
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block3, True)
|
test_witness_block(self.nodes[0], self.test_node, block3, True)
|
||||||
|
|
||||||
# Check that we can getdata for witness blocks or regular blocks,
|
# Check that we can getdata for witness blocks or regular blocks,
|
||||||
# and the right thing happens.
|
# and the right thing happens.
|
||||||
|
@ -423,7 +423,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# This gives us a witness commitment.
|
# This gives us a witness commitment.
|
||||||
assert(len(block.vtx[0].wit.vtxinwit) == 1)
|
assert(len(block.vtx[0].wit.vtxinwit) == 1)
|
||||||
assert(len(block.vtx[0].wit.vtxinwit[0].scriptWitness.stack) == 1)
|
assert(len(block.vtx[0].wit.vtxinwit[0].scriptWitness.stack) == 1)
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
# Now try to retrieve it...
|
# Now try to retrieve it...
|
||||||
rpc_block = self.nodes[0].getblock(block.hash, False)
|
rpc_block = self.nodes[0].getblock(block.hash, False)
|
||||||
non_wit_block = self.test_node.request_block(block.sha256, 2)
|
non_wit_block = self.test_node.request_block(block.sha256, 2)
|
||||||
|
@ -640,11 +640,11 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# its from)
|
# its from)
|
||||||
assert_equal(len(self.nodes[0].getrawmempool()), 0)
|
assert_equal(len(self.nodes[0].getrawmempool()), 0)
|
||||||
assert_equal(len(self.nodes[1].getrawmempool()), 0)
|
assert_equal(len(self.nodes[1].getrawmempool()), 0)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.old_node, tx, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.old_node, tx, with_witness=True, accepted=False)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=True, accepted=False)
|
||||||
|
|
||||||
# But eliminating the witness should fix it
|
# But eliminating the witness should fix it
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=False, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=False, accepted=True)
|
||||||
|
|
||||||
# Cleanup: mine the first transaction and update utxo
|
# Cleanup: mine the first transaction and update utxo
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
|
@ -674,7 +674,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
p2sh_tx.rehash()
|
p2sh_tx.rehash()
|
||||||
|
|
||||||
# Mine it on test_node to create the confirmed output.
|
# Mine it on test_node to create the confirmed output.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2sh_tx, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2sh_tx, with_witness=True, accepted=True)
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
|
||||||
|
@ -689,7 +689,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
# This is always accepted, since the mempool policy is to consider segwit as always active
|
# This is always accepted, since the mempool policy is to consider segwit as always active
|
||||||
# and thus allow segwit outputs
|
# and thus allow segwit outputs
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx, with_witness=True, accepted=True)
|
||||||
|
|
||||||
# Now create something that looks like a P2PKH output. This won't be spendable.
|
# Now create something that looks like a P2PKH output. This won't be spendable.
|
||||||
script_pubkey = CScript([OP_0, hash160(witness_hash)])
|
script_pubkey = CScript([OP_0, hash160(witness_hash)])
|
||||||
|
@ -701,7 +701,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.wit.vtxinwit[0].scriptWitness.stack = [witness_program]
|
tx2.wit.vtxinwit[0].scriptWitness.stack = [witness_program]
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
|
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx2, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx2, with_witness=True, accepted=True)
|
||||||
|
|
||||||
# Now update self.utxo for later tests.
|
# Now update self.utxo for later tests.
|
||||||
tx3 = CTransaction()
|
tx3 = CTransaction()
|
||||||
|
@ -723,7 +723,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx3.vout = [tx3_out]
|
tx3.vout = [tx3_out]
|
||||||
tx3.rehash()
|
tx3.rehash()
|
||||||
assert_equal(self.nodes[0].testmempoolaccept([bytes_to_hex_str(tx3.serialize_with_witness())]), [{'txid': tx3.hash, 'allowed': True}])
|
assert_equal(self.nodes[0].testmempoolaccept([bytes_to_hex_str(tx3.serialize_with_witness())]), [{'txid': tx3.hash, 'allowed': True}])
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx3, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx3, with_witness=True, accepted=True)
|
||||||
|
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
@ -760,10 +760,10 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
|
|
||||||
# Verify mempool acceptance and block validity
|
# Verify mempool acceptance and block validity
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=False, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=False, accepted=True)
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True, with_witness=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True, with_witness=True)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
|
||||||
# Now test attempts to spend the output.
|
# Now test attempts to spend the output.
|
||||||
|
@ -777,12 +777,12 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# will require a witness to spend a witness program regardless of
|
# will require a witness to spend a witness program regardless of
|
||||||
# segwit activation. Note that older bitcoind's that are not
|
# segwit activation. Note that older bitcoind's that are not
|
||||||
# segwit-aware would also reject this for failing CLEANSTACK.
|
# segwit-aware would also reject this for failing CLEANSTACK.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, spend_tx, with_witness=False, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.test_node, spend_tx, with_witness=False, accepted=False)
|
||||||
|
|
||||||
# Try to put the witness script in the script_sig, should also fail.
|
# Try to put the witness script in the script_sig, should also fail.
|
||||||
spend_tx.vin[0].script_sig = CScript([p2wsh_pubkey, b'a'])
|
spend_tx.vin[0].script_sig = CScript([p2wsh_pubkey, b'a'])
|
||||||
spend_tx.rehash()
|
spend_tx.rehash()
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, spend_tx, with_witness=False, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.test_node, spend_tx, with_witness=False, accepted=False)
|
||||||
|
|
||||||
# Now put the witness script in the witness, should succeed after
|
# Now put the witness script in the witness, should succeed after
|
||||||
# segwit activates.
|
# segwit activates.
|
||||||
|
@ -792,7 +792,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
spend_tx.wit.vtxinwit[0].scriptWitness.stack = [b'a', witness_program]
|
spend_tx.wit.vtxinwit[0].scriptWitness.stack = [b'a', witness_program]
|
||||||
|
|
||||||
# Verify mempool acceptance
|
# Verify mempool acceptance
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, spend_tx, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, spend_tx, with_witness=True, accepted=True)
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [spend_tx])
|
self.update_witness_block_with_transactions(block, [spend_tx])
|
||||||
|
|
||||||
|
@ -800,7 +800,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# This no longer works before activation, because SCRIPT_VERIFY_WITNESS
|
# This no longer works before activation, because SCRIPT_VERIFY_WITNESS
|
||||||
# is always set.
|
# is always set.
|
||||||
# TODO: rewrite this test to make clear that it only works after activation.
|
# TODO: rewrite this test to make clear that it only works after activation.
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Update self.utxo
|
# Update self.utxo
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
|
@ -821,7 +821,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
assert(msg_witness_block(block).serialize() != msg_block(block).serialize())
|
assert(msg_witness_block(block).serialize() != msg_block(block).serialize())
|
||||||
|
|
||||||
# This empty block should be valid.
|
# This empty block should be valid.
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Try to tweak the nonce
|
# Try to tweak the nonce
|
||||||
block_2 = self.build_next_block()
|
block_2 = self.build_next_block()
|
||||||
|
@ -832,7 +832,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
assert(block_2.vtx[0].vout[-1] != block.vtx[0].vout[-1])
|
assert(block_2.vtx[0].vout[-1] != block.vtx[0].vout[-1])
|
||||||
|
|
||||||
# This should also be valid.
|
# This should also be valid.
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_2, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block_2, accepted=True)
|
||||||
|
|
||||||
# Now test commitments with actual transactions
|
# Now test commitments with actual transactions
|
||||||
tx = CTransaction()
|
tx = CTransaction()
|
||||||
|
@ -864,7 +864,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
block_3.rehash()
|
block_3.rehash()
|
||||||
block_3.solve()
|
block_3.solve()
|
||||||
|
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_3, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block_3, accepted=False)
|
||||||
|
|
||||||
# Add a different commitment with different nonce, but in the
|
# Add a different commitment with different nonce, but in the
|
||||||
# right location, and with some funds burned(!).
|
# right location, and with some funds burned(!).
|
||||||
|
@ -878,7 +878,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
block_3.rehash()
|
block_3.rehash()
|
||||||
assert(len(block_3.vtx[0].vout) == 4) # 3 OP_returns
|
assert(len(block_3.vtx[0].vout) == 4) # 3 OP_returns
|
||||||
block_3.solve()
|
block_3.solve()
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_3, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block_3, accepted=True)
|
||||||
|
|
||||||
# Finally test that a block with no witness transactions can
|
# Finally test that a block with no witness transactions can
|
||||||
# omit the commitment.
|
# omit the commitment.
|
||||||
|
@ -890,7 +890,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
block_4.vtx.append(tx3)
|
block_4.vtx.append(tx3)
|
||||||
block_4.hashMerkleRoot = block_4.calc_merkle_root()
|
block_4.hashMerkleRoot = block_4.calc_merkle_root()
|
||||||
block_4.solve()
|
block_4.solve()
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_4, with_witness=False, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block_4, with_witness=False, accepted=True)
|
||||||
|
|
||||||
# Update available utxo's for use in later test.
|
# Update available utxo's for use in later test.
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
|
@ -930,11 +930,11 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Change the nonce -- should not cause the block to be permanently
|
# Change the nonce -- should not cause the block to be permanently
|
||||||
# failed
|
# failed
|
||||||
block.vtx[0].wit.vtxinwit[0].scriptWitness.stack = [ser_uint256(1)]
|
block.vtx[0].wit.vtxinwit[0].scriptWitness.stack = [ser_uint256(1)]
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Changing the witness reserved value doesn't change the block hash
|
# Changing the witness reserved value doesn't change the block hash
|
||||||
block.vtx[0].wit.vtxinwit[0].scriptWitness.stack = [ser_uint256(0)]
|
block.vtx[0].wit.vtxinwit[0].scriptWitness.stack = [ser_uint256(0)]
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
@subtest
|
@subtest
|
||||||
def test_witness_block_size(self):
|
def test_witness_block_size(self):
|
||||||
|
@ -998,7 +998,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# limit
|
# limit
|
||||||
assert(len(block.serialize(True)) > 2 * 1024 * 1024)
|
assert(len(block.serialize(True)) > 2 * 1024 * 1024)
|
||||||
|
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now resize the second transaction to make the block fit.
|
# Now resize the second transaction to make the block fit.
|
||||||
cur_length = len(block.vtx[-1].wit.vtxinwit[0].scriptWitness.stack[0])
|
cur_length = len(block.vtx[-1].wit.vtxinwit[0].scriptWitness.stack[0])
|
||||||
|
@ -1008,7 +1008,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
block.solve()
|
block.solve()
|
||||||
assert(get_virtual_size(block) == MAX_BLOCK_BASE_SIZE)
|
assert(get_virtual_size(block) == MAX_BLOCK_BASE_SIZE)
|
||||||
|
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Update available utxo's
|
# Update available utxo's
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
|
@ -1071,7 +1071,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
|
|
||||||
# Extra witness data should not be allowed.
|
# Extra witness data should not be allowed.
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Try extra signature data. Ok if we're not spending a witness output.
|
# Try extra signature data. Ok if we're not spending a witness output.
|
||||||
block.vtx[1].wit.vtxinwit = []
|
block.vtx[1].wit.vtxinwit = []
|
||||||
|
@ -1080,7 +1080,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
add_witness_commitment(block)
|
add_witness_commitment(block)
|
||||||
block.solve()
|
block.solve()
|
||||||
|
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Now try extra witness/signature data on an input that DOES require a
|
# Now try extra witness/signature data on an input that DOES require a
|
||||||
# witness
|
# witness
|
||||||
|
@ -1096,7 +1096,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
|
|
||||||
# This has extra witness data, so it should fail.
|
# This has extra witness data, so it should fail.
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now get rid of the extra witness, but add extra scriptSig data
|
# Now get rid of the extra witness, but add extra scriptSig data
|
||||||
tx2.vin[0].scriptSig = CScript([OP_TRUE])
|
tx2.vin[0].scriptSig = CScript([OP_TRUE])
|
||||||
|
@ -1108,7 +1108,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
block.solve()
|
block.solve()
|
||||||
|
|
||||||
# This has extra signature data for a witness input, so it should fail.
|
# This has extra signature data for a witness input, so it should fail.
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now get rid of the extra scriptsig on the witness input, and verify
|
# Now get rid of the extra scriptsig on the witness input, and verify
|
||||||
# success (even with extra scriptsig data in the non-witness input)
|
# success (even with extra scriptsig data in the non-witness input)
|
||||||
|
@ -1117,7 +1117,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
add_witness_commitment(block)
|
add_witness_commitment(block)
|
||||||
block.solve()
|
block.solve()
|
||||||
|
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Update utxo for later tests
|
# Update utxo for later tests
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
|
@ -1147,14 +1147,14 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
|
|
||||||
self.update_witness_block_with_transactions(block, [tx, tx2])
|
self.update_witness_block_with_transactions(block, [tx, tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now reduce the length of the stack element
|
# Now reduce the length of the stack element
|
||||||
tx2.wit.vtxinwit[0].scriptWitness.stack[0] = b'a' * (MAX_SCRIPT_ELEMENT_SIZE)
|
tx2.wit.vtxinwit[0].scriptWitness.stack[0] = b'a' * (MAX_SCRIPT_ELEMENT_SIZE)
|
||||||
|
|
||||||
add_witness_commitment(block)
|
add_witness_commitment(block)
|
||||||
block.solve()
|
block.solve()
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Update the utxo for later tests
|
# Update the utxo for later tests
|
||||||
self.utxo.pop()
|
self.utxo.pop()
|
||||||
|
@ -1188,7 +1188,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
self.update_witness_block_with_transactions(block, [tx, tx2])
|
self.update_witness_block_with_transactions(block, [tx, tx2])
|
||||||
|
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Try again with one less byte in the witness program
|
# Try again with one less byte in the witness program
|
||||||
witness_program = CScript([b'a' * 520] * 19 + [OP_DROP] * 62 + [OP_TRUE])
|
witness_program = CScript([b'a' * 520] * 19 + [OP_DROP] * 62 + [OP_TRUE])
|
||||||
|
@ -1203,7 +1203,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
block.vtx = [block.vtx[0]]
|
block.vtx = [block.vtx[0]]
|
||||||
self.update_witness_block_with_transactions(block, [tx, tx2])
|
self.update_witness_block_with_transactions(block, [tx, tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
self.utxo.pop()
|
self.utxo.pop()
|
||||||
self.utxo.append(UTXO(tx2.sha256, 0, tx2.vout[0].nValue))
|
self.utxo.append(UTXO(tx2.sha256, 0, tx2.vout[0].nValue))
|
||||||
|
@ -1227,7 +1227,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Try various ways to spend tx that should all break.
|
# Try various ways to spend tx that should all break.
|
||||||
# This "broken" transaction serializer will not normalize
|
# This "broken" transaction serializer will not normalize
|
||||||
|
@ -1262,7 +1262,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now try using a too short vtxinwit
|
# Now try using a too short vtxinwit
|
||||||
tx2.wit.vtxinwit.pop()
|
tx2.wit.vtxinwit.pop()
|
||||||
|
@ -1270,7 +1270,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block.vtx = [block.vtx[0]]
|
block.vtx = [block.vtx[0]]
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now make one of the intermediate witnesses be incorrect
|
# Now make one of the intermediate witnesses be incorrect
|
||||||
tx2.wit.vtxinwit.append(CTxInWitness())
|
tx2.wit.vtxinwit.append(CTxInWitness())
|
||||||
|
@ -1279,13 +1279,13 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block.vtx = [block.vtx[0]]
|
block.vtx = [block.vtx[0]]
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Fix the broken witness and the block should be accepted.
|
# Fix the broken witness and the block should be accepted.
|
||||||
tx2.wit.vtxinwit[5].scriptWitness.stack = [b'a', witness_program]
|
tx2.wit.vtxinwit[5].scriptWitness.stack = [b'a', witness_program]
|
||||||
block.vtx = [block.vtx[0]]
|
block.vtx = [block.vtx[0]]
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
self.utxo.pop()
|
self.utxo.pop()
|
||||||
self.utxo.append(UTXO(tx2.sha256, 0, tx2.vout[0].nValue))
|
self.utxo.append(UTXO(tx2.sha256, 0, tx2.vout[0].nValue))
|
||||||
|
@ -1314,11 +1314,11 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Verify that unnecessary witnesses are rejected.
|
# Verify that unnecessary witnesses are rejected.
|
||||||
self.test_node.announce_tx_and_wait_for_getdata(tx)
|
self.test_node.announce_tx_and_wait_for_getdata(tx)
|
||||||
assert_equal(len(self.nodes[0].getrawmempool()), 0)
|
assert_equal(len(self.nodes[0].getrawmempool()), 0)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=True, accepted=False)
|
||||||
|
|
||||||
# Verify that removing the witness succeeds.
|
# Verify that removing the witness succeeds.
|
||||||
self.test_node.announce_tx_and_wait_for_getdata(tx)
|
self.test_node.announce_tx_and_wait_for_getdata(tx)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=False, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=False, accepted=True)
|
||||||
|
|
||||||
# Now try to add extra witness data to a valid witness tx.
|
# Now try to add extra witness data to a valid witness tx.
|
||||||
witness_program = CScript([OP_TRUE])
|
witness_program = CScript([OP_TRUE])
|
||||||
|
@ -1343,24 +1343,24 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
# Node will not be blinded to the transaction
|
# Node will not be blinded to the transaction
|
||||||
self.std_node.announce_tx_and_wait_for_getdata(tx3)
|
self.std_node.announce_tx_and_wait_for_getdata(tx3)
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx3, True, False, b'tx-size')
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx3, True, False, b'tx-size')
|
||||||
self.std_node.announce_tx_and_wait_for_getdata(tx3)
|
self.std_node.announce_tx_and_wait_for_getdata(tx3)
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx3, True, False, b'tx-size')
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx3, True, False, b'tx-size')
|
||||||
|
|
||||||
# Remove witness stuffing, instead add extra witness push on stack
|
# Remove witness stuffing, instead add extra witness push on stack
|
||||||
tx3.vout[0] = CTxOut(tx2.vout[0].nValue - 1000, CScript([OP_TRUE, OP_DROP] * 15 + [OP_TRUE]))
|
tx3.vout[0] = CTxOut(tx2.vout[0].nValue - 1000, CScript([OP_TRUE, OP_DROP] * 15 + [OP_TRUE]))
|
||||||
tx3.wit.vtxinwit[0].scriptWitness.stack = [CScript([CScriptNum(1)]), witness_program]
|
tx3.wit.vtxinwit[0].scriptWitness.stack = [CScript([CScriptNum(1)]), witness_program]
|
||||||
tx3.rehash()
|
tx3.rehash()
|
||||||
|
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx2, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx2, with_witness=True, accepted=True)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx3, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx3, with_witness=True, accepted=False)
|
||||||
|
|
||||||
# Get rid of the extra witness, and verify acceptance.
|
# Get rid of the extra witness, and verify acceptance.
|
||||||
tx3.wit.vtxinwit[0].scriptWitness.stack = [witness_program]
|
tx3.wit.vtxinwit[0].scriptWitness.stack = [witness_program]
|
||||||
# Also check that old_node gets a tx announcement, even though this is
|
# Also check that old_node gets a tx announcement, even though this is
|
||||||
# a witness transaction.
|
# a witness transaction.
|
||||||
self.old_node.wait_for_inv([CInv(1, tx2.sha256)]) # wait until tx2 was inv'ed
|
self.old_node.wait_for_inv([CInv(1, tx2.sha256)]) # wait until tx2 was inv'ed
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx3, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx3, with_witness=True, accepted=True)
|
||||||
self.old_node.wait_for_inv([CInv(1, tx3.sha256)])
|
self.old_node.wait_for_inv([CInv(1, tx3.sha256)])
|
||||||
|
|
||||||
# Test that getrawtransaction returns correct witness information
|
# Test that getrawtransaction returns correct witness information
|
||||||
|
@ -1400,7 +1400,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
for i in range(NUM_SEGWIT_VERSIONS):
|
for i in range(NUM_SEGWIT_VERSIONS):
|
||||||
self.utxo.append(UTXO(tx.sha256, i, split_value))
|
self.utxo.append(UTXO(tx.sha256, i, split_value))
|
||||||
|
@ -1417,8 +1417,8 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx.vin = [CTxIn(COutPoint(self.utxo[0].sha256, self.utxo[0].n), b"")]
|
tx.vin = [CTxIn(COutPoint(self.utxo[0].sha256, self.utxo[0].n), b"")]
|
||||||
tx.vout = [CTxOut(self.utxo[0].nValue - 1000, script_pubkey)]
|
tx.vout = [CTxOut(self.utxo[0].nValue - 1000, script_pubkey)]
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx, with_witness=True, accepted=False)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=True, accepted=True)
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
temp_utxo.append(UTXO(tx.sha256, 0, tx.vout[0].nValue))
|
temp_utxo.append(UTXO(tx.sha256, 0, tx.vout[0].nValue))
|
||||||
|
|
||||||
|
@ -1437,8 +1437,8 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
# Gets accepted to test_node, because standardness of outputs isn't
|
# Gets accepted to test_node, because standardness of outputs isn't
|
||||||
# checked with fRequireStandard
|
# checked with fRequireStandard
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx2, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx2, with_witness=True, accepted=True)
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx2, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx2, with_witness=True, accepted=False)
|
||||||
temp_utxo.pop() # last entry in temp_utxo was the output we just spent
|
temp_utxo.pop() # last entry in temp_utxo was the output we just spent
|
||||||
temp_utxo.append(UTXO(tx2.sha256, 0, tx2.vout[0].nValue))
|
temp_utxo.append(UTXO(tx2.sha256, 0, tx2.vout[0].nValue))
|
||||||
|
|
||||||
|
@ -1454,7 +1454,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx3.rehash()
|
tx3.rehash()
|
||||||
# Spending a higher version witness output is not allowed by policy,
|
# Spending a higher version witness output is not allowed by policy,
|
||||||
# even with fRequireStandard=false.
|
# even with fRequireStandard=false.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx3, with_witness=True, accepted=False)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx3, with_witness=True, accepted=False)
|
||||||
self.test_node.sync_with_ping()
|
self.test_node.sync_with_ping()
|
||||||
with mininode_lock:
|
with mininode_lock:
|
||||||
assert(b"reserved for soft-fork upgrades" in self.test_node.last_message["reject"].reason)
|
assert(b"reserved for soft-fork upgrades" in self.test_node.last_message["reject"].reason)
|
||||||
|
@ -1462,7 +1462,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Building a block with the transaction must be valid, however.
|
# Building a block with the transaction must be valid, however.
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx2, tx3])
|
self.update_witness_block_with_transactions(block, [tx2, tx3])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
|
||||||
# Add utxo to our list
|
# Add utxo to our list
|
||||||
|
@ -1480,7 +1480,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# This next line will rehash the coinbase and update the merkle
|
# This next line will rehash the coinbase and update the merkle
|
||||||
# root, and solve.
|
# root, and solve.
|
||||||
self.update_witness_block_with_transactions(block, [])
|
self.update_witness_block_with_transactions(block, [])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
spend_tx = CTransaction()
|
spend_tx = CTransaction()
|
||||||
spend_tx.vin = [CTxIn(COutPoint(block.vtx[0].sha256, 0), b"")]
|
spend_tx.vin = [CTxIn(COutPoint(block.vtx[0].sha256, 0), b"")]
|
||||||
|
@ -1494,13 +1494,13 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
block2 = self.build_next_block()
|
block2 = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block2, [spend_tx])
|
self.update_witness_block_with_transactions(block2, [spend_tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block2, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block2, accepted=False)
|
||||||
|
|
||||||
# Advancing one more block should allow the spend.
|
# Advancing one more block should allow the spend.
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
block2 = self.build_next_block()
|
block2 = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block2, [spend_tx])
|
self.update_witness_block_with_transactions(block2, [spend_tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block2, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block2, accepted=True)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
|
||||||
@subtest
|
@subtest
|
||||||
|
@ -1532,7 +1532,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Confirm it in a block.
|
# Confirm it in a block.
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Now try to spend it. Send it to a P2WSH output, which we'll
|
# Now try to spend it. Send it to a P2WSH output, which we'll
|
||||||
# use in the next test.
|
# use in the next test.
|
||||||
|
@ -1551,11 +1551,11 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
|
|
||||||
# Should fail policy test.
|
# Should fail policy test.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx2, True, False, b'non-mandatory-script-verify-flag (Using non-compressed keys in segwit)')
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx2, True, False, b'non-mandatory-script-verify-flag (Using non-compressed keys in segwit)')
|
||||||
# But passes consensus.
|
# But passes consensus.
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Test 2: P2WSH
|
# Test 2: P2WSH
|
||||||
# Try to spend the P2WSH output created in last test.
|
# Try to spend the P2WSH output created in last test.
|
||||||
|
@ -1571,11 +1571,11 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
sign_p2pk_witness_input(witness_program, tx3, 0, SIGHASH_ALL, tx2.vout[0].nValue, key)
|
sign_p2pk_witness_input(witness_program, tx3, 0, SIGHASH_ALL, tx2.vout[0].nValue, key)
|
||||||
|
|
||||||
# Should fail policy test.
|
# Should fail policy test.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx3, True, False, b'non-mandatory-script-verify-flag (Using non-compressed keys in segwit)')
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx3, True, False, b'non-mandatory-script-verify-flag (Using non-compressed keys in segwit)')
|
||||||
# But passes consensus.
|
# But passes consensus.
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx3])
|
self.update_witness_block_with_transactions(block, [tx3])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Test 3: P2SH(P2WSH)
|
# Test 3: P2SH(P2WSH)
|
||||||
# Try to spend the P2SH output created in the last test.
|
# Try to spend the P2SH output created in the last test.
|
||||||
|
@ -1588,10 +1588,10 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
sign_p2pk_witness_input(witness_program, tx4, 0, SIGHASH_ALL, tx3.vout[0].nValue, key)
|
sign_p2pk_witness_input(witness_program, tx4, 0, SIGHASH_ALL, tx3.vout[0].nValue, key)
|
||||||
|
|
||||||
# Should fail policy test.
|
# Should fail policy test.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx4, True, False, b'non-mandatory-script-verify-flag (Using non-compressed keys in segwit)')
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx4, True, False, b'non-mandatory-script-verify-flag (Using non-compressed keys in segwit)')
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx4])
|
self.update_witness_block_with_transactions(block, [tx4])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Test 4: Uncompressed pubkeys should still be valid in non-segwit
|
# Test 4: Uncompressed pubkeys should still be valid in non-segwit
|
||||||
# transactions.
|
# transactions.
|
||||||
|
@ -1603,10 +1603,10 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx5.vin[0].scriptSig = CScript([signature, pubkey])
|
tx5.vin[0].scriptSig = CScript([signature, pubkey])
|
||||||
tx5.rehash()
|
tx5.rehash()
|
||||||
# Should pass policy and consensus.
|
# Should pass policy and consensus.
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx5, True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx5, True, True)
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx5])
|
self.update_witness_block_with_transactions(block, [tx5])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
self.utxo.append(UTXO(tx5.sha256, 0, tx5.vout[0].nValue))
|
self.utxo.append(UTXO(tx5.sha256, 0, tx5.vout[0].nValue))
|
||||||
|
|
||||||
@subtest
|
@subtest
|
||||||
|
@ -1626,11 +1626,11 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx.vout.append(CTxOut(self.utxo[0].nValue - 1000, script_pubkey))
|
tx.vout.append(CTxOut(self.utxo[0].nValue - 1000, script_pubkey))
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
|
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=True, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=True, accepted=True)
|
||||||
# Mine this transaction in preparation for following tests.
|
# Mine this transaction in preparation for following tests.
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
self.utxo.pop(0)
|
self.utxo.pop(0)
|
||||||
|
|
||||||
|
@ -1647,19 +1647,19 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Too-large input value
|
# Too-large input value
|
||||||
sign_p2pk_witness_input(witness_program, tx, 0, hashtype, prev_utxo.nValue + 1, key)
|
sign_p2pk_witness_input(witness_program, tx, 0, hashtype, prev_utxo.nValue + 1, key)
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Too-small input value
|
# Too-small input value
|
||||||
sign_p2pk_witness_input(witness_program, tx, 0, hashtype, prev_utxo.nValue - 1, key)
|
sign_p2pk_witness_input(witness_program, tx, 0, hashtype, prev_utxo.nValue - 1, key)
|
||||||
block.vtx.pop() # remove last tx
|
block.vtx.pop() # remove last tx
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Now try correct value
|
# Now try correct value
|
||||||
sign_p2pk_witness_input(witness_program, tx, 0, hashtype, prev_utxo.nValue, key)
|
sign_p2pk_witness_input(witness_program, tx, 0, hashtype, prev_utxo.nValue, key)
|
||||||
block.vtx.pop()
|
block.vtx.pop()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
prev_utxo = UTXO(tx.sha256, 0, tx.vout[0].nValue)
|
prev_utxo = UTXO(tx.sha256, 0, tx.vout[0].nValue)
|
||||||
|
|
||||||
|
@ -1683,7 +1683,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
used_sighash_single_out_of_bounds = False
|
used_sighash_single_out_of_bounds = False
|
||||||
|
@ -1725,7 +1725,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Test the block periodically, if we're close to maxblocksize
|
# Test the block periodically, if we're close to maxblocksize
|
||||||
if (get_virtual_size(block) > MAX_BLOCK_BASE_SIZE - 1000):
|
if (get_virtual_size(block) > MAX_BLOCK_BASE_SIZE - 1000):
|
||||||
self.update_witness_block_with_transactions(block, [])
|
self.update_witness_block_with_transactions(block, [])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
|
|
||||||
if (not used_sighash_single_out_of_bounds):
|
if (not used_sighash_single_out_of_bounds):
|
||||||
|
@ -1733,7 +1733,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Test the transactions we've added to the block
|
# Test the transactions we've added to the block
|
||||||
if (len(block.vtx) > 1):
|
if (len(block.vtx) > 1):
|
||||||
self.update_witness_block_with_transactions(block, [])
|
self.update_witness_block_with_transactions(block, [])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
# Now test witness version 0 P2PKH transactions
|
# Now test witness version 0 P2PKH transactions
|
||||||
pubkeyhash = hash160(pubkey)
|
pubkeyhash = hash160(pubkey)
|
||||||
|
@ -1755,7 +1755,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.vin[0].scriptSig = CScript([signature, pubkey])
|
tx2.vin[0].scriptSig = CScript([signature, pubkey])
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx, tx2])
|
self.update_witness_block_with_transactions(block, [tx, tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||||
|
|
||||||
# Move the signature to the witness.
|
# Move the signature to the witness.
|
||||||
block.vtx.pop()
|
block.vtx.pop()
|
||||||
|
@ -1765,7 +1765,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
|
|
||||||
self.update_witness_block_with_transactions(block, [tx2])
|
self.update_witness_block_with_transactions(block, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
temp_utxos.pop(0)
|
temp_utxos.pop(0)
|
||||||
|
|
||||||
|
@ -1786,7 +1786,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
index += 1
|
index += 1
|
||||||
block = self.build_next_block()
|
block = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block, [tx])
|
self.update_witness_block_with_transactions(block, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||||
|
|
||||||
for i in range(len(tx.vout)):
|
for i in range(len(tx.vout)):
|
||||||
self.utxo.append(UTXO(tx.sha256, i, tx.vout[i].nValue))
|
self.utxo.append(UTXO(tx.sha256, i, tx.vout[i].nValue))
|
||||||
|
@ -1808,7 +1808,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx.vin.append(CTxIn(COutPoint(self.utxo[0].sha256, self.utxo[0].n), b""))
|
tx.vin.append(CTxIn(COutPoint(self.utxo[0].sha256, self.utxo[0].n), b""))
|
||||||
tx.vout.append(CTxOut(self.utxo[0].nValue - 1000, script_pubkey))
|
tx.vout.append(CTxOut(self.utxo[0].nValue - 1000, script_pubkey))
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, False, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, False, True)
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
|
||||||
|
@ -1825,18 +1825,18 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
# This will be rejected due to a policy check:
|
# This will be rejected due to a policy check:
|
||||||
# No witness is allowed, since it is not a witness program but a p2sh program
|
# No witness is allowed, since it is not a witness program but a p2sh program
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx2, True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx2, True, False, b'bad-witness-nonstandard')
|
||||||
|
|
||||||
# If we send without witness, it should be accepted.
|
# If we send without witness, it should be accepted.
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, tx2, False, True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, tx2, False, True)
|
||||||
|
|
||||||
# Now create a new anyone-can-spend utxo for the next test.
|
# Now create a new anyone-can-spend utxo for the next test.
|
||||||
tx3 = CTransaction()
|
tx3 = CTransaction()
|
||||||
tx3.vin.append(CTxIn(COutPoint(tx2.sha256, 0), CScript([p2sh_program])))
|
tx3.vin.append(CTxIn(COutPoint(tx2.sha256, 0), CScript([p2sh_program])))
|
||||||
tx3.vout.append(CTxOut(tx2.vout[0].nValue - 1000, CScript([OP_TRUE, OP_DROP] * 15 + [OP_TRUE])))
|
tx3.vout.append(CTxOut(tx2.vout[0].nValue - 1000, CScript([OP_TRUE, OP_DROP] * 15 + [OP_TRUE])))
|
||||||
tx3.rehash()
|
tx3.rehash()
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx2, False, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx2, False, True)
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx3, False, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx3, False, True)
|
||||||
|
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
@ -1872,7 +1872,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx.vout.append(CTxOut(outputvalue, CScript([OP_HASH160, p2sh, OP_EQUAL])))
|
tx.vout.append(CTxOut(outputvalue, CScript([OP_HASH160, p2sh, OP_EQUAL])))
|
||||||
tx.rehash()
|
tx.rehash()
|
||||||
txid = tx.sha256
|
txid = tx.sha256
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, tx, with_witness=False, accepted=True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, tx, with_witness=False, accepted=True)
|
||||||
|
|
||||||
self.nodes[0].generate(1)
|
self.nodes[0].generate(1)
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
@ -1897,45 +1897,45 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
# Testing native P2WSH
|
# Testing native P2WSH
|
||||||
# Witness stack size, excluding witnessScript, over 100 is non-standard
|
# Witness stack size, excluding witnessScript, over 100 is non-standard
|
||||||
p2wsh_txs[0].wit.vtxinwit[0].scriptWitness.stack = [pad] * 101 + [scripts[0]]
|
p2wsh_txs[0].wit.vtxinwit[0].scriptWitness.stack = [pad] * 101 + [scripts[0]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2wsh_txs[0], True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2wsh_txs[0], True, False, b'bad-witness-nonstandard')
|
||||||
# Non-standard nodes should accept
|
# Non-standard nodes should accept
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2wsh_txs[0], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2wsh_txs[0], True, True)
|
||||||
|
|
||||||
# Stack element size over 80 bytes is non-standard
|
# Stack element size over 80 bytes is non-standard
|
||||||
p2wsh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 81] * 100 + [scripts[1]]
|
p2wsh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 81] * 100 + [scripts[1]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2wsh_txs[1], True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2wsh_txs[1], True, False, b'bad-witness-nonstandard')
|
||||||
# Non-standard nodes should accept
|
# Non-standard nodes should accept
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2wsh_txs[1], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2wsh_txs[1], True, True)
|
||||||
# Standard nodes should accept if element size is not over 80 bytes
|
# Standard nodes should accept if element size is not over 80 bytes
|
||||||
p2wsh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 80] * 100 + [scripts[1]]
|
p2wsh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 80] * 100 + [scripts[1]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2wsh_txs[1], True, True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2wsh_txs[1], True, True)
|
||||||
|
|
||||||
# witnessScript size at 3600 bytes is standard
|
# witnessScript size at 3600 bytes is standard
|
||||||
p2wsh_txs[2].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, scripts[2]]
|
p2wsh_txs[2].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, scripts[2]]
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2wsh_txs[2], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2wsh_txs[2], True, True)
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2wsh_txs[2], True, True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2wsh_txs[2], True, True)
|
||||||
|
|
||||||
# witnessScript size at 3601 bytes is non-standard
|
# witnessScript size at 3601 bytes is non-standard
|
||||||
p2wsh_txs[3].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, pad, scripts[3]]
|
p2wsh_txs[3].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, pad, scripts[3]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2wsh_txs[3], True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2wsh_txs[3], True, False, b'bad-witness-nonstandard')
|
||||||
# Non-standard nodes should accept
|
# Non-standard nodes should accept
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2wsh_txs[3], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2wsh_txs[3], True, True)
|
||||||
|
|
||||||
# Repeating the same tests with P2SH-P2WSH
|
# Repeating the same tests with P2SH-P2WSH
|
||||||
p2sh_txs[0].wit.vtxinwit[0].scriptWitness.stack = [pad] * 101 + [scripts[0]]
|
p2sh_txs[0].wit.vtxinwit[0].scriptWitness.stack = [pad] * 101 + [scripts[0]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2sh_txs[0], True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2sh_txs[0], True, False, b'bad-witness-nonstandard')
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2sh_txs[0], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2sh_txs[0], True, True)
|
||||||
p2sh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 81] * 100 + [scripts[1]]
|
p2sh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 81] * 100 + [scripts[1]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2sh_txs[1], True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2sh_txs[1], True, False, b'bad-witness-nonstandard')
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2sh_txs[1], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2sh_txs[1], True, True)
|
||||||
p2sh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 80] * 100 + [scripts[1]]
|
p2sh_txs[1].wit.vtxinwit[0].scriptWitness.stack = [pad * 80] * 100 + [scripts[1]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2sh_txs[1], True, True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2sh_txs[1], True, True)
|
||||||
p2sh_txs[2].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, scripts[2]]
|
p2sh_txs[2].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, scripts[2]]
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2sh_txs[2], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2sh_txs[2], True, True)
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2sh_txs[2], True, True)
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2sh_txs[2], True, True)
|
||||||
p2sh_txs[3].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, pad, scripts[3]]
|
p2sh_txs[3].wit.vtxinwit[0].scriptWitness.stack = [pad, pad, pad, scripts[3]]
|
||||||
test_transaction_acceptance(self.nodes[1].rpc, self.std_node, p2sh_txs[3], True, False, b'bad-witness-nonstandard')
|
test_transaction_acceptance(self.nodes[1], self.std_node, p2sh_txs[3], True, False, b'bad-witness-nonstandard')
|
||||||
test_transaction_acceptance(self.nodes[0].rpc, self.test_node, p2sh_txs[3], True, True)
|
test_transaction_acceptance(self.nodes[0], self.test_node, p2sh_txs[3], True, True)
|
||||||
|
|
||||||
self.nodes[0].generate(1) # Mine and clean up the mempool of non-standard node
|
self.nodes[0].generate(1) # Mine and clean up the mempool of non-standard node
|
||||||
# Valid but non-standard transactions in a block should be accepted by standard node
|
# Valid but non-standard transactions in a block should be accepted by standard node
|
||||||
|
@ -2011,7 +2011,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block_1 = self.build_next_block()
|
block_1 = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block_1, [tx])
|
self.update_witness_block_with_transactions(block_1, [tx])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_1, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block_1, accepted=True)
|
||||||
|
|
||||||
tx2 = CTransaction()
|
tx2 = CTransaction()
|
||||||
# If we try to spend the first n-1 outputs from tx, that should be
|
# If we try to spend the first n-1 outputs from tx, that should be
|
||||||
|
@ -2028,7 +2028,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
|
|
||||||
block_2 = self.build_next_block()
|
block_2 = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block_2, [tx2])
|
self.update_witness_block_with_transactions(block_2, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_2, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block_2, accepted=False)
|
||||||
|
|
||||||
# Try dropping the last input in tx2, and add an output that has
|
# Try dropping the last input in tx2, and add an output that has
|
||||||
# too many sigops (contributing to legacy sigop count).
|
# too many sigops (contributing to legacy sigop count).
|
||||||
|
@ -2041,14 +2041,14 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
block_3 = self.build_next_block()
|
block_3 = self.build_next_block()
|
||||||
self.update_witness_block_with_transactions(block_3, [tx2])
|
self.update_witness_block_with_transactions(block_3, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_3, accepted=False)
|
test_witness_block(self.nodes[0], self.test_node, block_3, accepted=False)
|
||||||
|
|
||||||
# If we drop the last checksig in this output, the tx should succeed.
|
# If we drop the last checksig in this output, the tx should succeed.
|
||||||
block_4 = self.build_next_block()
|
block_4 = self.build_next_block()
|
||||||
tx2.vout[-1].scriptPubKey = CScript([OP_CHECKSIG] * (checksig_count - 1))
|
tx2.vout[-1].scriptPubKey = CScript([OP_CHECKSIG] * (checksig_count - 1))
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
self.update_witness_block_with_transactions(block_4, [tx2])
|
self.update_witness_block_with_transactions(block_4, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_4, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block_4, accepted=True)
|
||||||
|
|
||||||
# Reset the tip back down for the next test
|
# Reset the tip back down for the next test
|
||||||
sync_blocks(self.nodes)
|
sync_blocks(self.nodes)
|
||||||
|
@ -2064,7 +2064,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||||
tx2.wit.vtxinwit[-1].scriptWitness.stack = [witness_program_justright]
|
tx2.wit.vtxinwit[-1].scriptWitness.stack = [witness_program_justright]
|
||||||
tx2.rehash()
|
tx2.rehash()
|
||||||
self.update_witness_block_with_transactions(block_5, [tx2])
|
self.update_witness_block_with_transactions(block_5, [tx2])
|
||||||
test_witness_block(self.nodes[0].rpc, self.test_node, block_5, accepted=True)
|
test_witness_block(self.nodes[0], self.test_node, block_5, accepted=True)
|
||||||
|
|
||||||
# TODO: test p2sh sigop counting
|
# TODO: test p2sh sigop counting
|
||||||
|
|
||||||
|
|
|
@ -482,7 +482,7 @@ class P2PDataStore(P2PInterface):
|
||||||
self.reject_code_received = message.code
|
self.reject_code_received = message.code
|
||||||
self.reject_reason_received = message.reason
|
self.reject_reason_received = message.reason
|
||||||
|
|
||||||
def send_blocks_and_test(self, blocks, rpc, success=True, request_block=True, reject_code=None, reject_reason=None, timeout=60):
|
def send_blocks_and_test(self, blocks, node, *, success=True, request_block=True, reject_code=None, reject_reason=None, timeout=60):
|
||||||
"""Send blocks to test node and test whether the tip advances.
|
"""Send blocks to test node and test whether the tip advances.
|
||||||
|
|
||||||
- add all blocks to our block_store
|
- add all blocks to our block_store
|
||||||
|
@ -508,16 +508,16 @@ class P2PDataStore(P2PInterface):
|
||||||
wait_until(lambda: blocks[-1].sha256 in self.getdata_requests, timeout=timeout, lock=mininode_lock)
|
wait_until(lambda: blocks[-1].sha256 in self.getdata_requests, timeout=timeout, lock=mininode_lock)
|
||||||
|
|
||||||
if success:
|
if success:
|
||||||
wait_until(lambda: rpc.getbestblockhash() == blocks[-1].hash, timeout=timeout)
|
wait_until(lambda: node.getbestblockhash() == blocks[-1].hash, timeout=timeout)
|
||||||
else:
|
else:
|
||||||
assert rpc.getbestblockhash() != blocks[-1].hash
|
assert node.getbestblockhash() != blocks[-1].hash
|
||||||
|
|
||||||
if reject_code is not None:
|
if reject_code is not None:
|
||||||
wait_until(lambda: self.reject_code_received == reject_code, lock=mininode_lock)
|
wait_until(lambda: self.reject_code_received == reject_code, lock=mininode_lock)
|
||||||
if reject_reason is not None:
|
if reject_reason is not None:
|
||||||
wait_until(lambda: self.reject_reason_received == reject_reason, lock=mininode_lock)
|
wait_until(lambda: self.reject_reason_received == reject_reason, lock=mininode_lock)
|
||||||
|
|
||||||
def send_txs_and_test(self, txs, rpc, success=True, expect_disconnect=False, reject_code=None, reject_reason=None):
|
def send_txs_and_test(self, txs, node, *, success=True, expect_disconnect=False, reject_code=None, reject_reason=None):
|
||||||
"""Send txs to test node and test whether they're accepted to the mempool.
|
"""Send txs to test node and test whether they're accepted to the mempool.
|
||||||
|
|
||||||
- add all txs to our tx_store
|
- add all txs to our tx_store
|
||||||
|
@ -541,7 +541,7 @@ class P2PDataStore(P2PInterface):
|
||||||
else:
|
else:
|
||||||
self.sync_with_ping()
|
self.sync_with_ping()
|
||||||
|
|
||||||
raw_mempool = rpc.getrawmempool()
|
raw_mempool = node.getrawmempool()
|
||||||
if success:
|
if success:
|
||||||
# Check that all txs are now in the mempool
|
# Check that all txs are now in the mempool
|
||||||
for tx in txs:
|
for tx in txs:
|
||||||
|
|
Loading…
Reference in a new issue