From: Evan Hunt Date: Wed, 24 Oct 2018 21:23:01 +0000 (-0700) Subject: convert dbdiff_test X-Git-Tag: v9.13.4~21^2~29 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6dfc868fbaf08100a5b853337424b4ed26b2bee6;p=thirdparty%2Fbind9.git convert dbdiff_test --- diff --git a/lib/dns/tests/Kyuafile b/lib/dns/tests/Kyuafile index af92e1db947..1a0597b4c32 100644 --- a/lib/dns/tests/Kyuafile +++ b/lib/dns/tests/Kyuafile @@ -3,7 +3,7 @@ test_suite('bind9') tap_test_program{name='acl_test'} atf_test_program{name='db_test'} -atf_test_program{name='dbdiff_test'} +tap_test_program{name='dbdiff_test'} atf_test_program{name='dbiterator_test'} atf_test_program{name='dbversion_test'} tap_test_program{name='dh_test'} diff --git a/lib/dns/tests/Makefile.in b/lib/dns/tests/Makefile.in index 5fc6763755a..9039220e3d0 100644 --- a/lib/dns/tests/Makefile.in +++ b/lib/dns/tests/Makefile.in @@ -108,9 +108,9 @@ db_test@EXEEXT@: db_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS} ${ISCLIBS} ${LIBS} dbdiff_test@EXEEXT@: dbdiff_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS} - ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \ - dbdiff_test.@O@ dnstest.@O@ ${DNSLIBS} \ - ${ISCLIBS} ${LIBS} + ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${CMOCKA_CFLAGS} \ + ${LDFLAGS} -o $@ dbdiff_test.@O@ dnstest.@O@ \ + ${DNSLIBS} ${ISCLIBS} ${LIBS} ${CMOCKA_LIBS} dbiterator_test@EXEEXT@: dbiterator_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS} ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \ diff --git a/lib/dns/tests/dbdiff_test.c b/lib/dns/tests/dbdiff_test.c index 2ddd24340eb..6b2bc1ab254 100644 --- a/lib/dns/tests/dbdiff_test.c +++ b/lib/dns/tests/dbdiff_test.c @@ -9,15 +9,22 @@ * information regarding copyright ownership. */ - -/*! \file */ - #include -#include +#if HAVE_CMOCKA + +#include +#include +#include -#include #include +#include +#include + +#define UNIT_TESTING +#include + +#include #include #include @@ -26,141 +33,152 @@ #include "dnstest.h" -/* - * Helper functions - */ - #define BUFLEN 255 #define BIGBUFLEN (64 * 1024) #define TEST_ORIGIN "test" -static void -test_create(const atf_tc_t *tc, dns_db_t **old, dns_db_t **newdb) { +static int +_setup(void **state) { isc_result_t result; - result = dns_test_loaddb(old, dns_dbtype_zone, TEST_ORIGIN, - atf_tc_get_md_var(tc, "X-old")); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + UNUSED(state); - result = dns_test_loaddb(newdb, dns_dbtype_zone, TEST_ORIGIN, - atf_tc_get_md_var(tc, "X-new")); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + result = dns_test_begin(NULL, false); + assert_int_equal(result, ISC_R_SUCCESS); + + return (0); } -/* - * Individual unit tests - */ +static int +_teardown(void **state) { + UNUSED(state); + + dns_test_end(); + + return (0); +} + +static void +test_create(const char *oldfile, dns_db_t **old, + const char *newfile, dns_db_t **newdb) +{ + isc_result_t result; -ATF_TC(diffx_same); -ATF_TC_HEAD(diffx_same, tc) { - atf_tc_set_md_var(tc, "descr", "dns_db_diffx of identical content"); - atf_tc_set_md_var(tc, "X-old", "testdata/diff/zone1.data"); - atf_tc_set_md_var(tc, "X-new", "testdata/diff/zone1.data"); } -ATF_TC_BODY(diffx_same, tc) { + result = dns_test_loaddb(old, dns_dbtype_zone, TEST_ORIGIN, oldfile); + assert_int_equal(result, ISC_R_SUCCESS); + + result = dns_test_loaddb(newdb, dns_dbtype_zone, TEST_ORIGIN, newfile); + assert_int_equal(result, ISC_R_SUCCESS); +} + +/* dns_db_diffx of identical content */ +static void +diffx_same(void **state) { dns_db_t *newdb = NULL, *olddb = NULL; isc_result_t result; dns_diff_t diff; - result = dns_test_begin(NULL, false); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + UNUSED(state); - test_create(tc, &olddb, &newdb); + test_create("testdata/diff/zone1.data", &olddb, + "testdata/diff/zone1.data", &newdb); dns_diff_init(mctx, &diff); result = dns_db_diffx(&diff, newdb, NULL, olddb, NULL, NULL); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); - ATF_REQUIRE_EQ(ISC_LIST_EMPTY(diff.tuples), true); + assert_true(ISC_LIST_EMPTY(diff.tuples)); dns_diff_clear(&diff); dns_db_detach(&newdb); dns_db_detach(&olddb); - dns_test_end(); } -ATF_TC(diffx_add); -ATF_TC_HEAD(diffx_add, tc) { - atf_tc_set_md_var(tc, "descr", - "dns_db_diffx of zone with record added"); - atf_tc_set_md_var(tc, "X-old", "testdata/diff/zone1.data"); - atf_tc_set_md_var(tc, "X-new", "testdata/diff/zone2.data"); -} -ATF_TC_BODY(diffx_add, tc) { +/* dns_db_diffx of zone with record added */ +static void +diffx_add(void **state) { dns_db_t *newdb = NULL, *olddb = NULL; dns_difftuple_t *tuple; isc_result_t result; dns_diff_t diff; int count = 0; - result = dns_test_begin(NULL, false); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + UNUSED(state); - test_create(tc, &olddb, &newdb); + test_create("testdata/diff/zone1.data", &olddb, + "testdata/diff/zone2.data", &newdb); dns_diff_init(mctx, &diff); result = dns_db_diffx(&diff, newdb, NULL, olddb, NULL, NULL); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); - ATF_REQUIRE_EQ(ISC_LIST_EMPTY(diff.tuples), false); + assert_false(ISC_LIST_EMPTY(diff.tuples)); for (tuple = ISC_LIST_HEAD(diff.tuples); tuple != NULL; tuple = ISC_LIST_NEXT(tuple, link)) { - ATF_REQUIRE_EQ(tuple->op, DNS_DIFFOP_ADD); + assert_int_equal(tuple->op, DNS_DIFFOP_ADD); count++; } - ATF_REQUIRE_EQ(count, 1); + assert_int_equal(count, 1); dns_diff_clear(&diff); dns_db_detach(&newdb); dns_db_detach(&olddb); - dns_test_end(); } -ATF_TC(diffx_remove); -ATF_TC_HEAD(diffx_remove, tc) { - atf_tc_set_md_var(tc, "descr", - "dns_db_diffx of zone with record removed"); - atf_tc_set_md_var(tc, "X-old", "testdata/diff/zone1.data"); - atf_tc_set_md_var(tc, "X-new", "testdata/diff/zone3.data"); -} -ATF_TC_BODY(diffx_remove, tc) { +/* dns_db_diffx of zone with record removed */ +static void +diffx_remove(void **state) { dns_db_t *newdb = NULL, *olddb = NULL; dns_difftuple_t *tuple; isc_result_t result; dns_diff_t diff; int count = 0; - result = dns_test_begin(NULL, false); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + UNUSED(state); - test_create(tc, &olddb, &newdb); + test_create("testdata/diff/zone1.data", &olddb, + "testdata/diff/zone3.data", &newdb); dns_diff_init(mctx, &diff); result = dns_db_diffx(&diff, newdb, NULL, olddb, NULL, NULL); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); - ATF_REQUIRE_EQ(ISC_LIST_EMPTY(diff.tuples), false); + assert_false(ISC_LIST_EMPTY(diff.tuples)); for (tuple = ISC_LIST_HEAD(diff.tuples); tuple != NULL; tuple = ISC_LIST_NEXT(tuple, link)) { - ATF_REQUIRE_EQ(tuple->op, DNS_DIFFOP_DEL); + assert_int_equal(tuple->op, DNS_DIFFOP_DEL); count++; } - ATF_REQUIRE_EQ(count, 1); + assert_int_equal(count, 1); dns_diff_clear(&diff); dns_db_detach(&newdb); dns_db_detach(&olddb); - dns_test_end(); } -/* - * Main - */ -ATF_TP_ADD_TCS(tp) { - ATF_TP_ADD_TC(tp, diffx_same); - ATF_TP_ADD_TC(tp, diffx_add); - ATF_TP_ADD_TC(tp, diffx_remove); - return (atf_no_error()); +int +main(void) { + const struct CMUnitTest tests[] = { + cmocka_unit_test_setup_teardown(diffx_same, _setup, _teardown), + cmocka_unit_test_setup_teardown(diffx_add, _setup, _teardown), + cmocka_unit_test_setup_teardown(diffx_remove, + _setup, _teardown), + }; + + return (cmocka_run_group_tests(tests, NULL, NULL)); } + +#else /* HAVE_CMOCKA */ + +#include + +int +main(void) { + printf("1..0 # Skipped: cmocka not available\n"); + return (0); +} + +#endif