Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/bsd/blacklist/test more bugs



details:   https://anonhg.NetBSD.org/src/rev/23e1f602a497
branches:  trunk
changeset: 805864:23e1f602a497
user:      christos <christos%NetBSD.org@localhost>
date:      Thu Jan 22 05:03:52 2015 +0000

description:
more bugs

diffstat:

 external/bsd/blacklist/test/Makefile  |   4 +++-
 external/bsd/blacklist/test/cltest.c  |  15 +++++++++++----
 external/bsd/blacklist/test/srvtest.c |  23 ++++++++++++++---------
 3 files changed, 28 insertions(+), 14 deletions(-)

diffs (143 lines):

diff -r 2bdadf9db4c5 -r 23e1f602a497 external/bsd/blacklist/test/Makefile
--- a/external/bsd/blacklist/test/Makefile      Thu Jan 22 04:20:50 2015 +0000
+++ b/external/bsd/blacklist/test/Makefile      Thu Jan 22 05:03:52 2015 +0000
@@ -1,9 +1,11 @@
-# $NetBSD: Makefile,v 1.1 2015/01/21 16:16:00 christos Exp $
+# $NetBSD: Makefile,v 1.2 2015/01/22 05:03:52 christos Exp $
 
 MKMAN=no
 
 PROGS=srvtest cltest 
 SRCS.srvtest = srvtest.c
 SRCS.cltest = cltest.c
+LDADD+=-lutil
+DPADD+=${LIBUTIL}
 
 .include <bsd.prog.mk>
diff -r 2bdadf9db4c5 -r 23e1f602a497 external/bsd/blacklist/test/cltest.c
--- a/external/bsd/blacklist/test/cltest.c      Thu Jan 22 04:20:50 2015 +0000
+++ b/external/bsd/blacklist/test/cltest.c      Thu Jan 22 05:03:52 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cltest.c,v 1.4 2015/01/22 03:48:07 christos Exp $      */
+/*     $NetBSD: cltest.c,v 1.5 2015/01/22 05:03:52 christos Exp $      */
 
 /*-
  * Copyright (c) 2015 The NetBSD Foundation, Inc.
@@ -33,7 +33,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: cltest.c,v 1.4 2015/01/22 03:48:07 christos Exp $");
+__RCSID("$NetBSD: cltest.c,v 1.5 2015/01/22 05:03:52 christos Exp $");
 
 #include <sys/types.h> 
 #include <sys/socket.h>
@@ -45,6 +45,9 @@
 #include <unistd.h>
 #include <stdlib.h>
 #include <err.h>
+#ifdef HAVE_UTIL_H
+#include <util.h>
+#endif
 
 static __dead void
 usage(int c)
@@ -78,7 +81,7 @@
                s->sin_port = p;
        }
 #ifdef HAVE_STRUCT_SOCKADDR_SA_LEN
-       ss->ss_len = *slen;
+       ss->ss_len = (uint8_t)*slen;
 #endif
        if (c == -1)
                err(EXIT_FAILURE, "Invalid address `%s'", a);
@@ -95,8 +98,9 @@
        int type = SOCK_STREAM;
        in_port_t port = 6161;
        socklen_t slen;
+       char buf[128];
 
-       while ((c = getopt(argc, argv, "a:m:p:u")) == -1) {
+       while ((c = getopt(argc, argv, "a:m:p:u")) != -1) {
                switch (c) {
                case 'a':
                        addr = optarg;
@@ -120,11 +124,14 @@
        if ((sfd = socket(AF_INET, type, 0)) == -1)
                err(EXIT_FAILURE, "socket");
 
+       sockaddr_snprintf(buf, sizeof(buf), "%a:%p", (const void *)&ss);
+       printf("connecting to: %s\n", buf);
        if (connect(sfd, (const void *)&ss, slen) == -1)
                err(EXIT_FAILURE, "connect");
 
        size_t len = strlen(msg) + 1;
        if (write(sfd, msg, len) != (ssize_t)len)
                err(EXIT_FAILURE, "write");
+       sleep(10);
        return 0;
 }
diff -r 2bdadf9db4c5 -r 23e1f602a497 external/bsd/blacklist/test/srvtest.c
--- a/external/bsd/blacklist/test/srvtest.c     Thu Jan 22 04:20:50 2015 +0000
+++ b/external/bsd/blacklist/test/srvtest.c     Thu Jan 22 05:03:52 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: srvtest.c,v 1.7 2015/01/22 04:13:04 christos Exp $     */
+/*     $NetBSD: srvtest.c,v 1.8 2015/01/22 05:03:52 christos Exp $     */
 
 /*-
  * Copyright (c) 2015 The NetBSD Foundation, Inc.
@@ -33,7 +33,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: srvtest.c,v 1.7 2015/01/22 04:13:04 christos Exp $");
+__RCSID("$NetBSD: srvtest.c,v 1.8 2015/01/22 05:03:52 christos Exp $");
 
 #include <sys/types.h> 
 #include <sys/socket.h>
@@ -94,25 +94,30 @@
                s6->sin6_port = p;
        }
 #ifdef HAVE_STRUCT_SOCKADDR_SA_LEN
-       ss.ss_len = slen;
+       ss.ss_len = (uint8_t)slen;
 #endif
      
        if (bind(sfd, (const void *)&ss, slen) == -1)
                err(1, "bind");
 
-       if (listen(sfd, 5) == -1)
-               err(1, "listen");
+       if (type != SOCK_DGRAM)
+               if (listen(sfd, 5) == -1)
+                       err(1, "listen");
        return sfd;
 }
 
 static void
-handle(int sfd)
+handle(int type, int sfd)
 {
        struct sockaddr_storage ss;
        socklen_t alen = sizeof(ss);
        int afd;
-       if ((afd = accept(sfd, (void *)&ss, &alen)) == -1)
-               err(1, "accept");
+
+       if (type != SOCK_DGRAM) {
+               if ((afd = accept(sfd, (void *)&ss, &alen)) == -1)
+                       err(1, "accept");
+       } else
+               afd = sfd;
 
        /* Create child process */
        switch (fork()) {
@@ -174,7 +179,7 @@
                for (size_t i = 0; i < __arraycount(pfd); i++) {
                        if ((pfd[i].revents & POLLIN) == 0)
                                continue;
-                       handle(pfd[i].fd);
+                       handle(type, pfd[i].fd);
                }
        }
 }



Home | Main Index | Thread Index | Old Index