mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-07-07 00:40:34 +02:00
Merge #15982: tests: Make msg_block a witness block
fa1d766717
tests: Make msg_block a witness block (MarcoFalke)fa52eb55c9
test: Remove True argument to CBlock::serialize (MarcoFalke) Pull request description: Unnamed arguments are confusing as to what they mean without looking up the function signature. Since segwit is active by default in regtest, and all blocks are serialized with witness (#15664), remove the argument `with_witness=True` from all calls to `CBlock::serialize` and `BlockTransactions::serialize`. ACKs for commit fa1d76: laanwj: code-review ACKfa1d766717
Tree-SHA512: 2c550646f99c9ca86a223ca988c61a730f5e6646807adeaa7174fb2424a32cea3fef8bcd3e0b12e162e7ff192877d0c02fd0654df6ee1a9b821b065707c2dcbc
This commit is contained in:
@ -25,12 +25,12 @@ from test_framework.messages import (
|
||||
MSG_WITNESS_FLAG,
|
||||
NODE_NETWORK,
|
||||
NODE_WITNESS,
|
||||
msg_block,
|
||||
msg_no_witness_block,
|
||||
msg_getdata,
|
||||
msg_headers,
|
||||
msg_inv,
|
||||
msg_tx,
|
||||
msg_witness_block,
|
||||
msg_block,
|
||||
msg_witness_tx,
|
||||
ser_uint256,
|
||||
ser_vector,
|
||||
@ -111,7 +111,7 @@ def get_virtual_size(witness_block):
|
||||
|
||||
Virtual size is base + witness/4."""
|
||||
base_size = len(witness_block.serialize(with_witness=False))
|
||||
total_size = len(witness_block.serialize(with_witness=True))
|
||||
total_size = len(witness_block.serialize())
|
||||
# the "+3" is so we round up
|
||||
vsize = int((3 * base_size + total_size + 3) / 4)
|
||||
return vsize
|
||||
@ -134,7 +134,7 @@ def test_witness_block(node, p2p, block, accepted, with_witness=True, reason=Non
|
||||
- use the getbestblockhash rpc to check for acceptance."""
|
||||
reason = [reason] if reason else []
|
||||
with node.assert_debug_log(expected_msgs=reason):
|
||||
p2p.send_message(msg_witness_block(block) if with_witness else msg_block(block))
|
||||
p2p.send_message(msg_block(block) if with_witness else msg_no_witness_block(block))
|
||||
p2p.sync_with_ping()
|
||||
assert_equal(node.getbestblockhash() == block.hash, accepted)
|
||||
|
||||
@ -298,7 +298,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||
|
||||
block = self.build_next_block(version=1)
|
||||
block.solve()
|
||||
self.test_node.send_message(msg_block(block))
|
||||
self.test_node.send_message(msg_no_witness_block(block))
|
||||
self.test_node.sync_with_ping() # make sure the block was processed
|
||||
txid = block.vtx[0].sha256
|
||||
|
||||
@ -345,7 +345,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||
|
||||
# But it should not be permanently marked bad...
|
||||
# Resend without witness information.
|
||||
self.test_node.send_message(msg_block(block))
|
||||
self.test_node.send_message(msg_no_witness_block(block))
|
||||
self.test_node.sync_with_ping()
|
||||
assert_equal(self.nodes[0].getbestblockhash(), block.hash)
|
||||
|
||||
@ -403,7 +403,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||
block_hash = int(block_hash, 16)
|
||||
block = self.test_node.request_block(block_hash, 2)
|
||||
wit_block = self.test_node.request_block(block_hash, 2 | MSG_WITNESS_FLAG)
|
||||
assert_equal(block.serialize(True), wit_block.serialize(True))
|
||||
assert_equal(block.serialize(), wit_block.serialize())
|
||||
assert_equal(block.serialize(), hex_str_to_bytes(rpc_block))
|
||||
else:
|
||||
# After activation, witness blocks and non-witness blocks should
|
||||
@ -419,15 +419,15 @@ class SegWitTest(BitcoinTestFramework):
|
||||
rpc_block = self.nodes[0].getblock(block.hash, False)
|
||||
non_wit_block = self.test_node.request_block(block.sha256, 2)
|
||||
wit_block = self.test_node.request_block(block.sha256, 2 | MSG_WITNESS_FLAG)
|
||||
assert_equal(wit_block.serialize(True), hex_str_to_bytes(rpc_block))
|
||||
assert_equal(wit_block.serialize(), hex_str_to_bytes(rpc_block))
|
||||
assert_equal(wit_block.serialize(False), non_wit_block.serialize())
|
||||
assert_equal(wit_block.serialize(True), block.serialize(True))
|
||||
assert_equal(wit_block.serialize(), block.serialize())
|
||||
|
||||
# Test size, vsize, weight
|
||||
rpc_details = self.nodes[0].getblock(block.hash, True)
|
||||
assert_equal(rpc_details["size"], len(block.serialize(True)))
|
||||
assert_equal(rpc_details["size"], len(block.serialize()))
|
||||
assert_equal(rpc_details["strippedsize"], len(block.serialize(False)))
|
||||
weight = 3 * len(block.serialize(False)) + len(block.serialize(True))
|
||||
weight = 3 * len(block.serialize(False)) + len(block.serialize())
|
||||
assert_equal(rpc_details["weight"], weight)
|
||||
|
||||
# Upgraded node should not ask for blocks from unupgraded
|
||||
@ -791,7 +791,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||
block.solve()
|
||||
|
||||
# Test the test -- witness serialization should be different
|
||||
assert msg_witness_block(block).serialize() != msg_block(block).serialize()
|
||||
assert msg_block(block).serialize() != msg_no_witness_block(block).serialize()
|
||||
|
||||
# This empty block should be valid.
|
||||
test_witness_block(self.nodes[0], self.test_node, block, accepted=True)
|
||||
@ -884,13 +884,13 @@ class SegWitTest(BitcoinTestFramework):
|
||||
|
||||
# We can't send over the p2p network, because this is too big to relay
|
||||
# TODO: repeat this test with a block that can be relayed
|
||||
self.nodes[0].submitblock(block.serialize(True).hex())
|
||||
self.nodes[0].submitblock(block.serialize().hex())
|
||||
|
||||
assert self.nodes[0].getbestblockhash() != block.hash
|
||||
|
||||
block.vtx[0].wit.vtxinwit[0].scriptWitness.stack.pop()
|
||||
assert get_virtual_size(block) < MAX_BLOCK_BASE_SIZE
|
||||
self.nodes[0].submitblock(block.serialize(True).hex())
|
||||
self.nodes[0].submitblock(block.serialize().hex())
|
||||
|
||||
assert self.nodes[0].getbestblockhash() == block.hash
|
||||
|
||||
@ -969,7 +969,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||
assert_equal(vsize, MAX_BLOCK_BASE_SIZE + 1)
|
||||
# Make sure that our test case would exceed the old max-network-message
|
||||
# limit
|
||||
assert len(block.serialize(True)) > 2 * 1024 * 1024
|
||||
assert len(block.serialize()) > 2 * 1024 * 1024
|
||||
|
||||
test_witness_block(self.nodes[0], self.test_node, block, accepted=False)
|
||||
|
||||
@ -997,14 +997,14 @@ class SegWitTest(BitcoinTestFramework):
|
||||
add_witness_commitment(block, nonce=1)
|
||||
block.vtx[0].wit = CTxWitness() # drop the nonce
|
||||
block.solve()
|
||||
self.nodes[0].submitblock(block.serialize(True).hex())
|
||||
self.nodes[0].submitblock(block.serialize().hex())
|
||||
assert self.nodes[0].getbestblockhash() != block.hash
|
||||
|
||||
# Now redo commitment with the standard nonce, but let bitcoind fill it in.
|
||||
add_witness_commitment(block, nonce=0)
|
||||
block.vtx[0].wit = CTxWitness()
|
||||
block.solve()
|
||||
self.nodes[0].submitblock(block.serialize(True).hex())
|
||||
self.nodes[0].submitblock(block.serialize().hex())
|
||||
assert_equal(self.nodes[0].getbestblockhash(), block.hash)
|
||||
|
||||
# This time, add a tx with non-empty witness, but don't supply
|
||||
@ -1019,7 +1019,7 @@ class SegWitTest(BitcoinTestFramework):
|
||||
block_2.vtx[0].vout.pop()
|
||||
block_2.vtx[0].wit = CTxWitness()
|
||||
|
||||
self.nodes[0].submitblock(block_2.serialize(True).hex())
|
||||
self.nodes[0].submitblock(block_2.serialize().hex())
|
||||
# Tip should not advance!
|
||||
assert self.nodes[0].getbestblockhash() != block_2.hash
|
||||
|
||||
|
Reference in New Issue
Block a user