Skip to content

Commit

Permalink
2002-09-29 Roland McGrath <roland@redhat.com>
Browse files Browse the repository at this point in the history
	* test-skeleton.c (timeout_handler): Use WUNTRACED flag in waitpid.
	Examine the child's status and print something different if it wasn't
	just killed by our SIGKILL.
	(main): In the child process call setpgid to put it in its own pgrp.
  • Loading branch information
Roland McGrath committed Sep 30, 2002
1 parent d0f82f5 commit b79e373
Showing 1 changed file with 17 additions and 2 deletions.
19 changes: 17 additions & 2 deletions test-skeleton.c
Original file line number Diff line number Diff line change
Expand Up @@ -128,12 +128,13 @@ __attribute__ ((noreturn))
timeout_handler (int sig __attribute__ ((unused)))
{
int killed;
int status;

/* Send signal. */
kill (pid, SIGKILL);

/* Wait for it to terminate. */
killed = waitpid (pid, NULL, WNOHANG);
killed = waitpid (pid, &status, WNOHANG|WUNTRACED);
if (killed != 0 && killed != pid)
{
perror ("Failed to killed test process");
Expand All @@ -144,7 +145,17 @@ timeout_handler (int sig __attribute__ ((unused)))
CLEANUP_HANDLER;
#endif

fputs ("Timed out: killed the child process\n", stderr);
if (WIFSIGNALED (status) && WTERMSIG (status) == SIGKILL)
fputs ("Timed out: killed the child process\n", stderr);
else if (WIFSTOPPED (status))
fprintf (stderr, "Timed out: the child process was %s\n",
strsignal (WSTOPSIG (status)));
else if (WIFSIGNALED (status))
fprintf (stderr, "Timed out: the child process got signal %s\n",
strsignal (WTERMSIG (status)));
else
fprintf (stderr, "Timed out: killed the child process but it exited %d\n",
WEXITSTATUS (status));

/* Exit with an error. */
exit (1);
Expand Down Expand Up @@ -233,6 +244,10 @@ main (int argc, char *argv[])
setrlimit (RLIMIT_CORE, &core_limit);
#endif

/* We put the test process in its own pgrp so that if it bogusly
generates any job control signals, they won't hit the whole build. */
setpgid (0, 0);

/* Execute the test function and exit with the return value. */
exit (TEST_FUNCTION);
}
Expand Down

0 comments on commit b79e373

Please sign in to comment.