nextcloud-desktop/tests/std_tests/check_std_c_time.c
2012-02-04 13:24:56 +01:00

100 lines
1.9 KiB
C

#include <string.h>
#include <unistd.h>
#include "support.h"
#include "csync_time.h"
#include "std/c_time.h"
START_TEST (check_c_tspecdiff)
{
struct timespec start, finish, diff;
csync_gettime(&start);
csync_gettime(&finish);
diff = c_tspecdiff(finish, start);
fail_unless(diff.tv_sec == 0, NULL);
fail_unless(diff.tv_nsec >= 0, NULL);
}
END_TEST
START_TEST (check_c_tspecdiff_five)
{
struct timespec start, finish, diff;
csync_gettime(&start);
sleep(5);
csync_gettime(&finish);
diff = c_tspecdiff(finish, start);
fail_unless(diff.tv_sec == 5, NULL);
fail_unless(diff.tv_nsec > 0, NULL);
}
END_TEST
START_TEST (check_c_secdiff)
{
struct timespec start, finish;
double diff;
csync_gettime(&start);
csync_gettime(&finish);
diff = c_secdiff(finish, start);
fail_unless(diff >= 0.00 && diff < 1.00, "diff is %.2f", diff);
}
END_TEST
START_TEST (check_c_secdiff_three)
{
struct timespec start, finish;
double diff;
csync_gettime(&start);
sleep(3);
csync_gettime(&finish);
diff = c_secdiff(finish, start);
fail_unless(diff > 3.00 && diff < 4.00, "diff is %.2f", diff);
}
END_TEST
static Suite *make_std_c_suite(void) {
Suite *s = suite_create("std:path:c_basename");
create_case(s, "check_c_tspecdiff", check_c_tspecdiff);
create_case(s, "check_c_tspecdiff_five", check_c_tspecdiff_five);
create_case(s, "check_c_secdiff", check_c_secdiff);
create_case(s, "check_c_secdiff_three", check_c_secdiff_three);
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_std_c_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;
}