// Copyright (c) 2020 The Bitcoin Core developers // Distributed under the MIT software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #include #include #include #include #include #include #include #include #include #include void test_one_input(const std::vector& buffer) { FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size()); const Optional block_header = ConsumeDeserializable(fuzzed_data_provider); if (!block_header) { return; } { const uint256 hash = block_header->GetHash(); static const uint256 u256_max(uint256S("ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff")); assert(hash != u256_max); assert(block_header->GetBlockTime() == block_header->nTime); assert(block_header->IsNull() == (block_header->nBits == 0)); } { CBlockHeader mut_block_header = *block_header; mut_block_header.SetNull(); assert(mut_block_header.IsNull()); CBlock block{*block_header}; assert(block.GetBlockHeader().GetHash() == block_header->GetHash()); (void)block.ToString(); block.SetNull(); assert(block.GetBlockHeader().GetHash() == mut_block_header.GetHash()); } { std::optional block_locator = ConsumeDeserializable(fuzzed_data_provider); if (block_locator) { (void)block_locator->IsNull(); block_locator->SetNull(); assert(block_locator->IsNull()); } } }