mirror of
https://github.com/dashpay/dash.git
synced 2024-12-26 04:22:55 +01:00
merge bitcoin#19065: Add fuzzing harness for CAddrMan
This commit is contained in:
parent
fb77c47ed4
commit
c2cb946d5c
@ -8,6 +8,7 @@ FUZZ_TARGETS = \
|
|||||||
test/fuzz/addr_info_deserialize \
|
test/fuzz/addr_info_deserialize \
|
||||||
test/fuzz/addrdb \
|
test/fuzz/addrdb \
|
||||||
test/fuzz/address_deserialize \
|
test/fuzz/address_deserialize \
|
||||||
|
test/fuzz/addrman \
|
||||||
test/fuzz/addrman_deserialize \
|
test/fuzz/addrman_deserialize \
|
||||||
test/fuzz/asmap \
|
test/fuzz/asmap \
|
||||||
test/fuzz/asmap_direct \
|
test/fuzz/asmap_direct \
|
||||||
@ -370,6 +371,12 @@ test_fuzz_address_deserialize_LDADD = $(FUZZ_SUITE_LD_COMMON)
|
|||||||
test_fuzz_address_deserialize_LDFLAGS = $(FUZZ_SUITE_LDFLAGS_COMMON)
|
test_fuzz_address_deserialize_LDFLAGS = $(FUZZ_SUITE_LDFLAGS_COMMON)
|
||||||
test_fuzz_address_deserialize_SOURCES = $(FUZZ_SUITE) test/fuzz/deserialize.cpp
|
test_fuzz_address_deserialize_SOURCES = $(FUZZ_SUITE) test/fuzz/deserialize.cpp
|
||||||
|
|
||||||
|
test_fuzz_addrman_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES)
|
||||||
|
test_fuzz_addrman_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
||||||
|
test_fuzz_addrman_LDADD = $(FUZZ_SUITE_LD_COMMON)
|
||||||
|
test_fuzz_addrman_LDFLAGS = $(FUZZ_SUITE_LDFLAGS_COMMON)
|
||||||
|
test_fuzz_addrman_SOURCES = $(FUZZ_SUITE) test/fuzz/addrman.cpp
|
||||||
|
|
||||||
test_fuzz_addrman_deserialize_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) -DADDRMAN_DESERIALIZE=1
|
test_fuzz_addrman_deserialize_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) -DADDRMAN_DESERIALIZE=1
|
||||||
test_fuzz_addrman_deserialize_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
test_fuzz_addrman_deserialize_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
||||||
test_fuzz_addrman_deserialize_LDADD = $(FUZZ_SUITE_LD_COMMON)
|
test_fuzz_addrman_deserialize_LDADD = $(FUZZ_SUITE_LD_COMMON)
|
||||||
|
119
src/test/fuzz/addrman.cpp
Normal file
119
src/test/fuzz/addrman.cpp
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
// 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 <addrdb.h>
|
||||||
|
#include <addrman.h>
|
||||||
|
#include <chainparams.h>
|
||||||
|
#include <merkleblock.h>
|
||||||
|
#include <test/fuzz/FuzzedDataProvider.h>
|
||||||
|
#include <test/fuzz/fuzz.h>
|
||||||
|
#include <test/fuzz/util.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <util/asmap.h>
|
||||||
|
|
||||||
|
#include <cstdint>
|
||||||
|
#include <optional>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
void initialize()
|
||||||
|
{
|
||||||
|
SelectParams(CBaseChainParams::REGTEST);
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_one_input(const std::vector<uint8_t>& buffer)
|
||||||
|
{
|
||||||
|
FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
|
||||||
|
|
||||||
|
SetMockTime(ConsumeTime(fuzzed_data_provider));
|
||||||
|
CAddrMan addr_man;
|
||||||
|
if (fuzzed_data_provider.ConsumeBool()) {
|
||||||
|
addr_man.m_asmap = ConsumeRandomLengthBitVector(fuzzed_data_provider);
|
||||||
|
if (!SanityCheckASMap(addr_man.m_asmap)) {
|
||||||
|
addr_man.m_asmap.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (fuzzed_data_provider.ConsumeBool()) {
|
||||||
|
switch (fuzzed_data_provider.ConsumeIntegralInRange<int>(0, 11)) {
|
||||||
|
case 0: {
|
||||||
|
addr_man.Clear();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 1: {
|
||||||
|
addr_man.ResolveCollisions();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 2: {
|
||||||
|
(void)addr_man.SelectTriedCollision();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 3: {
|
||||||
|
(void)addr_man.Select(fuzzed_data_provider.ConsumeBool());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 4: {
|
||||||
|
(void)addr_man.GetAddr();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 5: {
|
||||||
|
const std::optional<CAddress> opt_address = ConsumeDeserializable<CAddress>(fuzzed_data_provider);
|
||||||
|
const std::optional<CNetAddr> opt_net_addr = ConsumeDeserializable<CNetAddr>(fuzzed_data_provider);
|
||||||
|
if (opt_address && opt_net_addr) {
|
||||||
|
addr_man.Add(*opt_address, *opt_net_addr, fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(0, 100000000));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 6: {
|
||||||
|
std::vector<CAddress> addresses;
|
||||||
|
while (fuzzed_data_provider.ConsumeBool()) {
|
||||||
|
const std::optional<CAddress> opt_address = ConsumeDeserializable<CAddress>(fuzzed_data_provider);
|
||||||
|
if (!opt_address) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
addresses.push_back(*opt_address);
|
||||||
|
}
|
||||||
|
const std::optional<CNetAddr> opt_net_addr = ConsumeDeserializable<CNetAddr>(fuzzed_data_provider);
|
||||||
|
if (opt_net_addr) {
|
||||||
|
addr_man.Add(addresses, *opt_net_addr, fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(0, 100000000));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 7: {
|
||||||
|
const std::optional<CService> opt_service = ConsumeDeserializable<CService>(fuzzed_data_provider);
|
||||||
|
if (opt_service) {
|
||||||
|
addr_man.Good(*opt_service, fuzzed_data_provider.ConsumeBool(), ConsumeTime(fuzzed_data_provider));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 8: {
|
||||||
|
const std::optional<CService> opt_service = ConsumeDeserializable<CService>(fuzzed_data_provider);
|
||||||
|
if (opt_service) {
|
||||||
|
addr_man.Attempt(*opt_service, fuzzed_data_provider.ConsumeBool(), ConsumeTime(fuzzed_data_provider));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 9: {
|
||||||
|
const std::optional<CService> opt_service = ConsumeDeserializable<CService>(fuzzed_data_provider);
|
||||||
|
if (opt_service) {
|
||||||
|
addr_man.Connected(*opt_service, ConsumeTime(fuzzed_data_provider));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 10: {
|
||||||
|
const std::optional<CService> opt_service = ConsumeDeserializable<CService>(fuzzed_data_provider);
|
||||||
|
if (opt_service) {
|
||||||
|
addr_man.SetServices(*opt_service, ServiceFlags{fuzzed_data_provider.ConsumeIntegral<uint64_t>()});
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 11: {
|
||||||
|
(void)addr_man.Check();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
(void)addr_man.size();
|
||||||
|
CDataStream data_stream(SER_NETWORK, PROTOCOL_VERSION);
|
||||||
|
data_stream << addr_man;
|
||||||
|
}
|
@ -117,7 +117,7 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
|||||||
connman.RemoveAddedNode(random_string);
|
connman.RemoveAddedNode(random_string);
|
||||||
break;
|
break;
|
||||||
case 24: {
|
case 24: {
|
||||||
const std::vector<bool> asmap = ConsumeRandomLengthIntegralVector<bool>(fuzzed_data_provider, 512);
|
const std::vector<bool> asmap = ConsumeRandomLengthBitVector(fuzzed_data_provider);
|
||||||
if (SanityCheckASMap(asmap)) {
|
if (SanityCheckASMap(asmap)) {
|
||||||
connman.SetAsmap(asmap);
|
connman.SetAsmap(asmap);
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ void test_one_input(const std::vector<uint8_t>& buffer)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 3: {
|
case 3: {
|
||||||
const std::vector<bool> asmap = ConsumeRandomLengthIntegralVector<bool>(fuzzed_data_provider, 128);
|
const std::vector<bool> asmap = ConsumeRandomLengthBitVector(fuzzed_data_provider);
|
||||||
if (!SanityCheckASMap(asmap)) {
|
if (!SanityCheckASMap(asmap)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include <chainparamsbase.h>
|
#include <chainparamsbase.h>
|
||||||
#include <coins.h>
|
#include <coins.h>
|
||||||
#include <consensus/consensus.h>
|
#include <consensus/consensus.h>
|
||||||
|
#include <merkleblock.h>
|
||||||
#include <net.h>
|
#include <net.h>
|
||||||
#include <netaddress.h>
|
#include <netaddress.h>
|
||||||
#include <netbase.h>
|
#include <netbase.h>
|
||||||
@ -24,6 +25,7 @@
|
|||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
#include <uint256.h>
|
#include <uint256.h>
|
||||||
|
#include <util/time.h>
|
||||||
#include <version.h>
|
#include <version.h>
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
@ -37,6 +39,16 @@
|
|||||||
return {s.begin(), s.end()};
|
return {s.begin(), s.end()};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[[ nodiscard ]] inline std::vector<bool> ConsumeRandomLengthBitVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
||||||
|
{
|
||||||
|
return BytesToBits(ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length));
|
||||||
|
}
|
||||||
|
|
||||||
|
[[ nodiscard ]] inline CDataStream ConsumeDataStream(FuzzedDataProvider& fuzzed_data_provider, const size_t max_length = 4096) noexcept
|
||||||
|
{
|
||||||
|
return {ConsumeRandomLengthByteVector(fuzzed_data_provider, max_length), SER_NETWORK, INIT_PROTO_VERSION};
|
||||||
|
}
|
||||||
|
|
||||||
[[ nodiscard ]] inline std::vector<std::string> ConsumeRandomLengthStringVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_vector_size = 16, const size_t max_string_length = 16) noexcept
|
[[ nodiscard ]] inline std::vector<std::string> ConsumeRandomLengthStringVector(FuzzedDataProvider& fuzzed_data_provider, const size_t max_vector_size = 16, const size_t max_string_length = 16) noexcept
|
||||||
{
|
{
|
||||||
const size_t n_elements = fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, max_vector_size);
|
const size_t n_elements = fuzzed_data_provider.ConsumeIntegralInRange<size_t>(0, max_vector_size);
|
||||||
@ -82,6 +94,13 @@ template <typename T>
|
|||||||
return fuzzed_data_provider.ConsumeIntegralInRange<CAmount>(0, MAX_MONEY);
|
return fuzzed_data_provider.ConsumeIntegralInRange<CAmount>(0, MAX_MONEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[[ nodiscard ]] inline int64_t ConsumeTime(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
|
{
|
||||||
|
static const int64_t time_min = ParseISO8601DateTime("1970-01-01T00:00:00Z");
|
||||||
|
static const int64_t time_max = ParseISO8601DateTime("9999-12-31T23:59:59Z");
|
||||||
|
return fuzzed_data_provider.ConsumeIntegralInRange<int64_t>(time_min, time_max);
|
||||||
|
}
|
||||||
|
|
||||||
[[ nodiscard ]] inline CScript ConsumeScript(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
[[ nodiscard ]] inline CScript ConsumeScript(FuzzedDataProvider& fuzzed_data_provider) noexcept
|
||||||
{
|
{
|
||||||
const std::vector<uint8_t> b = ConsumeRandomLengthByteVector(fuzzed_data_provider);
|
const std::vector<uint8_t> b = ConsumeRandomLengthByteVector(fuzzed_data_provider);
|
||||||
|
Loading…
Reference in New Issue
Block a user