summaryrefslogtreecommitdiffstats
path: root/winsup/testsuite/winsup.api/pthread/cancel11.c
diff options
context:
space:
mode:
authorThomas Pfaff <tpfaff@gmx.net>2003-02-04 19:34:21 +0000
committerThomas Pfaff <tpfaff@gmx.net>2003-02-04 19:34:21 +0000
commit53c384f2069e717e72725800fe7da28a5d826f78 (patch)
treea4296707f5e51fac8a167e8155eef61cae116c94 /winsup/testsuite/winsup.api/pthread/cancel11.c
parent3dbafd873eb4fbc587a37c06fa4e101ab4350b8e (diff)
downloadcygnal-53c384f2069e717e72725800fe7da28a5d826f78.tar.gz
cygnal-53c384f2069e717e72725800fe7da28a5d826f78.tar.bz2
cygnal-53c384f2069e717e72725800fe7da28a5d826f78.zip
* winsup.api/pthread/cancel11.c: New test.
* winsup.api/pthread/cancel12.c: Ditto.
Diffstat (limited to 'winsup/testsuite/winsup.api/pthread/cancel11.c')
-rw-r--r--winsup/testsuite/winsup.api/pthread/cancel11.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/winsup/testsuite/winsup.api/pthread/cancel11.c b/winsup/testsuite/winsup.api/pthread/cancel11.c
new file mode 100644
index 000000000..b6554ed69
--- /dev/null
+++ b/winsup/testsuite/winsup.api/pthread/cancel11.c
@@ -0,0 +1,74 @@
+/*
+ * File: cancel11.c
+ *
+ * Test Synopsis: Test if system is a cancellation point.
+ *
+ * Test Method (Validation or Falsification):
+ * -
+ *
+ * Requirements Tested:
+ * -
+ *
+ * Features Tested:
+ * -
+ *
+ * Cases Tested:
+ * -
+ *
+ * Description:
+ * -
+ *
+ * Environment:
+ * -
+ *
+ * Input:
+ * - None.
+ *
+ * Output:
+ * - File name, Line number, and failed expression on failure.
+ * - No output on success.
+ *
+ * Assumptions:
+ * - have working pthread_create, pthread_cancel, pthread_setcancelstate
+ * pthread_join
+ *
+ * Pass Criteria:
+ * - Process returns zero exit status.
+ *
+ * Fail Criteria:
+ * - Process returns non-zero exit status.
+ */
+
+#include "test.h"
+
+static void sig_handler(int sig)
+{
+}
+
+static void *Thread(void *punused)
+{
+ system ("sleep 10");
+
+ return NULL;
+}
+
+int main (void)
+{
+ void * result;
+ pthread_t t;
+
+ signal (SIGINT, sig_handler);
+
+ assert (pthread_create (&t, NULL, Thread, NULL) == 0);
+ sleep (5);
+ assert (pthread_cancel (t) == 0);
+ assert (pthread_join (t, &result) == 0);
+ assert (result == PTHREAD_CANCELED);
+
+ assert ((void *)signal (SIGINT, NULL) == sig_handler);
+
+ /* Wait until child process has terminated */
+ sleep (10);
+
+ return 0;
+}