[PATCH v2 wayland] tests: add timeout

Pekka Paalanen ppaalanen at gmail.com
Mon Nov 17 07:02:33 PST 2014


On Wed, 12 Nov 2014 13:16:42 +0100
Marek Chalupa <mchqwerty at gmail.com> wrote:

> 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 at gmail.com>
> ---
>  tests/test-runner.c | 47
> +++++++++++++++++++++++++++++++++++++++++++++++ tests/test-runner.h
> |  7 +++++++ 2 files changed, 54 insertions(+)
> 
> diff --git a/tests/test-runner.c b/tests/test-runner.c
> index 8f3d5d3..3b2e6a9 100644
> --- a/tests/test-runner.c
> +++ b/tests/test-runner.c
> @@ -41,6 +41,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 *
> @@ -107,14 +112,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. " @@ -147,6 +193,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);
> diff --git a/tests/test-runner.h b/tests/test-runner.h
> index 707504c..3295e1c 100644
> --- a/tests/test-runner.h
> +++ b/tests/test-runner.h
> @@ -37,4 +37,11 @@ count_open_fds(void);
>  void
>  exec_fd_leak_check(int nr_expected_fds); /* never returns */
>  
> +/*
> + * set/reset the timeout in seconds. The timeout starts
> + * at the point of invoking this function
> + */
> +void
> +test_set_timeout(unsigned int);
> +
>  #endif

Nice, pushed.

However, would you like to follow up with a patch to fix the NUL byte
printing in test_set_timeout()? ;-)


Thanks,
pq


More information about the wayland-devel mailing list