test: add some unit tests for merkle.cpp
following situations are covered: - empty block - one Tx - Merkle root of a block with odd Txs should not change with repeating last one - Merkle root is computed with combining Merkle root of left subtree and right subtree - block witness is Merkle root of a block when setting first Tx to zero. Signed-off-by: soroosh-sdi <soroosh.sardari@gmail.com>
This commit is contained in:
parent
08bb4c3156
commit
8573429d46
1 changed files with 100 additions and 0 deletions
|
@ -249,4 +249,104 @@ BOOST_AUTO_TEST_CASE(merkle_test)
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
BOOST_AUTO_TEST_CASE(merkle_test_empty_block)
|
||||
{
|
||||
bool mutated = false;
|
||||
CBlock block;
|
||||
uint256 root = BlockMerkleRoot(block, &mutated);
|
||||
|
||||
BOOST_CHECK_EQUAL(root.IsNull(), true);
|
||||
BOOST_CHECK_EQUAL(mutated, false);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(merkle_test_oneTx_block)
|
||||
{
|
||||
bool mutated = false;
|
||||
CBlock block;
|
||||
|
||||
block.vtx.resize(1);
|
||||
CMutableTransaction mtx;
|
||||
mtx.nLockTime = 0;
|
||||
block.vtx[0] = MakeTransactionRef(std::move(mtx));
|
||||
uint256 root = BlockMerkleRoot(block, &mutated);
|
||||
BOOST_CHECK_EQUAL(root, block.vtx[0]->GetHash());
|
||||
BOOST_CHECK_EQUAL(mutated, false);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(merkle_test_OddTxWithRepeatedLastTx_block)
|
||||
{
|
||||
bool mutated;
|
||||
CBlock block, blockWithRepeatedLastTx;
|
||||
|
||||
block.vtx.resize(3);
|
||||
|
||||
for (std::size_t pos = 0; pos < block.vtx.size(); pos++) {
|
||||
CMutableTransaction mtx;
|
||||
mtx.nLockTime = pos;
|
||||
block.vtx[pos] = MakeTransactionRef(std::move(mtx));
|
||||
}
|
||||
|
||||
blockWithRepeatedLastTx = block;
|
||||
blockWithRepeatedLastTx.vtx.push_back(blockWithRepeatedLastTx.vtx.back());
|
||||
|
||||
uint256 rootofBlock = BlockMerkleRoot(block, &mutated);
|
||||
BOOST_CHECK_EQUAL(mutated, false);
|
||||
|
||||
uint256 rootofBlockWithRepeatedLastTx = BlockMerkleRoot(blockWithRepeatedLastTx, &mutated);
|
||||
BOOST_CHECK_EQUAL(rootofBlock, rootofBlockWithRepeatedLastTx);
|
||||
BOOST_CHECK_EQUAL(mutated, true);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(merkle_test_LeftSubtreeRightSubtree)
|
||||
{
|
||||
CBlock block, leftSubtreeBlock, rightSubtreeBlock;
|
||||
|
||||
block.vtx.resize(4);
|
||||
std::size_t pos;
|
||||
for (pos = 0; pos < block.vtx.size(); pos++) {
|
||||
CMutableTransaction mtx;
|
||||
mtx.nLockTime = pos;
|
||||
block.vtx[pos] = MakeTransactionRef(std::move(mtx));
|
||||
}
|
||||
|
||||
for (pos = 0; pos < block.vtx.size() / 2; pos++)
|
||||
leftSubtreeBlock.vtx.push_back(block.vtx[pos]);
|
||||
|
||||
for (pos = block.vtx.size() / 2; pos < block.vtx.size(); pos++)
|
||||
rightSubtreeBlock.vtx.push_back(block.vtx[pos]);
|
||||
|
||||
uint256 root = BlockMerkleRoot(block);
|
||||
uint256 rootOfLeftSubtree = BlockMerkleRoot(leftSubtreeBlock);
|
||||
uint256 rootOfRightSubtree = BlockMerkleRoot(rightSubtreeBlock);
|
||||
std::vector<uint256> leftRight;
|
||||
leftRight.push_back(rootOfLeftSubtree);
|
||||
leftRight.push_back(rootOfRightSubtree);
|
||||
uint256 rootOfLR = ComputeMerkleRoot(leftRight);
|
||||
|
||||
BOOST_CHECK_EQUAL(root, rootOfLR);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(merkle_test_BlockWitness)
|
||||
{
|
||||
CBlock block;
|
||||
|
||||
block.vtx.resize(2);
|
||||
for (std::size_t pos = 0; pos < block.vtx.size(); pos++) {
|
||||
CMutableTransaction mtx;
|
||||
mtx.nLockTime = pos;
|
||||
block.vtx[pos] = MakeTransactionRef(std::move(mtx));
|
||||
}
|
||||
|
||||
uint256 blockWitness = BlockWitnessMerkleRoot(block);
|
||||
|
||||
std::vector<uint256> hashes;
|
||||
hashes.resize(block.vtx.size());
|
||||
hashes[0].SetNull();
|
||||
hashes[1] = block.vtx[1]->GetHash();
|
||||
|
||||
uint256 merkelRootofHashes = ComputeMerkleRoot(hashes);
|
||||
|
||||
BOOST_CHECK_EQUAL(merkelRootofHashes, blockWitness);
|
||||
}
|
||||
BOOST_AUTO_TEST_SUITE_END()
|
||||
|
|
Loading…
Add table
Reference in a new issue