]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
convert dbdiff_test
authorEvan Hunt <each@isc.org>
Wed, 24 Oct 2018 21:23:01 +0000 (14:23 -0700)
committerEvan Hunt <each@isc.org>
Thu, 15 Nov 2018 04:17:04 +0000 (20:17 -0800)
lib/dns/tests/Kyuafile
lib/dns/tests/Makefile.in
lib/dns/tests/dbdiff_test.c

index af92e1db9476d70900fbfcf83021811eecf8aac2..1a0597b4c32ac2d96bd9b3519f32dbf0c2a7cc6f 100644 (file)
@@ -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'}
index 5fc6763755abc6c0fcfc70ebe97ce81892a7e80a..9039220e3d076e22b48e0e5f098e71ad313f15b5 100644 (file)
@@ -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 $@ \
index 2ddd24340eb44253f436d91723bb83b8b28fb9fd..6b2bc1ab25422aa8b305e4ef3fb71dce32a0eba4 100644 (file)
@@ -9,15 +9,22 @@
  * information regarding copyright ownership.
  */
 
-
-/*! \file */
-
 #include <config.h>
 
-#include <atf-c.h>
+#if HAVE_CMOCKA
+
+#include <stdarg.h>
+#include <stddef.h>
+#include <setjmp.h>
 
-#include <unistd.h>
 #include <stdlib.h>
+#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 "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 <stdio.h>
+
+int
+main(void) {
+       printf("1..0 # Skipped: cmocka not available\n");
+       return (0);
+}
+
+#endif