From be57b79d6ccb57286abf64e5a33c5a5b13d5d955 Mon Sep 17 00:00:00 2001 From: Andreas Schneider Date: Fri, 9 May 2008 09:25:50 +0200 Subject: [PATCH] Add test for csync_difftime(). --- tests/CMakeLists.txt | 1 + tests/csync_tests/check_csync_time.c | 61 ++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 tests/csync_tests/check_csync_time.c diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index cb875be60..678788dcb 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -33,6 +33,7 @@ macro_add_check_test(check_csync_lock csync_tests/check_csync_lock.c ${TEST_TARG macro_add_check_test(check_csync_config csync_tests/check_csync_config.c ${TEST_TARGET_LIBRARIES}) macro_add_check_test(check_csync_exclude csync_tests/check_csync_exclude.c ${TEST_TARGET_LIBRARIES}) macro_add_check_test(check_csync_journal csync_tests/check_csync_journal.c ${TEST_TARGET_LIBRARIES}) +macro_add_check_test(check_csync_time csync_tests/check_csync_time.c ${TEST_TARGET_LIBRARIES}) # vio macro_add_check_test(check_vio_handle vio_tests/check_vio_handle.c ${TEST_TARGET_LIBRARIES}) diff --git a/tests/csync_tests/check_csync_time.c b/tests/csync_tests/check_csync_time.c new file mode 100644 index 000000000..75c18b760 --- /dev/null +++ b/tests/csync_tests/check_csync_time.c @@ -0,0 +1,61 @@ +#include "support.h" + +#include "csync_time.h" + +CSYNC *csync; + +static void setup(void) { + fail_if(system("mkdir -p /tmp/check_csync1") < 0, "Setup failed"); + fail_if(system("mkdir -p /tmp/check_csync2") < 0, "Setup failed"); + fail_if(csync_create(&csync, "/tmp/check_csync1", "/tmp/check_csync2") < 0, "Setup failed"); +} + +static void teardown(void) { + fail_if(csync_destroy(csync) < 0, "Teardown failed"); + csync = NULL; + fail_if(system("rm -rf /tmp/check_csync1") < 0, "Teardown failed"); + fail_if(system("rm -rf /tmp/check_csync2") < 0, "Teardown failed"); +} + +START_TEST (check_csync_time) +{ + /* + * The creation should took less than 1 second, so the return + * value should be 0. + */ + fail_unless(csync_timediff(csync) == 0, NULL); +} +END_TEST + + +static Suite *make_csync_suite(void) { + Suite *s = suite_create("csync_time"); + + create_case_fixture(s, "check_csync_time", check_csync_time, setup, teardown); + + return s; +} + +int main(int argc, char **argv) { + Suite *s = NULL; + SRunner *sr = NULL; + struct argument_s arguments; + int nf; + + ZERO_STRUCT(arguments); + + cmdline_parse(argc, argv, &arguments); + + s = make_csync_suite(); + + sr = srunner_create(s); + if (arguments.nofork) { + srunner_set_fork_status(sr, CK_NOFORK); + } + srunner_run_all(sr, CK_VERBOSE); + nf = srunner_ntests_failed(sr); + srunner_free(sr); + + return (nf == 0) ? EXIT_SUCCESS : EXIT_FAILURE; +} +