From: Evan Hunt Date: Wed, 24 Oct 2018 17:06:21 +0000 (-0700) Subject: convert notify_test X-Git-Tag: v9.13.4~21^2~60 X-Git-Url: http://git.ipfire.org/gitweb/?a=commitdiff_plain;h=48dc2831d71c9d1897a702349a6ae2f773d12349;p=thirdparty%2Fbind9.git convert notify_test --- diff --git a/lib/ns/tests/Kyuafile b/lib/ns/tests/Kyuafile index e36015abf6a..cc07b8fde50 100644 --- a/lib/ns/tests/Kyuafile +++ b/lib/ns/tests/Kyuafile @@ -2,5 +2,5 @@ syntax(2) test_suite('bind9') atf_test_program{name='listenlist_test'} -atf_test_program{name='notify_test'} +tap_test_program{name='notify_test'} tap_test_program{name='query_test'} diff --git a/lib/ns/tests/Makefile.in b/lib/ns/tests/Makefile.in index f37fb443626..a814c113847 100644 --- a/lib/ns/tests/Makefile.in +++ b/lib/ns/tests/Makefile.in @@ -50,9 +50,9 @@ listenlist_test@EXEEXT@: listenlist_test.@O@ nstest.@O@ ${NSDEPLIBS} ${ISCDEPLIB ${ISCLIBS} ${LIBS} notify_test@EXEEXT@: notify_test.@O@ nstest.@O@ ${NSDEPLIBS} ${ISCDEPLIBS} ${DNSDEPLIBS} - ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \ - notify_test.@O@ nstest.@O@ ${NSLIBS} ${DNSLIBS} \ - ${ISCLIBS} ${LIBS} + ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${CMOCKA_CFLAGS} \ + ${LDFLAGS} -o $@ notify_test.@O@ nstest.@O@ \ + ${NSLIBS} ${DNSLIBS} ${ISCLIBS} ${LIBS} ${CMOCKA_LIBS} query_test@EXEEXT@: query_test.@O@ nstest.@O@ ${NSDEPLIBS} ${ISCDEPLIBS} ${DNSDEPLIBS} ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${CMOCKA_CFLAGS} \ diff --git a/lib/ns/tests/notify_test.c b/lib/ns/tests/notify_test.c index f420b60ba79..990c3b99efc 100644 --- a/lib/ns/tests/notify_test.c +++ b/lib/ns/tests/notify_test.c @@ -9,18 +9,26 @@ * information regarding copyright ownership. */ -/*! \file */ - #include -#include +#if HAVE_CMOCKA + +#include +#include +#include +#include #include +#include #include +#define UNIT_TESTING +#include + #include #include #include +#include #include #include @@ -31,6 +39,27 @@ #include "nstest.h" +static int +_setup(void **state) { + isc_result_t result; + + UNUSED(state); + + result = ns_test_begin(NULL, true); + assert_int_equal(result, ISC_R_SUCCESS); + + return (0); +} + +static int +_teardown(void **state) { + UNUSED(state); + + ns_test_end(); + + return (0); +} + static void check_response(isc_buffer_t *buf) { isc_result_t result; @@ -39,25 +68,23 @@ check_response(isc_buffer_t *buf) { isc_buffer_t b; result = dns_message_create(mctx, DNS_MESSAGE_INTENTPARSE, &message); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); result = dns_message_parse(message, buf, 0); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); isc_buffer_init(&b, rcodebuf, sizeof(rcodebuf)); result = dns_rcode_totext(message->rcode, &b); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); - ATF_CHECK_EQ(message->rcode, dns_rcode_noerror); + assert_int_equal(message->rcode, dns_rcode_noerror); dns_message_destroy(&message); } -ATF_TC(notify_start); -ATF_TC_HEAD(notify_start, tc) { - atf_tc_set_md_var(tc, "descr", "notify start"); -} -ATF_TC_BODY(notify_start, tc) { +/* test ns_notify_start() */ +static void +notify_start(void **state) { isc_result_t result; ns_client_t *client = NULL; dns_message_t *nmsg = NULL; @@ -65,20 +92,17 @@ ATF_TC_BODY(notify_start, tc) { isc_buffer_t nbuf; size_t nsize; - UNUSED(tc); - - result = ns_test_begin(NULL, true); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + UNUSED(state); result = ns_test_getclient(NULL, false, &client); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); result = ns_test_makeview("view", false, &client->view); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); result = ns_test_serve_zone("example.com", "testdata/notify/zone1.db", client->view); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); /* * Create a NOTIFY message by parsing a file in testdata. @@ -87,15 +111,15 @@ ATF_TC_BODY(notify_start, tc) { result = ns_test_getdata("testdata/notify/notify1.msg", ndata, sizeof(ndata), &nsize); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); isc_buffer_init(&nbuf, ndata, nsize); isc_buffer_add(&nbuf, nsize); result = dns_message_create(mctx, DNS_MESSAGE_INTENTPARSE, &nmsg); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); result = dns_message_parse(nmsg, &nbuf, 0); - ATF_REQUIRE_EQ(result, ISC_R_SUCCESS); + assert_int_equal(result, ISC_R_SUCCESS); /* * Set up client object with this message and test the NOTIFY @@ -115,14 +139,26 @@ ATF_TC_BODY(notify_start, tc) { ns_test_cleanup_zone(); ns_client_detach(&client); +} - ns_test_end(); +int +main(void) { + const struct CMUnitTest tests[] = { + cmocka_unit_test_setup_teardown(notify_start, + _setup, _teardown), + }; + + return (cmocka_run_group_tests(tests, NULL, NULL)); } -/* - * Main - */ -ATF_TP_ADD_TCS(tp) { - ATF_TP_ADD_TC(tp, notify_start); - return (atf_no_error()); +#else /* HAVE_CMOCKA */ + +#include + +int +main(void) { + printf("1..0 # Skipped: cmocka not available\n"); + return (0); } + +#endif