mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-06-02 09:15:04 +02:00
Merge #18780: validation: add const for minimum witness commitment size
692f8307fctest: add test for witness commitment index (fanquake)06442549f8validation: Add minimum witness commitment size constant (fanquake) Pull request description:16101de5f3: Per [BIP 141](https://github.com/bitcoin/bips/blob/master/bip-0141.mediawiki#Commitment_structure), the witness commitment structure is at least 38 bytes, OP_RETURN (0x6a) + 36 (0x24) + 4 byte header (0xaa21a9ed) + 32 byte SHA256 hash. It can be longer, however any additional data has no consensus meaning.54f8c48d6a: As per BIP 141, if there is more than 1 pubkey that matches the witness commitment structure, the one with the highest output index should be chosen. This adds a sanity check that we are doing that, which will fail if anyone tries to "optimize" GetWitnessCommitmentIndex() by returning early. ACKs for top commit: MarcoFalke: ACK692f8307fc🌵 jonatack: Code review ACK692f830ajtowns: ACK692f8307fcjnewbery: utACK692f8307fclaanwj: ACK692f8307fcTree-SHA512: 7af3fe4b8a52fea2cdd0aec95f7bb935351a77b73d934bc88d6625a3503311b2a062cba5190b2228f97caa76840db3889032d910fc8e318ca8e7810a8afbafa0
This commit is contained in:
@@ -340,4 +340,38 @@ BOOST_AUTO_TEST_CASE(mempool_locks_reorg)
|
||||
rpc_thread.join();
|
||||
}
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(witness_commitment_index)
|
||||
{
|
||||
CScript pubKey;
|
||||
pubKey << 1 << OP_TRUE;
|
||||
auto ptemplate = BlockAssembler(*m_node.mempool, Params()).CreateNewBlock(pubKey);
|
||||
CBlock pblock = ptemplate->block;
|
||||
|
||||
CTxOut witness;
|
||||
witness.scriptPubKey.resize(MINIMUM_WITNESS_COMMITMENT);
|
||||
witness.scriptPubKey[0] = OP_RETURN;
|
||||
witness.scriptPubKey[1] = 0x24;
|
||||
witness.scriptPubKey[2] = 0xaa;
|
||||
witness.scriptPubKey[3] = 0x21;
|
||||
witness.scriptPubKey[4] = 0xa9;
|
||||
witness.scriptPubKey[5] = 0xed;
|
||||
|
||||
// A witness larger than the minimum size is still valid
|
||||
CTxOut min_plus_one = witness;
|
||||
min_plus_one.scriptPubKey.resize(MINIMUM_WITNESS_COMMITMENT + 1);
|
||||
|
||||
CTxOut invalid = witness;
|
||||
invalid.scriptPubKey[0] = OP_VERIFY;
|
||||
|
||||
CMutableTransaction txCoinbase(*pblock.vtx[0]);
|
||||
txCoinbase.vout.resize(4);
|
||||
txCoinbase.vout[0] = witness;
|
||||
txCoinbase.vout[1] = witness;
|
||||
txCoinbase.vout[2] = min_plus_one;
|
||||
txCoinbase.vout[3] = invalid;
|
||||
pblock.vtx[0] = MakeTransactionRef(std::move(txCoinbase));
|
||||
|
||||
BOOST_CHECK_EQUAL(GetWitnessCommitmentIndex(pblock), 2);
|
||||
}
|
||||
BOOST_AUTO_TEST_SUITE_END()
|
||||
|
||||
Reference in New Issue
Block a user