[LTP] [PATCH 3/8] syscalls/waitpid: implement waitpid_ret_test()
Stanislav Kholmanskikh
stanislav.kholmanskikh@oracle.com
Wed Aug 10 10:41:01 CEST 2016
Several test cases call waitpid() and then verify the returned
value and errno set. Moved this code into a function.
Signed-off-by: Stanislav Kholmanskikh <stanislav.kholmanskikh@oracle.com>
---
testcases/kernel/syscalls/waitpid/waitpid07.c | 6 +---
testcases/kernel/syscalls/waitpid/waitpid08.c | 24 +---------------
testcases/kernel/syscalls/waitpid/waitpid_common.h | 29 ++++++++++++++++++++
3 files changed, 31 insertions(+), 28 deletions(-)
diff --git a/testcases/kernel/syscalls/waitpid/waitpid07.c b/testcases/kernel/syscalls/waitpid/waitpid07.c
index 74da914..89fcbac 100644
--- a/testcases/kernel/syscalls/waitpid/waitpid07.c
+++ b/testcases/kernel/syscalls/waitpid/waitpid07.c
@@ -48,12 +48,8 @@ static void do_child_1(void)
}
/* Check that waitpid with WNOHANG returns zero */
- pid = waitpid(-1, &status, WNOHANG);
- if (pid != 0) {
- tst_res(TFAIL, "waitpid() returned %d, expected 0",
- pid);
+ if (waitpid_ret_test(-1, &status, WNOHANG, 0, 0))
return;
- }
TST_CHECKPOINT_WAKE2(0, MAXKIDS);
diff --git a/testcases/kernel/syscalls/waitpid/waitpid08.c b/testcases/kernel/syscalls/waitpid/waitpid08.c
index 0f0ee9d..e17663f 100644
--- a/testcases/kernel/syscalls/waitpid/waitpid08.c
+++ b/testcases/kernel/syscalls/waitpid/waitpid08.c
@@ -51,36 +51,14 @@ static void do_child_1(void)
/* Check that waitpid with WNOHANG|WUNTRACED returns
* zero
*/
- pid = waitpid(-1, &status, WNOHANG | WUNTRACED);
- if (pid != 0) {
- tst_res(TFAIL,
- "waitpid(WNOHANG | WUNTRACED) returned %d, expected 0",
- pid);
+ if (waitpid_ret_test(-1, &status, WNOHANG | WUNTRACED, 0, 0))
return;
- }
TST_CHECKPOINT_WAKE2(0, MAXKIDS);
if (reap_children(-1, WUNTRACED, fork_kid_pid, MAXKIDS))
return;
- /*
- * Check that waitpid(WUNTRACED) returns -1 when no
- * stopped children
- */
- pid = waitpid(-1, &status, WUNTRACED);
- if (pid != -1) {
- tst_res(TFAIL, "waitpid(WUNTRACED) returned %d, expected -1",
- pid);
- return;
- }
-
- if (errno != ECHILD) {
- tst_res(TFAIL, "waitpid(WUNTRACED) set errno %s, expected %s",
- tst_strerrno(errno), tst_strerrno(ECHILD));
- return;
- }
-
tst_res(TPASS, "Test PASSED");
}
diff --git a/testcases/kernel/syscalls/waitpid/waitpid_common.h b/testcases/kernel/syscalls/waitpid/waitpid_common.h
index 008577a..df0de9b 100644
--- a/testcases/kernel/syscalls/waitpid/waitpid_common.h
+++ b/testcases/kernel/syscalls/waitpid/waitpid_common.h
@@ -75,6 +75,35 @@ static void do_exit(int stop)
exit(3);
}
+static int waitpid_errno_check(int err, int exp_err)
+{
+ if (err != exp_err) {
+ tst_res(TFAIL, "waitpid() set errno to %s, expected %s",
+ tst_strerrno(err), tst_strerrno(exp_err));
+ return -1;
+ }
+
+ return 0;
+}
+
+int waitpid_ret_test(pid_t wp_pid, int *wp_status, int wp_opts,
+ pid_t wp_ret, int wp_errno)
+{
+ pid_t ret;
+
+ ret = waitpid(wp_pid, wp_status, wp_opts);
+ if (ret != wp_ret) {
+ tst_res(TFAIL, "waitpid() returned %d, expected %d",
+ ret, wp_ret);
+ return -1;
+ }
+
+ if ((ret == -1) && waitpid_errno_check(errno, wp_errno))
+ return -1;
+
+ return 0;
+}
+
static int reap_children(pid_t wp_pid, int wp_opts, pid_t *children, int len)
{
pid_t pid;
--
1.7.1
More information about the ltp
mailing list