aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--winsup/testsuite/ChangeLog4
-rw-r--r--winsup/testsuite/winsup.api/checksignal.c79
2 files changed, 83 insertions, 0 deletions
diff --git a/winsup/testsuite/ChangeLog b/winsup/testsuite/ChangeLog
index bba5781..849af81 100644
--- a/winsup/testsuite/ChangeLog
+++ b/winsup/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2001-11-08 Corinna Vinschen <corinna@vinschen.de>
+
+ * checksignal.c: New testcase.
+
2001-11-04 Christopher Faylor <cgf@redhat.com>
* Makefile.in: Oops. Revert previous change. Add Makefile/Makefile.in
diff --git a/winsup/testsuite/winsup.api/checksignal.c b/winsup/testsuite/winsup.api/checksignal.c
new file mode 100644
index 0000000..a8b5d39
--- /dev/null
+++ b/winsup/testsuite/winsup.api/checksignal.c
@@ -0,0 +1,79 @@
+#include <stdio.h>
+#include <errno.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <signal.h>
+
+#include "test.h"
+#include "usctest.h"
+
+char *TCID = "checksignal"; /* Test program identifier. */
+int TST_TOTAL = 3; /* Total number of test cases. */
+extern int Tst_count; /* Test Case counter for tst_* routines */
+
+void
+sig_handler (int signo)
+{
+ errno = EINVAL;
+}
+
+int
+main ()
+{
+ int n, ret;
+ int fds[2];
+ char buf[10];
+ struct sigaction act;
+
+ Tst_count = 0;
+
+ if (pipe (fds) < 0)
+ tst_brk (TBROK, NULL, NULL, "Create pipe");
+
+ /* Reset SA_RESTART flag. */
+ while ((ret = sigaction (SIGALRM, NULL, &act)) == EINTR)
+ ;
+ if (ret)
+ tst_brk (TBROK, NULL, NULL, "Get signal action structure");
+ act.sa_flags &= ~SA_RESTART;
+ while ((ret = sigaction (SIGALRM, &act, NULL)) == EINTR)
+ ;
+ if (ret)
+ tst_brk (TBROK, NULL, NULL, "Reset SA_RESTART");
+
+ /* Set signal handler using signal(2) call... */
+ if (signal (SIGALRM, sig_handler) < 0)
+ tst_brk (TBROK, NULL, NULL, "Call signal() to install signal handler");
+ /* ...and check if signal(2) sets SA_RESTART again. */
+ while ((ret = sigaction (SIGALRM, NULL, &act)) == EINTR)
+ ;
+ if (ret)
+ tst_brk (TBROK, NULL, NULL, "Get signal action structure");
+ tst_resm (act.sa_flags & SA_RESTART ? TPASS : TFAIL,
+ "signal() sets SA_RESTART");
+
+ /* Reset SA_RESTART flag again. */
+ act.sa_handler = sig_handler;
+ act.sa_flags &= ~SA_RESTART;
+ while ((ret = sigaction (SIGALRM, &act, NULL)) == EINTR)
+ ;
+ if (ret)
+ tst_brk (TBROK, NULL, NULL, "Reset SA_RESTART");
+
+ /* Start timer to force a SIGALRM. */
+ alarm (1);
+
+ /* Call read(2) to check if the EINTR errno is correctly preserved,
+ even if the signal handler routine changes errno. */
+ n = read(fds[0], buf, 10);
+ tst_resm (n < 0 && errno == EINTR ? TPASS : TFAIL,
+ "Set EINTR on interrupted read() call");
+
+ /* Check if another errno is correctly returned (here EBADF). */
+ close (fds[0]);
+ n = read(fds[0], buf, 10);
+ tst_resm (n < 0 && errno == EBADF ? TPASS : TFAIL,
+ "Set EBADF on closed file descriptor");
+
+ tst_exit ();
+}