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

index 5a871c9d832b20e477d0b69ba402bc647de9b439..84f772e19bf65a2ac53a8db8507c66e27cfa3aaf 100644 (file)
@@ -5,7 +5,7 @@ tap_test_program{name='aes_test'}
 tap_test_program{name='buffer_test'}
 tap_test_program{name='counter_test'}
 tap_test_program{name='errno_test'}
-atf_test_program{name='file_test'}
+tap_test_program{name='file_test'}
 atf_test_program{name='hash_test'}
 tap_test_program{name='heap_test'}
 tap_test_program{name='hmac_test'}
index fb082e690b80f58c6dfb6dc83c3db20514f1142f..4b2f1a024b3dc94de715b5faa981435d2f97a98b 100644 (file)
@@ -78,8 +78,9 @@ errno_test@EXEEXT@: errno_test.@O@ ${ISCDEPLIBS}
                ${ISCLIBS} ${LIBS} ${CMOCKA_LIBS}
 
 file_test@EXEEXT@: file_test.@O@ ${ISCDEPLIBS}
-       ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \
-                       file_test.@O@ ${ISCLIBS} ${LIBS}
+       ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${CMOCKA_CFLAGS} \
+               ${LDFLAGS} -o $@ file_test.@O@ \
+               ${ISCLIBS} ${LIBS} ${CMOCKA_LIBS}
 
 hash_test@EXEEXT@: hash_test.@O@ ${ISCDEPLIBS}
        ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \
index 3dadb52c5a24ee81b15a92880966b3c292e08eea..86bc1ea7746a25d82c5b3926a86006df56c2649b 100644 (file)
 
 #include <config.h>
 
+#if HAVE_CMOCKA
+
+#include <stdarg.h>
+#include <stddef.h>
+#include <setjmp.h>
+
 #include <fcntl.h>
 #include <stdlib.h>
 #include <string.h>
 #include <unistd.h>
 
-#include <atf-c.h>
+#define UNIT_TESTING
+#include <cmocka.h>
 
 #include <isc/file.h>
 #include <isc/result.h>
-
-ATF_TC(isc_file_sanitize);
-ATF_TC_HEAD(isc_file_sanitize, tc) {
-       atf_tc_set_md_var(tc, "descr", "sanitized filenames");
-}
+#include <isc/util.h>
 
 #define NAME "internal"
 #define SHA "3bed2cb3a3acf7b6a8ef408420cc682d5520e26976d354254f528c965612054f"
@@ -44,93 +47,109 @@ touch(const char *filename) {
 
        unlink(filename);
        fd = creat(filename, 0644);
-       if (fd != -1)
+       if (fd != -1) {
                close(fd);
+       }
 }
 
-ATF_TC_BODY(isc_file_sanitize, tc) {
+/* test sanitized filenames */
+static void
+isc_file_sanitize_test(void **state) {
        isc_result_t result;
        char buf[1024];
 
-       ATF_CHECK(chdir(TESTS) != -1);
+       UNUSED(state);
+
+       assert_return_code(chdir(TESTS), 0);
 
        result = isc_file_sanitize("testdata/file", NAME, "test", buf, 1024);
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK(strcmp(buf, F(NAME)) == 0);
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_int_equal(strcmp(buf, F(NAME)), 0);
 
        touch(F(TRUNC_SHA));
        result = isc_file_sanitize("testdata/file", NAME, "test", buf, 1024);
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK(strcmp(buf, F(TRUNC_SHA)) == 0);
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_int_equal(strcmp(buf, F(TRUNC_SHA)), 0);
 
        touch(F(SHA));
        result = isc_file_sanitize("testdata/file", NAME, "test", buf, 1024);
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK(strcmp(buf, F(SHA)) == 0);
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_int_equal(strcmp(buf, F(SHA)), 0);
 
        result = isc_file_sanitize("testdata/file", BAD1, "test", buf, 1024);
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK(strcmp(buf, F(BADHASH1)) == 0);
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_int_equal(strcmp(buf, F(BADHASH1)), 0);
 
        result = isc_file_sanitize("testdata/file", BAD2, "test", buf, 1024);
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK(strcmp(buf, F(BADHASH2)) == 0);
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_int_equal(strcmp(buf, F(BADHASH2)), 0);
 
        unlink(F(TRUNC_SHA));
        unlink(F(SHA));
 }
 
-ATF_TC(isc_file_template);
-ATF_TC_HEAD(isc_file_template, tc) {
-       atf_tc_set_md_var(tc, "descr", "file template");
-}
-
-ATF_TC_BODY(isc_file_template, tc) {
+/* test filename templates */
+static void
+isc_file_template_test(void **state) {
        isc_result_t result;
        char buf[1024];
 
-       ATF_CHECK(chdir(TESTS) != -1);
+       UNUSED(state);
+
+       assert_return_code(chdir(TESTS), 0);
 
        result = isc_file_template("/absolute/path", "file-XXXXXXXX",
                                   buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "/absolute/file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "/absolute/file-XXXXXXXX");
 
        result = isc_file_template("relative/path", "file-XXXXXXXX",
                                   buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "relative/file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "relative/file-XXXXXXXX");
 
        result = isc_file_template("/trailing/slash/", "file-XXXXXXXX",
                                   buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "/trailing/slash/file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "/trailing/slash/file-XXXXXXXX");
 
        result = isc_file_template("relative/trailing/slash/", "file-XXXXXXXX",
                                   buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "relative/trailing/slash/file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "relative/trailing/slash/file-XXXXXXXX");
 
        result = isc_file_template("/", "file-XXXXXXXX", buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "/file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "/file-XXXXXXXX");
 
        result = isc_file_template("noslash", "file-XXXXXXXX",
                                   buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "file-XXXXXXXX");
 
        result = isc_file_template(NULL, "file-XXXXXXXX", buf, sizeof(buf));
-       ATF_CHECK_EQ(result, ISC_R_SUCCESS);
-       ATF_CHECK_STREQ(buf, "file-XXXXXXXX");
+       assert_int_equal(result, ISC_R_SUCCESS);
+       assert_string_equal(buf, "file-XXXXXXXX");
 }
 
-/*
- * Main
- */
-ATF_TP_ADD_TCS(tp) {
-       ATF_TP_ADD_TC(tp, isc_file_sanitize);
-       ATF_TP_ADD_TC(tp, isc_file_template);
-       return (atf_no_error());
+int
+main(void) {
+       const struct CMUnitTest tests[] = {
+               cmocka_unit_test(isc_file_sanitize_test),
+               cmocka_unit_test(isc_file_template_test),
+       };
+
+       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