mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-12 04:42:36 -03:00
fuzz: Implement fuzzed_dns_lookup_function as lambda
This commit is contained in:
parent
eceb3f7707
commit
7c8c140ecc
1 changed files with 9 additions and 15 deletions
|
@ -12,27 +12,22 @@
|
|||
#include <string>
|
||||
#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)
|
||||
{
|
||||
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 unsigned int max_results = fuzzed_data_provider.ConsumeIntegral<unsigned int>();
|
||||
const bool allow_lookup = fuzzed_data_provider.ConsumeBool();
|
||||
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;
|
||||
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());
|
||||
}
|
||||
}
|
||||
fuzzed_data_provider_ptr = nullptr;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue