// Copyright (c) 2020-2021 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 FUZZ_TARGET(rolling_bloom_filter) { FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size()); CRollingBloomFilter rolling_bloom_filter{ fuzzed_data_provider.ConsumeIntegralInRange(1, 1000), 0.999 / fuzzed_data_provider.ConsumeIntegralInRange(1, std::numeric_limits::max())}; LIMITED_WHILE(fuzzed_data_provider.remaining_bytes() > 0, 3000) { CallOneOf( fuzzed_data_provider, [&] { const std::vector b = ConsumeRandomLengthByteVector(fuzzed_data_provider); (void)rolling_bloom_filter.contains(b); rolling_bloom_filter.insert(b); const bool present = rolling_bloom_filter.contains(b); assert(present); }, [&] { const uint256 u256{ConsumeUInt256(fuzzed_data_provider)}; (void)rolling_bloom_filter.contains(u256); rolling_bloom_filter.insert(u256); const bool present = rolling_bloom_filter.contains(u256); assert(present); }, [&] { rolling_bloom_filter.reset(); }); } }