diff options
| author | Marek Chalupa <mchqwerty@gmail.com> | 2014-11-12 13:16:42 +0100 |
|---|---|---|
| committer | Pekka Paalanen <pekka.paalanen@collabora.co.uk> | 2014-11-17 16:45:49 +0200 |
| commit | 7bf8049c484959f7ccc3262724466172dce786b6 (patch) | |
| tree | 35f6498842cb8f7d346d0978c5049a64d3b480f4 /tests/test-runner.c | |
| parent | connection: abort if a listener function is NULL (diff) | |
| download | wayland-7bf8049c484959f7ccc3262724466172dce786b6.tar wayland-7bf8049c484959f7ccc3262724466172dce786b6.tar.gz wayland-7bf8049c484959f7ccc3262724466172dce786b6.tar.bz2 wayland-7bf8049c484959f7ccc3262724466172dce786b6.tar.lz wayland-7bf8049c484959f7ccc3262724466172dce786b6.tar.xz wayland-7bf8049c484959f7ccc3262724466172dce786b6.tar.zst wayland-7bf8049c484959f7ccc3262724466172dce786b6.zip | |
tests: add timeout
Add test_set_timeout() function that allows the test to
set timeout for its completition. Any other call to the function
re-sets the timeout to the new value. The timeouts can be turned off
(usefull when debugging) by setting evironment variable
WAYLAND_TESTS_NO_TIMEOUTS.
v2:
rename NO_TIMEOUTS to WAYLAND_TESTS_NO_TIMEOUTS
use unsigned int as argument of test_set_timeout()
improve printing of the message about timeout
Signed-off-by: Marek Chalupa <mchqwerty@gmail.com>
Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
Diffstat (limited to 'tests/test-runner.c')
| -rw-r--r-- | tests/test-runner.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/test-runner.c b/tests/test-runner.c index af80d2b..09c50e2 100644 --- a/tests/test-runner.c +++ b/tests/test-runner.c @@ -44,6 +44,11 @@ static void* (*sys_calloc)(size_t, size_t); int leak_check_enabled; +/* when this var is set to 0, every call to test_set_timeout() is + * suppressed - handy when debugging the test. Can be set by + * WAYLAND_TESTS_NO_TIMEOUTS evnironment var */ +static int timeouts_enabled = 1; + extern const struct test __start_test_section, __stop_test_section; __attribute__ ((visibility("default"))) void * @@ -110,14 +115,55 @@ usage(const char *name, int status) exit(status); } +void +test_set_timeout(unsigned int to) +{ + int re; + + if (!timeouts_enabled) { + fprintf(stderr, "Timeouts suppressed.\n"); + return; + } + + re = alarm(to); + fprintf(stderr, "Timeout was %sset", re ? "re-" : ""); + + if (to != 0) + fprintf(stderr, " to %d second%c from now.\n", + to, to > 1 ? 's' : 0); + else + fprintf(stderr, " off.\n"); +} + +static void +sigalrm_handler(int signum) +{ + fprintf(stderr, "Test timed out.\n"); + abort(); +} + static void run_test(const struct test *t) { int cur_alloc = num_alloc; int cur_fds, num_fds; + struct sigaction sa; cur_fds = count_open_fds(); + + if (timeouts_enabled) { + sa.sa_handler = sigalrm_handler; + sa.sa_flags = 0; + sigemptyset(&sa.sa_mask); + assert(sigaction(SIGALRM, &sa, NULL) == 0); + } + t->run(); + + /* turn off timeout (if any) after test completition */ + if (timeouts_enabled) + alarm(0); + if (leak_check_enabled) { if (cur_alloc != num_alloc) { fprintf(stderr, "Memory leak detected in test. " @@ -189,6 +235,7 @@ int main(int argc, char *argv[]) sys_free = dlsym(RTLD_NEXT, "free"); leak_check_enabled = !getenv("NO_ASSERT_LEAK_CHECK"); + timeouts_enabled = !getenv("WAYLAND_TESTS_NO_TIMEOUTS"); if (argc == 2 && strcmp(argv[1], "--help") == 0) usage(argv[0], EXIT_SUCCESS); |
