diff options
author | Thomas Pfaff <tpfaff@gmx.net> | 2003-02-04 19:34:21 +0000 |
---|---|---|
committer | Thomas Pfaff <tpfaff@gmx.net> | 2003-02-04 19:34:21 +0000 |
commit | 53c384f2069e717e72725800fe7da28a5d826f78 (patch) | |
tree | a4296707f5e51fac8a167e8155eef61cae116c94 /winsup/testsuite | |
parent | 3dbafd873eb4fbc587a37c06fa4e101ab4350b8e (diff) | |
download | newlib-53c384f2069e717e72725800fe7da28a5d826f78.zip newlib-53c384f2069e717e72725800fe7da28a5d826f78.tar.gz newlib-53c384f2069e717e72725800fe7da28a5d826f78.tar.bz2 |
* winsup.api/pthread/cancel11.c: New test.
* winsup.api/pthread/cancel12.c: Ditto.
Diffstat (limited to 'winsup/testsuite')
-rw-r--r-- | winsup/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | winsup/testsuite/winsup.api/pthread/cancel11.c | 74 | ||||
-rw-r--r-- | winsup/testsuite/winsup.api/pthread/cancel12.c | 70 |
3 files changed, 149 insertions, 0 deletions
diff --git a/winsup/testsuite/ChangeLog b/winsup/testsuite/ChangeLog index 83185b6..e3906d2 100644 --- a/winsup/testsuite/ChangeLog +++ b/winsup/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2003-02-04 Thomas Pfaff <tpfaff@gmx.net> + + * winsup.api/pthread/cancel11.c: New test. + * winsup.api/pthread/cancel12.c: Ditto. + 2003-01-23 Christopher Faylor <cgf@redhat.com> * Makefile.in: Don't filter out -g. Actually pass correct CFLAGS to diff --git a/winsup/testsuite/winsup.api/pthread/cancel11.c b/winsup/testsuite/winsup.api/pthread/cancel11.c new file mode 100644 index 0000000..b6554ed --- /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; +} diff --git a/winsup/testsuite/winsup.api/pthread/cancel12.c b/winsup/testsuite/winsup.api/pthread/cancel12.c new file mode 100644 index 0000000..f1c64e3 --- /dev/null +++ b/winsup/testsuite/winsup.api/pthread/cancel12.c @@ -0,0 +1,70 @@ +/* + * File: cancel12.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) +{ + signal (SIGINT, sig_handler); + + system ("sleep 5"); + + assert ((void *)signal (SIGINT, NULL) == sig_handler); + + return NULL; +} + +int main (void) +{ + void *old_sigh; + void * result; + pthread_t t; + + assert (pthread_create (&t, NULL, Thread, NULL) == 0); + assert (pthread_join (t, &result) == 0); + assert (result == NULL); + + return 0; +} |