Commit ed26a908 by Edward Thomson

clar: cross-platform elapsed time counter

Abstract time counter for tests; use gettimeofday on Unix and
GetTickCount on Windows.
parent 4e15c9c8
...@@ -13,7 +13,6 @@ ...@@ -13,7 +13,6 @@
#include <stdarg.h> #include <stdarg.h>
#include <wchar.h> #include <wchar.h>
#include <time.h> #include <time.h>
#include <sys/time.h>
/* required for sandboxing */ /* required for sandboxing */
#include <sys/types.h> #include <sys/types.h>
...@@ -251,6 +250,37 @@ clar_report_all(void) ...@@ -251,6 +250,37 @@ clar_report_all(void)
} }
} }
#ifdef WIN32
# define clar_time DWORD
static void clar_time_now(clar_time *out)
{
*out = GetTickCount();
}
static double clar_time_diff(clar_time *start, clar_time *end)
{
return ((double)*end - (double)*start) / 1000;
}
#else
# include <sys/time.h>
# define clar_time struct timeval
static void clar_time_now(clar_time *out)
{
struct timezone tz;
gettimeofday(out, &tz);
}
static double clar_time_diff(clar_time *start, clar_time *end)
{
return ((double)end->tv_sec + (double)end->tv_usec / 1.0E6) -
((double)start->tv_sec + (double)start->tv_usec / 1.0E6);
}
#endif
static void static void
clar_run_test( clar_run_test(
const struct clar_suite *suite, const struct clar_suite *suite,
...@@ -258,34 +288,32 @@ clar_run_test( ...@@ -258,34 +288,32 @@ clar_run_test(
const struct clar_func *initialize, const struct clar_func *initialize,
const struct clar_func *cleanup) const struct clar_func *cleanup)
{ {
struct timeval start, end; clar_time start, end;
struct timezone tz;
_clar.trampoline_enabled = 1; _clar.trampoline_enabled = 1;
CL_TRACE(CL_TRACE__TEST__BEGIN); CL_TRACE(CL_TRACE__TEST__BEGIN);
_clar.last_report->start = time(NULL);
clar_time_now(&start);
if (setjmp(_clar.trampoline) == 0) { if (setjmp(_clar.trampoline) == 0) {
if (initialize->ptr != NULL) if (initialize->ptr != NULL)
initialize->ptr(); initialize->ptr();
_clar.last_report->start = time(NULL);
gettimeofday(&start, &tz);
CL_TRACE(CL_TRACE__TEST__RUN_BEGIN); CL_TRACE(CL_TRACE__TEST__RUN_BEGIN);
test->ptr(); test->ptr();
CL_TRACE(CL_TRACE__TEST__RUN_END); CL_TRACE(CL_TRACE__TEST__RUN_END);
} }
gettimeofday(&end, &tz); clar_time_now(&end);
_clar.trampoline_enabled = 0; _clar.trampoline_enabled = 0;
if (_clar.last_report->status == CL_TEST_NOTRUN) if (_clar.last_report->status == CL_TEST_NOTRUN)
_clar.last_report->status = CL_TEST_OK; _clar.last_report->status = CL_TEST_OK;
_clar.last_report->elapsed = ((double)end.tv_sec + (double)end.tv_usec / 1.0E6) - _clar.last_report->elapsed = clar_time_diff(&start, &end);
((double)start.tv_sec + (double)start.tv_usec / 1.0E6);
if (_clar.local_cleanup != NULL) if (_clar.local_cleanup != NULL)
_clar.local_cleanup(_clar.local_cleanup_payload); _clar.local_cleanup(_clar.local_cleanup_payload);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment