Module Name: src
Committed By: christos
Date: Sat Jan 28 02:47:10 UTC 2012
Modified Files:
src/tests/lib/libc/sys: t_pipe2.c
Log Message:
add a signopipe test
To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/tests/lib/libc/sys/t_pipe2.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/tests/lib/libc/sys/t_pipe2.c
diff -u src/tests/lib/libc/sys/t_pipe2.c:1.2 src/tests/lib/libc/sys/t_pipe2.c:1.3
--- src/tests/lib/libc/sys/t_pipe2.c:1.2 Mon Oct 31 17:30:16 2011
+++ src/tests/lib/libc/sys/t_pipe2.c Fri Jan 27 21:47:09 2012
@@ -1,4 +1,4 @@
-/* $NetBSD: t_pipe2.c,v 1.2 2011/10/31 21:30:16 christos Exp $ */
+/* $NetBSD: t_pipe2.c,v 1.3 2012/01/28 02:47:09 christos Exp $ */
/*-
* Copyright (c) 2011 The NetBSD Foundation, Inc.
@@ -36,7 +36,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: t_pipe2.c,v 1.2 2011/10/31 21:30:16 christos Exp $");
+__RCSID("$NetBSD: t_pipe2.c,v 1.3 2012/01/28 02:47:09 christos Exp $");
#include <atf-c.h>
#include <fcntl.h>
@@ -75,6 +75,14 @@ run(int flags)
ATF_REQUIRE((fcntl(fd[1], F_GETFL) & O_NONBLOCK) == 0);
}
+ if (flags & O_NOSIGPIPE) {
+ ATF_REQUIRE(fcntl(fd[0], F_GETNOSIGPIPE) != 0);
+ ATF_REQUIRE(fcntl(fd[1], F_GETNOSIGPIPE) != 0);
+ } else {
+ ATF_REQUIRE(fcntl(fd[0], F_GETNOSIGPIPE) == 0);
+ ATF_REQUIRE(fcntl(fd[1], F_GETNOSIGPIPE) == 0);
+ }
+
ATF_REQUIRE(close(fd[0]) != -1);
ATF_REQUIRE(close(fd[1]) != -1);
}
@@ -104,7 +112,7 @@ ATF_TC_BODY(pipe2_nonblock, tc)
ATF_TC(pipe2_cloexec);
ATF_TC_HEAD(pipe2_cloexec, tc)
{
- atf_tc_set_md_var(tc, "descr", "A close-on-exec of pipe2(2)");
+ atf_tc_set_md_var(tc, "descr", "A close-on-exec test of pipe2(2)");
}
ATF_TC_BODY(pipe2_cloexec, tc)
@@ -112,6 +120,17 @@ ATF_TC_BODY(pipe2_cloexec, tc)
run(O_CLOEXEC);
}
+ATF_TC(pipe2_nosigpipe);
+ATF_TC_HEAD(pipe2_nosigpipe, tc)
+{
+ atf_tc_set_md_var(tc, "descr", "A no sigpipe test of pipe2(2)");
+}
+
+ATF_TC_BODY(pipe2_nosigpipe, tc)
+{
+ run(O_NOSIGPIPE);
+}
+
ATF_TC(pipe2_einval);
ATF_TC_HEAD(pipe2_einval, tc)
{
@@ -130,6 +149,7 @@ ATF_TP_ADD_TCS(tp)
ATF_TP_ADD_TC(tp, pipe2_basic);
ATF_TP_ADD_TC(tp, pipe2_nonblock);
ATF_TP_ADD_TC(tp, pipe2_cloexec);
+ ATF_TP_ADD_TC(tp, pipe2_nosigpipe);
ATF_TP_ADD_TC(tp, pipe2_einval);
return atf_no_error();