tests: fuzz dns resource records

It should help to catch issues like https://github.com/systemd/systemd/issues/19584,
https://github.com/systemd/systemd/issues/25449.
This commit is contained in:
Evgeny Vereshchagin 2022-11-25 20:00:30 +00:00
parent b6e8a4f2b6
commit ae8654f9e6
2 changed files with 40 additions and 0 deletions

View file

@ -0,0 +1,35 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include "fd-util.h"
#include "fuzz.h"
#include "memory-util.h"
#include "resolved-dns-packet.h"
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
_cleanup_free_ char *out = NULL; /* out should be freed after f */
size_t out_size;
_cleanup_fclose_ FILE *f = NULL;
_cleanup_(dns_resource_record_unrefp) DnsResourceRecord *rr = NULL, *copy = NULL;
_cleanup_(json_variant_unrefp) JsonVariant *v = NULL;
if (outside_size_range(size, 0, DNS_PACKET_SIZE_MAX))
return 0;
if (dns_resource_record_new_from_raw(&rr, data, size) < 0)
return 0;
assert_se(copy = dns_resource_record_copy(rr));
assert_se(dns_resource_record_equal(copy, rr) > 0);
assert_se(f = open_memstream_unlocked(&out, &out_size));
(void) fprintf(f, "%s", strna(dns_resource_record_to_string(rr)));
if (dns_resource_record_to_json(rr, &v) < 0)
return 0;
(void) json_variant_dump(v, JSON_FORMAT_PRETTY|JSON_FORMAT_COLOR|JSON_FORMAT_SOURCE, f, NULL);
(void) dns_resource_record_to_wire_format(rr, false);
(void) dns_resource_record_to_wire_format(rr, true);
return 0;
}

View file

@ -237,6 +237,11 @@ fuzzers += [
libshared],
[lib_openssl_or_gcrypt,
libm]],
[files('fuzz-resource-record.c'),
[libsystemd_resolve_core,
libshared],
[lib_openssl_or_gcrypt,
libm]],
]
systemd_resolved_sources += files('resolved.c')