summaryrefslogtreecommitdiff
path: root/regress/sys/kern/accept
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>2002-02-11 15:40:32 +0000
committerArtur Grabowski <art@cvs.openbsd.org>2002-02-11 15:40:32 +0000
commitcca9abc62ac63f880d029e335788ed34fbd2093c (patch)
tree9fab1fc03f27af71fb5f99b1165f9a382c9bd523 /regress/sys/kern/accept
parentfc71df2dbf7fb342a08eb9caba5c20fb3d728d39 (diff)
Test some obscrue behavior of accept.
Diffstat (limited to 'regress/sys/kern/accept')
-rw-r--r--regress/sys/kern/accept/Makefile5
-rw-r--r--regress/sys/kern/accept/accept.c107
2 files changed, 112 insertions, 0 deletions
diff --git a/regress/sys/kern/accept/Makefile b/regress/sys/kern/accept/Makefile
new file mode 100644
index 00000000000..58a2d63605e
--- /dev/null
+++ b/regress/sys/kern/accept/Makefile
@@ -0,0 +1,5 @@
+# $OpenBSD: Makefile,v 1.1 2002/02/11 15:40:31 art Exp $
+
+PROG= accept
+
+.include <bsd.regress.mk>
diff --git a/regress/sys/kern/accept/accept.c b/regress/sys/kern/accept/accept.c
new file mode 100644
index 00000000000..2974142733c
--- /dev/null
+++ b/regress/sys/kern/accept/accept.c
@@ -0,0 +1,107 @@
+/* $OpenBSD: accept.c,v 1.1 2002/02/11 15:40:31 art Exp $ */
+/*
+ * Written by Artur Grabowski <art@openbsd.org>, 2002 Public Domain.
+ */
+#include <sys/param.h>
+#include <sys/socket.h>
+#include <sys/time.h>
+#include <sys/wait.h>
+#include <sys/un.h>
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <err.h>
+#include <signal.h>
+#include <string.h>
+
+#define SOCK_NAME "test-sock"
+
+int child(void);
+
+int
+main(argc, argv)
+ int argc;
+ char *argv[];
+{
+ int listensock, sock;
+ struct sockaddr_un sun, csun;
+ int csunlen;
+ int fd, lastfd;
+ int status;
+ int ischild;
+
+ /*
+ * Create the listen socket.
+ */
+ if ((listensock = socket(PF_LOCAL, SOCK_STREAM, 0)) == -1)
+ err(1, "socket");
+
+ unlink(SOCK_NAME);
+ memset(&sun, 0, sizeof(sun));
+ sun.sun_family = AF_LOCAL;
+ strcpy(sun.sun_path, SOCK_NAME);
+ sun.sun_len = SUN_LEN(&sun);
+
+
+ if (bind(listensock, (struct sockaddr *)&sun, sizeof(sun)) == -1)
+ err(1, "bind");
+
+ if (listen(listensock, 1) == -1)
+ err(1, "listen");
+
+ switch (fork()) {
+ case -1:
+ err(1, "fork");
+ case 0:
+ return child();
+ }
+
+ while ((fd = open("/dev/null", O_RDONLY)) >= 0)
+ lastfd = fd;
+
+ switch (fork()) {
+ case -1:
+ err(1, "fork");
+ case 0:
+ ischild = 1;
+ close(lastfd); /* Close one fd so that accept can succeed */
+ sleep(2); /* sleep a bit so that we're the second to accept */
+ }
+
+ sock = accept(listensock, (struct sockaddr *)&csun, &csunlen);
+
+ if (!ischild && sock >= 0)
+ errx(1, "accept succeeded in parent");
+ if (ischild && sock < 0)
+ err(1, "accept failed in child");
+
+ while (!ischild && wait4(-1, &status, 0, NULL) > 0)
+ ;
+
+ return (0);
+}
+
+int
+child()
+{
+ int i, fd, sock;
+ struct sockaddr_un sun;
+
+ /*
+ * Create socket and connect to the receiver.
+ */
+ if ((sock = socket(PF_LOCAL, SOCK_STREAM, 0)) == -1)
+ errx(1, "child socket");
+
+ (void) memset(&sun, 0, sizeof(sun));
+ sun.sun_family = AF_LOCAL;
+ (void) strcpy(sun.sun_path, SOCK_NAME);
+ sun.sun_len = SUN_LEN(&sun);
+
+ if (connect(sock, (struct sockaddr *)&sun, sizeof(sun)) == -1)
+ err(1, "child connect");
+
+ return (0);
+}