Branch data Line data Source code
1 : : // Copyright (c) 2020-2021 The Bitcoin Core developers 2 : : // Distributed under the MIT software license, see the accompanying 3 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php. 4 : : 5 : : #include <merkleblock.h> 6 : : #include <test/fuzz/FuzzedDataProvider.h> 7 : : #include <test/fuzz/fuzz.h> 8 : : #include <test/fuzz/util.h> 9 : : #include <uint256.h> 10 : : 11 : : #include <cstdint> 12 : : #include <optional> 13 : : #include <string> 14 : : #include <vector> 15 : : 16 [ - + ]: 583 : FUZZ_TARGET(merkleblock) 17 : : { 18 : 237 : FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size()); 19 : 237 : CPartialMerkleTree partial_merkle_tree; 20 [ + - ]: 237 : CallOneOf( 21 : : fuzzed_data_provider, 22 : 282 : [&] { 23 : 45 : const std::optional<CPartialMerkleTree> opt_partial_merkle_tree = ConsumeDeserializable<CPartialMerkleTree>(fuzzed_data_provider); 24 [ + + ]: 45 : if (opt_partial_merkle_tree) { 25 [ + - + - : 203 : partial_merkle_tree = *opt_partial_merkle_tree; + - ] 26 : 30 : } 27 : 45 : }, 28 : 429 : [&] { 29 : 192 : CMerkleBlock merkle_block; 30 : 192 : const std::optional<CBlock> opt_block = ConsumeDeserializable<CBlock>(fuzzed_data_provider); 31 [ + - ]: 192 : CBloomFilter bloom_filter; 32 : 192 : std::set<uint256> txids; 33 [ + + + - : 192 : if (opt_block && !opt_block->vtx.empty()) { + + ] 34 [ + - + + ]: 96 : if (fuzzed_data_provider.ConsumeBool()) { 35 [ + - + - ]: 21 : merkle_block = CMerkleBlock{*opt_block, bloom_filter}; 36 [ + - + + ]: 96 : } else if (fuzzed_data_provider.ConsumeBool()) { 37 [ + - + + : 1440 : LIMITED_WHILE(fuzzed_data_provider.ConsumeBool(), 10000) { + + ] 38 [ + - ]: 1378 : txids.insert(ConsumeUInt256(fuzzed_data_provider)); 39 : 1378 : } 40 [ + - + - ]: 62 : merkle_block = CMerkleBlock{*opt_block, txids}; 41 : 62 : } 42 : 96 : } 43 [ + - ]: 192 : partial_merkle_tree = merkle_block.txn; 44 : 192 : }); 45 [ + - ]: 237 : (void)partial_merkle_tree.GetNumTransactions(); 46 : 237 : std::vector<uint256> matches; 47 : 237 : std::vector<unsigned int> indices; 48 [ - + ]: 237 : (void)partial_merkle_tree.ExtractMatches(matches, indices); 49 : 237 : }