2
0
mirror of https://gitlab.isc.org/isc-projects/bind9 synced 2025-08-22 18:19:42 +00:00
bind/lib/dns/tests/dbiterator_test.c

393 lines
8.7 KiB
C
Raw Normal View History

/*
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
*
* 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.
*/
2018-10-24 16:04:26 -07:00
#if HAVE_CMOCKA
#include <sched.h> /* IWYU pragma: keep */
#include <setjmp.h>
2018-10-24 16:04:26 -07:00
#include <stdarg.h>
#include <stddef.h>
2011-08-23 03:43:03 +00:00
#include <stdlib.h>
2018-10-24 16:04:26 -07:00
#include <string.h>
#include <unistd.h>
#define UNIT_TESTING
#include <cmocka.h>
#include <isc/util.h>
#include <dns/db.h>
#include <dns/dbiterator.h>
#include <dns/name.h>
#include "dnstest.h"
2020-02-13 14:44:37 -08:00
#define BUFLEN 255
#define BIGBUFLEN (64 * 1024)
#define TEST_ORIGIN "test"
2018-10-24 16:04:26 -07:00
static int
2020-02-13 14:44:37 -08:00
_setup(void **state) {
2018-10-24 16:04:26 -07:00
isc_result_t result;
UNUSED(state);
result = dns_test_begin(NULL, false);
assert_int_equal(result, ISC_R_SUCCESS);
return (0);
}
static int
2020-02-13 14:44:37 -08:00
_teardown(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
dns_test_end();
return (0);
}
static isc_result_t
2020-02-13 14:44:37 -08:00
make_name(const char *src, dns_name_t *name) {
isc_buffer_t b;
isc_buffer_constinit(&b, src, strlen(src));
isc_buffer_add(&b, strlen(src));
return (dns_name_fromtext(name, &b, dns_rootname, 0, NULL));
}
/* create: make sure we can create a dbiterator */
static void
2020-02-13 14:44:37 -08:00
test_create(const char *filename) {
isc_result_t result;
dns_db_t *db = NULL;
dns_dbiterator_t *iter = NULL;
2018-10-24 16:04:26 -07:00
result = dns_test_loaddb(&db, dns_dbtype_cache, TEST_ORIGIN, filename);
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_db_createiterator(db, 0, &iter);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
dns_dbiterator_destroy(&iter);
dns_db_detach(&db);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
create(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
2018-10-24 16:04:26 -07:00
test_create("testdata/dbiterator/zone1.data");
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
create_nsec3(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
test_create("testdata/dbiterator/zone2.data");
}
/* walk: walk a database */
static void
2020-02-13 14:44:37 -08:00
test_walk(const char *filename, int nodes) {
isc_result_t result;
dns_db_t *db = NULL;
dns_dbiterator_t *iter = NULL;
2020-02-13 14:44:37 -08:00
dns_dbnode_t *node = NULL;
dns_name_t *name;
dns_fixedname_t f;
int i = 0;
name = dns_fixedname_initname(&f);
2018-10-24 16:04:26 -07:00
result = dns_test_loaddb(&db, dns_dbtype_cache, TEST_ORIGIN, filename);
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_db_createiterator(db, 0, &iter);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
for (result = dns_dbiterator_first(iter); result == ISC_R_SUCCESS;
2020-02-13 14:44:37 -08:00
result = dns_dbiterator_next(iter))
{
result = dns_dbiterator_current(iter, &node, name);
if (result == DNS_R_NEWORIGIN) {
result = ISC_R_SUCCESS;
}
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
dns_db_detachnode(db, &node);
i++;
}
2018-10-24 16:04:26 -07:00
assert_int_equal(i, nodes);
dns_dbiterator_destroy(&iter);
dns_db_detach(&db);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
walk(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
2018-10-24 16:04:26 -07:00
test_walk("testdata/dbiterator/zone1.data", 12);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
walk_nsec3(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
test_walk("testdata/dbiterator/zone2.data", 33);
}
/* reverse: walk database backwards */
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
test_reverse(const char *filename) {
isc_result_t result;
dns_db_t *db = NULL;
dns_dbiterator_t *iter = NULL;
2020-02-13 14:44:37 -08:00
dns_dbnode_t *node = NULL;
dns_name_t *name;
dns_fixedname_t f;
int i = 0;
name = dns_fixedname_initname(&f);
2018-10-24 16:04:26 -07:00
result = dns_test_loaddb(&db, dns_dbtype_cache, TEST_ORIGIN, filename);
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_db_createiterator(db, 0, &iter);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
for (result = dns_dbiterator_last(iter); result == ISC_R_SUCCESS;
2020-02-13 14:44:37 -08:00
result = dns_dbiterator_prev(iter))
{
result = dns_dbiterator_current(iter, &node, name);
if (result == DNS_R_NEWORIGIN) {
result = ISC_R_SUCCESS;
}
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
dns_db_detachnode(db, &node);
i++;
}
2018-10-24 16:04:26 -07:00
assert_int_equal(i, 12);
dns_dbiterator_destroy(&iter);
dns_db_detach(&db);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
reverse(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
2018-10-24 16:04:26 -07:00
test_reverse("testdata/dbiterator/zone1.data");
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
reverse_nsec3(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
test_reverse("testdata/dbiterator/zone2.data");
}
/* seek: walk database starting at a particular node */
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
test_seek_node(const char *filename, int nodes) {
isc_result_t result;
dns_db_t *db = NULL;
dns_dbiterator_t *iter = NULL;
2020-02-13 14:44:37 -08:00
dns_dbnode_t *node = NULL;
dns_name_t *name, *seekname;
dns_fixedname_t f1, f2;
int i = 0;
name = dns_fixedname_initname(&f1);
seekname = dns_fixedname_initname(&f2);
2018-10-24 16:04:26 -07:00
result = dns_test_loaddb(&db, dns_dbtype_cache, TEST_ORIGIN, filename);
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_db_createiterator(db, 0, &iter);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
result = make_name("c." TEST_ORIGIN, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_dbiterator_seek(iter, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
while (result == ISC_R_SUCCESS) {
result = dns_dbiterator_current(iter, &node, name);
if (result == DNS_R_NEWORIGIN) {
result = ISC_R_SUCCESS;
}
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
dns_db_detachnode(db, &node);
result = dns_dbiterator_next(iter);
i++;
}
2018-10-24 16:04:26 -07:00
assert_int_equal(i, nodes);
dns_dbiterator_destroy(&iter);
dns_db_detach(&db);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
seek_node(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
2018-10-24 16:04:26 -07:00
test_seek_node("testdata/dbiterator/zone1.data", 9);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
seek_node_nsec3(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
test_seek_node("testdata/dbiterator/zone2.data", 30);
}
/*
* seek_emty: walk database starting at an empty nonterminal node
* (should fail)
*/
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
test_seek_empty(const char *filename) {
isc_result_t result;
dns_db_t *db = NULL;
dns_dbiterator_t *iter = NULL;
2020-02-13 14:44:37 -08:00
dns_name_t *seekname;
dns_fixedname_t f1;
seekname = dns_fixedname_initname(&f1);
2018-10-24 16:04:26 -07:00
result = dns_test_loaddb(&db, dns_dbtype_cache, TEST_ORIGIN, filename);
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_db_createiterator(db, 0, &iter);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
result = make_name("d." TEST_ORIGIN, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_dbiterator_seek(iter, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, DNS_R_PARTIALMATCH);
dns_dbiterator_destroy(&iter);
dns_db_detach(&db);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
seek_empty(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
2018-10-24 16:04:26 -07:00
test_seek_empty("testdata/dbiterator/zone1.data");
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
seek_empty_nsec3(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
test_seek_empty("testdata/dbiterator/zone2.data");
}
/*
2018-10-24 16:04:26 -07:00
* seek_nx: walk database starting at a nonexistent node
*/
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
test_seek_nx(const char *filename) {
isc_result_t result;
dns_db_t *db = NULL;
dns_dbiterator_t *iter = NULL;
2020-02-13 14:44:37 -08:00
dns_name_t *seekname;
dns_fixedname_t f1;
seekname = dns_fixedname_initname(&f1);
2018-10-24 16:04:26 -07:00
result = dns_test_loaddb(&db, dns_dbtype_cache, TEST_ORIGIN, filename);
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_db_createiterator(db, 0, &iter);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
result = make_name("nonexistent." TEST_ORIGIN, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
result = dns_dbiterator_seek(iter, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, DNS_R_PARTIALMATCH);
result = make_name("nonexistent.", seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_SUCCESS);
2011-08-23 23:54:00 +00:00
result = dns_dbiterator_seek(iter, seekname);
2018-10-24 16:04:26 -07:00
assert_int_equal(result, ISC_R_NOTFOUND);
dns_dbiterator_destroy(&iter);
dns_db_detach(&db);
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
seek_nx(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
2018-10-24 16:04:26 -07:00
test_seek_nx("testdata/dbiterator/zone1.data");
}
2018-10-24 16:04:26 -07:00
static void
2020-02-13 14:44:37 -08:00
seek_nx_nsec3(void **state) {
2018-10-24 16:04:26 -07:00
UNUSED(state);
test_seek_nx("testdata/dbiterator/zone2.data");
}
/*
* XXX:
* dns_dbiterator API calls that are not yet part of this unit test:
*
* dns_dbiterator_pause
* dns_dbiterator_origin
* dns_dbiterator_setcleanmode
*/
2018-10-24 16:04:26 -07:00
int
2020-02-13 14:44:37 -08:00
main(void) {
2018-10-24 16:04:26 -07:00
const struct CMUnitTest tests[] = {
cmocka_unit_test_setup_teardown(create, _setup, _teardown),
cmocka_unit_test_setup_teardown(create_nsec3, _setup,
_teardown),
2018-10-24 16:04:26 -07:00
cmocka_unit_test_setup_teardown(walk, _setup, _teardown),
cmocka_unit_test_setup_teardown(walk_nsec3, _setup, _teardown),
cmocka_unit_test_setup_teardown(reverse, _setup, _teardown),
cmocka_unit_test_setup_teardown(reverse_nsec3, _setup,
_teardown),
2018-10-24 16:04:26 -07:00
cmocka_unit_test_setup_teardown(seek_node, _setup, _teardown),
cmocka_unit_test_setup_teardown(seek_node_nsec3, _setup,
_teardown),
2018-10-24 16:04:26 -07:00
cmocka_unit_test_setup_teardown(seek_empty, _setup, _teardown),
cmocka_unit_test_setup_teardown(seek_empty_nsec3, _setup,
_teardown),
2018-10-24 16:04:26 -07:00
cmocka_unit_test_setup_teardown(seek_nx, _setup, _teardown),
cmocka_unit_test_setup_teardown(seek_nx_nsec3, _setup,
_teardown),
2018-10-24 16:04:26 -07:00
};
return (cmocka_run_group_tests(tests, NULL, NULL));
}
#else /* HAVE_CMOCKA */
#include <stdio.h>
int
2020-02-13 14:44:37 -08:00
main(void) {
2018-10-24 16:04:26 -07:00
printf("1..0 # Skipped: cmocka not available\n");
return (SKIPPED_TEST_EXIT_CODE);
2018-10-24 16:04:26 -07:00
}
#endif /* if HAVE_CMOCKA */