A C library for asynchronous DNS requests (grpc依赖)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Brad House affdf92306 remove dead code: bitncmp 1 year ago
..
fuzzinput Avoid buffer overflow in RC4 loop comparison (#336) 5 years ago
fuzznames Avoid buffer overflow in RC4 loop comparison (#336) 5 years ago
.gitignore ignore aminclude_static.am, as generated by AX_AM_MACROS_STATIC (#508) 2 years ago
CMakeLists.txt Use external GoogleTest instead of bundling it (#655) 1 year ago
Makefile.am Use external GoogleTest instead of bundling it (#655) 1 year ago
Makefile.inc provide SPDX identifiers and a REUSE CI job to verify 2 years ago
Makefile.m32 Use external GoogleTest instead of bundling it (#655) 1 year ago
Makefile.msvc Use external GoogleTest instead of bundling it (#655) 1 year ago
README.md provide SPDX identifiers and a REUSE CI job to verify 2 years ago
ares-fuzz.c Reformat code using clang-format (#579) 1 year ago
ares-test-ai.h `ares_channel` -> `ares_channel_t *`: don't bury the pointer (#595) 1 year ago
ares-test-fuzz-name.c Reformat code using clang-format (#579) 1 year ago
ares-test-fuzz.c Reformat code using clang-format (#579) 1 year ago
ares-test-init.cc Rewrite sortlist hand parser for memory safety and bugs (#653) 1 year ago
ares-test-internal.cc remove dead code: bitncmp 1 year ago
ares-test-live.cc Windows UBSAN tests (#649) 1 year ago
ares-test-main.cc ares_init_options with ARES_OPT_UDP_PORT wrong byte order 1 year ago
ares-test-misc.cc Support ipv6 link-local servers and %iface syntax (#646) 1 year ago
ares-test-mock-ai.cc now that warnings are enabled on test cases, clear a bunch of warnings 1 year ago
ares-test-mock.cc enhance timeout test case to make sure it will re-use a previously downed server 1 year ago
ares-test-ns.cc provide SPDX identifiers and a REUSE CI job to verify 2 years ago
ares-test-parse-a.cc fix additional windows test warnings 1 year ago
ares-test-parse-aaaa.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse-caa.cc now that warnings are enabled on test cases, clear a bunch of warnings 1 year ago
ares-test-parse-mx.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse-naptr.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse-ns.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse-ptr.cc fix additional windows test warnings 1 year ago
ares-test-parse-soa-any.cc now that warnings are enabled on test cases, clear a bunch of warnings 1 year ago
ares-test-parse-soa.cc now that warnings are enabled on test cases, clear a bunch of warnings 1 year ago
ares-test-parse-srv.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse-txt.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse-uri.cc cleanup some Windows warnings in test 1 year ago
ares-test-parse.cc cleanup some Windows warnings in test 1 year ago
ares-test.cc Clean up some Windows-only warnings (#654) 1 year ago
ares-test.h Support ipv6 link-local servers and %iface syntax (#646) 1 year ago
buildconf provide SPDX identifiers and a REUSE CI job to verify 2 years ago
configure.ac Use external GoogleTest instead of bundling it (#655) 1 year ago
dns-dump.cc now that warnings are enabled on test cases, clear a bunch of warnings 1 year ago
dns-proto-test.cc provide SPDX identifiers and a REUSE CI job to verify 2 years ago
dns-proto.cc fix test case regression due to missing parens 1 year ago
dns-proto.h Reformat code using clang-format (#579) 1 year ago
fuzzcheck.sh provide SPDX identifiers and a REUSE CI job to verify 2 years ago

README.md

c-ares Unit Test Suite

This directory holds unit tests for the c-ares library. To build the tests:

  • Build the main c-ares library first, in the directory above this. To enable tests of internal functions, configure the library build to expose hidden symbols with ./configure --disable-symbol-hiding.
  • Generate a configure file by running autoreconf -iv (which requires a local installation of autotools).
  • ./configure
  • make
  • Run the tests with ./arestest, or ./arestest -v for extra debug info.

Points to note:

  • The tests are written in C++11, and so need a C++ compiler that supports this. To avoid adding this as a requirement for the library, the configuration and build of the tests is independent from the library.
  • The tests include some live queries, which will fail when run on a machine without internet connectivity. To skip live tests, run with ./arestest --gtest_filter=-*.Live*.
  • The tests include queries of a mock DNS server. This server listens on port 5300 by default, but the port can be changed with the -p 5300 option to arestest.

Test Types

The test suite includes various different types of test.

  • There are live tests (ares-test-live.cc), which assume that the current machine has a valid DNS setup and connection to the internet; these tests issue queries for real domains but don't particularly check what gets returned. The tests will fail on an offline machine.
  • There are some mock tests (ares-test-mock.cc) that set up a fake DNS server and inject its port into the c-ares library configuration. These tests allow specific response messages to be crafted and injected, and so are likely to be used for many more tests in future.
    • To make this generation/injection easier, the dns-proto.h file includes C++ helper classes for building DNS packets.
  • Other library entrypoints that don't require network activity (e.g. ares_parse_*_reply) are tested directly.
  • A couple of the tests use a helper method of the test fixture to inject memory allocation failures, using a recent change to the c-ares library that allows override of malloc/free.
  • There are some tests of the internal entrypoints of the library (ares-test-internal.c), but these are only enabled if the library was configured with --disable-symbol-hiding and/or --enable-expose-statics.
  • There is also an entrypoint to allow Clang's libfuzzer to drive the packet parsing code in ares_parse_*_reply, together with a standalone wrapper for it (./aresfuzz) to allow use of command line fuzzers (such as afl-fuzz) for further fuzz testing.

Code Coverage Information

To generate code coverage information:

  • Configure both the library and the tests with ./configure --enable-code-coverage before building. This requires the relevant code coverage tools (gcov, lcov) to be installed locally.
  • Run the tests with test/arestest.
  • Generate code coverage output with make code-coverage-capture in the library directory (i.e. not in test/).

Fuzzing

libFuzzer

To fuzz the packet parsing code with libFuzzer, follow the main libFuzzer instructions:

  • Configure the c-ares library and test suite with a recent Clang and a sanitizer, for example:

    % export CFLAGS="-fsanitize=fuzzer-no-link,address"
    % export CC=clang
    % ./configure --disable-shared && make
    
  • Link each of the fuzzer entrypoints in with ares-fuzz.cc:

    % clang -I.. -c ares-test-fuzz.c
    % clang -I.. -c ares-test-fuzz-name.c
    % clang++ -fsanitize=fuzzer,address ares-test-fuzz.o ../.libs/libcares.a -o ares-libfuzzer
    % clang++ -fsanitize=fuzzer,address ares-test-fuzz-name.o ../.libs/libcares.a -o ares-libfuzzer-name
    
  • Run the fuzzer using the starting corpus with:

    % ./ares-libfuzzer fuzzinput/  # OR
    % ./ares-libfuzzer-name fuzznames/
    

AFL

To fuzz using AFL, follow the AFL quick start guide:

  • Download and build AFL.

  • Configure the c-ares library and test tool to use AFL's compiler wrappers:

    % export CC=$AFLDIR/afl-gcc
    % ./configure --disable-shared && make
    % cd test && ./configure && make aresfuzz aresfuzzname
    
  • Run the AFL fuzzer against the starting corpus:

    % mkdir fuzzoutput
    % $AFLDIR/afl-fuzz -i fuzzinput -o fuzzoutput -- ./aresfuzz  # OR
    % $AFLDIR/afl-fuzz -i fuzznames -o fuzzoutput -- ./aresfuzzname
    

AFL Persistent Mode

If a recent version of Clang is available, AFL can use its built-in compiler instrumentation; this configuration also allows the use of a (much) faster persistent mode, where multiple fuzz inputs are run for each process invocation.

  • Download and build a recent AFL, and run make in the llvm_mode subdirectory to ensure that afl-clang-fast gets built.

  • Configure the c-ares library and test tool to use AFL's clang wrappers that use compiler instrumentation:

    % export CC=$AFLDIR/afl-clang-fast
    % ./configure --disable-shared && make
    % cd test && ./configure && make aresfuzz
    
  • Run the AFL fuzzer (in persistent mode) against the starting corpus:

    % mkdir fuzzoutput
    % $AFLDIR/afl-fuzz -i fuzzinput -o fuzzoutput -- ./aresfuzz