mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-06-12 09:52:21 +02:00
Merge #21443: fuzz: Implement fuzzed_dns_lookup_function as a lambda
7c8c140ecc95ab2ac90e20951416886c9ac5fa93 fuzz: Implement fuzzed_dns_lookup_function as lambda (practicalswift) Pull request description: Implement `fuzzed_dns_lookup_function` as a lambda. As wisely suggested by MarcoFalke in https://github.com/bitcoin/bitcoin/pull/19415#discussion_r594244506. Thanks! :) ACKs for top commit: MarcoFalke: cr ACK 7c8c140ecc95ab2ac90e20951416886c9ac5fa93 vasild: ACK 7c8c140ecc95ab2ac90e20951416886c9ac5fa93 Tree-SHA512: b175f2ad42e9a2be1f769ac677b2872e73ae621731d27e9a24bedadc14d9a6682c7fd1946a0df436d37e7b0cc0d212c1eef69f0409fb975cf9c460cd45f6e4ac
This commit is contained in:
commit
9a5e097435
@ -12,27 +12,22 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace {
|
|
||||||
FuzzedDataProvider* fuzzed_data_provider_ptr = nullptr;
|
|
||||||
|
|
||||||
std::vector<CNetAddr> fuzzed_dns_lookup_function(const std::string& name, bool allow_lookup)
|
|
||||||
{
|
|
||||||
std::vector<CNetAddr> resolved_addresses;
|
|
||||||
while (fuzzed_data_provider_ptr->ConsumeBool()) {
|
|
||||||
resolved_addresses.push_back(ConsumeNetAddr(*fuzzed_data_provider_ptr));
|
|
||||||
}
|
|
||||||
return resolved_addresses;
|
|
||||||
}
|
|
||||||
} // namespace
|
|
||||||
|
|
||||||
FUZZ_TARGET(netbase_dns_lookup)
|
FUZZ_TARGET(netbase_dns_lookup)
|
||||||
{
|
{
|
||||||
FuzzedDataProvider fuzzed_data_provider{buffer.data(), buffer.size()};
|
FuzzedDataProvider fuzzed_data_provider{buffer.data(), buffer.size()};
|
||||||
fuzzed_data_provider_ptr = &fuzzed_data_provider;
|
|
||||||
const std::string name = fuzzed_data_provider.ConsumeRandomLengthString(512);
|
const std::string name = fuzzed_data_provider.ConsumeRandomLengthString(512);
|
||||||
const unsigned int max_results = fuzzed_data_provider.ConsumeIntegral<unsigned int>();
|
const unsigned int max_results = fuzzed_data_provider.ConsumeIntegral<unsigned int>();
|
||||||
const bool allow_lookup = fuzzed_data_provider.ConsumeBool();
|
const bool allow_lookup = fuzzed_data_provider.ConsumeBool();
|
||||||
const int default_port = fuzzed_data_provider.ConsumeIntegral<int>();
|
const int default_port = fuzzed_data_provider.ConsumeIntegral<int>();
|
||||||
|
|
||||||
|
auto fuzzed_dns_lookup_function = [&](const std::string&, bool) {
|
||||||
|
std::vector<CNetAddr> resolved_addresses;
|
||||||
|
while (fuzzed_data_provider.ConsumeBool()) {
|
||||||
|
resolved_addresses.push_back(ConsumeNetAddr(fuzzed_data_provider));
|
||||||
|
}
|
||||||
|
return resolved_addresses;
|
||||||
|
};
|
||||||
|
|
||||||
{
|
{
|
||||||
std::vector<CNetAddr> resolved_addresses;
|
std::vector<CNetAddr> resolved_addresses;
|
||||||
if (LookupHost(name, resolved_addresses, max_results, allow_lookup, fuzzed_dns_lookup_function)) {
|
if (LookupHost(name, resolved_addresses, max_results, allow_lookup, fuzzed_dns_lookup_function)) {
|
||||||
@ -73,5 +68,4 @@ FUZZ_TARGET(netbase_dns_lookup)
|
|||||||
assert(resolved_subnet.IsValid());
|
assert(resolved_subnet.IsValid());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fuzzed_data_provider_ptr = nullptr;
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user