mirror of
https://github.com/isc-projects/bind9.git
synced 2026-03-15 23:22:35 -04:00
If the machine running the job is extra loaded (or extra slow), the print test in the badcache unit test would fail because the TTL would be 59 (possibly even lower) and the test expects the badcache.out to only have TTL 60. Refactor the test to check for the expected strings and check whether the TTL is in the expected range.
358 lines
11 KiB
C
358 lines
11 KiB
C
/*
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
|
*
|
|
* SPDX-License-Identifier: MPL-2.0
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
|
*
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
* information regarding copyright ownership.
|
|
*/
|
|
|
|
#include <inttypes.h>
|
|
#include <sched.h> /* IWYU pragma: keep */
|
|
#include <setjmp.h>
|
|
#include <stdarg.h>
|
|
#include <stdbool.h>
|
|
#include <stddef.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <unistd.h>
|
|
|
|
#define UNIT_TESTING
|
|
#include <cmocka.h>
|
|
|
|
#include <isc/buffer.h>
|
|
#include <isc/commandline.h>
|
|
#include <isc/md.h>
|
|
#include <isc/mem.h>
|
|
#include <isc/os.h>
|
|
#include <isc/thread.h>
|
|
#include <isc/urcu.h>
|
|
#include <isc/util.h>
|
|
#include <isc/uv.h>
|
|
|
|
#include <dns/badcache.h>
|
|
#include <dns/compress.h>
|
|
#include <dns/fixedname.h>
|
|
#include <dns/name.h>
|
|
#include <dns/rdatatype.h>
|
|
|
|
#include <tests/dns.h>
|
|
|
|
#define BADCACHE_TEST_FLAG 1 << 3
|
|
|
|
ISC_LOOP_TEST_IMPL(basic) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_result_t result;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
|
|
flags = 0;
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
flags = 0;
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_a, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
assert_int_equal(flags, 0);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_LOOP_TEST_IMPL(expire) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_result_t result;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
dns_badcache_add(bc, name, dns_rdatatype_a, false, flags, now + 60);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now + 61);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_a, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
dns_badcache_add(bc, name, dns_rdatatype_a, true, flags, now + 120);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_a, &flags, now + 61);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_LOOP_TEST_IMPL(print) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_stdtime_t expire = now + 60;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
FILE *file = NULL;
|
|
char buf[4096];
|
|
size_t len;
|
|
char *pos;
|
|
char *endptr;
|
|
const char *part1 = ";\n; badcache\n;\n; example.com/A [ttl ";
|
|
const char *part2 = "]\n; example.com/AAAA [ttl ";
|
|
const char *part3 = "]\n";
|
|
long ttl;
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
dns_badcache_add(bc, name, dns_rdatatype_a, false, flags, expire);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, expire);
|
|
|
|
file = fopen("./badcache.out", "w");
|
|
dns_badcache_print(bc, "badcache", file);
|
|
fclose(file);
|
|
|
|
file = fopen("./badcache.out", "r");
|
|
len = fread(buf, sizeof(buf[0]), ARRAY_SIZE(buf), file);
|
|
assert_int_equal(len, 68);
|
|
fclose(file);
|
|
|
|
pos = buf;
|
|
assert_memory_equal(pos, part1, strlen(part1));
|
|
pos += strlen(part1);
|
|
|
|
ttl = strtol(pos, &endptr, 0);
|
|
assert_ptr_not_equal(pos, endptr);
|
|
assert_true(ttl >= 0 && ttl <= 60);
|
|
pos = endptr;
|
|
|
|
assert_memory_equal(pos, part2, strlen(part2));
|
|
pos += strlen(part2);
|
|
|
|
ttl = strtol(pos, &endptr, 0);
|
|
assert_ptr_not_equal(pos, endptr);
|
|
assert_true(ttl >= 0 && ttl <= 60);
|
|
pos = endptr;
|
|
|
|
assert_memory_equal(pos, part3, strlen(part3));
|
|
pos += strlen(part3);
|
|
|
|
assert_int_equal(pos - buf, len);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_LOOP_TEST_IMPL(flush) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_result_t result;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_badcache_flush(bc);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_LOOP_TEST_IMPL(flushname) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_result_t result;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_name_fromstring(name, "sub.sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_flushname(bc, name);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_a, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_name_fromstring(name, "sub.sub.example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_LOOP_TEST_IMPL(flushtree) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_result_t result;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
dns_name_fromstring(name, "sub.sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now + 60);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_flushtree(bc, name);
|
|
|
|
dns_name_fromstring(name, "sub.sub.example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags, now);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
assert_int_equal(flags, BADCACHE_TEST_FLAG);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_LOOP_TEST_IMPL(purge) {
|
|
dns_badcache_t *bc = NULL;
|
|
dns_fixedname_t fname = { 0 };
|
|
dns_name_t *name = dns_fixedname_initname(&fname);
|
|
isc_stdtime_t now = isc_stdtime_now();
|
|
isc_result_t result;
|
|
uint32_t flags = BADCACHE_TEST_FLAG;
|
|
|
|
bc = dns_badcache_new(mctx);
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now - 60);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now - 60);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
dns_name_fromstring(name, "sub.sub.example.com.", NULL, 0, NULL);
|
|
dns_badcache_add(bc, name, dns_rdatatype_aaaa, false, flags, now);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now - 60);
|
|
assert_int_equal(result, ISC_R_SUCCESS);
|
|
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now + 30);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_name_fromstring(name, "sub.sub.example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now + 30);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_name_fromstring(name, "sub.example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now + 30);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_name_fromstring(name, "example.com.", NULL, 0, NULL);
|
|
result = dns_badcache_find(bc, name, dns_rdatatype_aaaa, &flags,
|
|
now + 30);
|
|
assert_int_equal(result, ISC_R_NOTFOUND);
|
|
|
|
dns_badcache_destroy(&bc);
|
|
|
|
isc_loopmgr_shutdown(loopmgr);
|
|
}
|
|
|
|
ISC_TEST_LIST_START
|
|
ISC_TEST_ENTRY_CUSTOM(basic, setup_managers, teardown_managers)
|
|
ISC_TEST_ENTRY_CUSTOM(expire, setup_managers, teardown_managers)
|
|
ISC_TEST_ENTRY_CUSTOM(print, setup_managers, teardown_managers)
|
|
ISC_TEST_ENTRY_CUSTOM(flush, setup_managers, teardown_managers)
|
|
ISC_TEST_ENTRY_CUSTOM(flushname, setup_managers, teardown_managers)
|
|
ISC_TEST_ENTRY_CUSTOM(flushtree, setup_managers, teardown_managers)
|
|
ISC_TEST_ENTRY_CUSTOM(purge, setup_managers, teardown_managers)
|
|
ISC_TEST_LIST_END
|
|
|
|
ISC_TEST_MAIN
|