aboutsummaryrefslogtreecommitdiffstats
path: root/tests/test-runner.c
diff options
context:
space:
mode:
authorMarek Chalupa <mchqwerty@gmail.com>2014-11-12 13:16:42 +0100
committerPekka Paalanen <pekka.paalanen@collabora.co.uk>2014-11-17 16:45:49 +0200
commit7bf8049c484959f7ccc3262724466172dce786b6 (patch)
tree35f6498842cb8f7d346d0978c5049a64d3b480f4 /tests/test-runner.c
parentconnection: abort if a listener function is NULL (diff)
downloadwayland-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.c47
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);