Source-Changes-HG archive

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

[src/trunk]: src/tests/net/net add a test for v4 mapped addresses



details:   https://anonhg.NetBSD.org/src/rev/784646233c15
branches:  trunk
changeset: 935605:784646233c15
user:      christos <christos%NetBSD.org@localhost>
date:      Mon Jul 06 18:45:25 2020 +0000

description:
add a test for v4 mapped addresses

diffstat:

 tests/net/net/Makefile   |    5 +-
 tests/net/net/t_mapped.c |  320 +++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 324 insertions(+), 1 deletions(-)

diffs (truncated from 348 to 300 lines):

diff -r c4561acc8526 -r 784646233c15 tests/net/net/Makefile
--- a/tests/net/net/Makefile    Mon Jul 06 18:30:48 2020 +0000
+++ b/tests/net/net/Makefile    Mon Jul 06 18:45:25 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.23 2020/03/01 18:08:16 christos Exp $
+# $NetBSD: Makefile,v 1.24 2020/07/06 18:45:25 christos Exp $
 #
 
 .include <bsd.own.mk>
@@ -6,6 +6,7 @@
 TESTSDIR=      ${TESTSBASE}/net/net
 
 TESTS_C=       t_unix
+TESTS_C+=      t_mapped
 TESTS_C+=      t_tcp
 TESTS_C+=      t_udp
 TESTS_C+=      t_pktinfo
@@ -26,4 +27,6 @@
 LDADD.t_raw+=  -lrumpnet_local -lrumpnet_netinet -lrumpnet_net
 LDADD.t_raw+=  -lrumpnet ${LIBRUMPBASE}
 
+LDADD.t_mapped+=       -lutil
+
 .include <bsd.test.mk>
diff -r c4561acc8526 -r 784646233c15 tests/net/net/t_mapped.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/net/net/t_mapped.c  Mon Jul 06 18:45:25 2020 +0000
@@ -0,0 +1,320 @@
+/*     $NetBSD: t_mapped.c,v 1.1 2020/07/06 18:45:25 christos Exp $    */
+
+/*-
+ * Copyright (c) 2020 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Christos Zoulas.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#define _GNU_SOURCE
+
+#include <sys/cdefs.h>
+#ifdef __RCSID
+__RCSID("$Id: t_mapped.c,v 1.1 2020/07/06 18:45:25 christos Exp $");
+#endif
+
+#include <sys/param.h>
+#include <sys/types.h>
+#include <sys/socket.h>
+#include <sys/wait.h>
+#include <netinet/in.h>
+#include <stdio.h>
+#include <string.h>
+#include <sched.h>
+#include <stdbool.h>
+#include <unistd.h>
+#include <time.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <err.h>
+#include <stdlib.h>
+#include <signal.h>
+#include "util.h"
+
+#include "test.h"
+
+static char mymsg[] = "hi mom!";
+
+static void
+print(const char *msg, const struct sockaddr *addr)
+{
+       char buf[1024];
+
+       sockaddr_snprintf(buf, sizeof(buf), "%a:%p", addr);
+       printf("%s: %s\n", msg, buf);
+}
+
+static int
+mksocket(int sfam)
+{
+       int fd = socket(sfam, SOCK_STREAM, 0);
+       if (fd ==  -1)
+               FAIL("socket");
+       if (sfam != AF_INET6)
+               return fd;
+       int f = 0;
+#if 0
+       /* crashes the kernel, should not be allowed kernel only? */
+       if (setsockopt(fd, IPPROTO_IPV6, 24 /* IPV6_2292RTHDR */,
+           &f, sizeof(f)) == -1)
+               FAIL("setsockopt");
+#endif
+       if (setsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, &f, sizeof(f)) == -1)
+               FAIL("setsockopt");
+       return fd;
+fail:
+       return -1;
+}
+
+static socklen_t
+mkserver(int sfam, struct sockaddr_storage *ss)
+{
+       struct sockaddr_in *sin;
+       struct sockaddr_in6 *sin6;
+
+       memset(ss, 0, sizeof(*ss));
+       ss->ss_family = sfam;
+       switch (sfam) {
+       case AF_INET:
+               sin = (struct sockaddr_in *)ss;
+               sin->sin_port = htons(12345);
+#ifdef BSD4_4
+               sin->sin_len = sizeof(*sin);
+#endif
+               return sizeof(*sin);
+       case AF_INET6:
+               sin6 = (struct sockaddr_in6 *)ss;
+               sin6->sin6_port = htons(12345);
+#ifdef BSD4_4
+               sin6->sin6_len = sizeof(*sin6);
+#endif
+               return sizeof(*sin6);
+       default:
+               FAIL("bad family");
+       }
+fail:
+       return -1;
+}
+
+#if 0
+static const struct in6_addr in6addr_loopback = IN6ADDR_LOOPBACK_INIT;
+#endif
+static socklen_t
+mkclient(int sfam, struct sockaddr_storage *ss)
+{
+       struct sockaddr_in *sin;
+       struct sockaddr_in6 *sin6;
+
+       memset(ss, 0, sizeof(*ss));
+       ss->ss_family = sfam;
+       switch (sfam) {
+       case AF_INET:
+               sin = (struct sockaddr_in *)ss;
+               sin->sin_port = htons(12345);
+#ifdef BSD4_4
+               sin->sin_len = sizeof(*sin);
+#endif
+               sin->sin_addr.s_addr = htonl(INADDR_LOOPBACK);
+               return sizeof(*sin);
+       case AF_INET6:
+               sin6 = (struct sockaddr_in6 *)ss;
+               sin6->sin6_port = htons(12345);
+#ifdef BSD4_4
+               sin6->sin6_len = sizeof(*sin6);
+#endif
+#if 1
+               sin6->sin6_addr = in6addr_loopback;
+#else
+               struct in6_addr *a = &sin6->sin6_addr;
+               a->__u6_addr.__u6_addr32[0] == 0;
+               a->__u6_addr.__u6_addr32[1] == 0;
+               a->__u6_addr.__u6_addr32[2] == ntohl(0x0000ffff);
+               a->__u6_addr.__u6_addr32[3] == ntohl(INADDR_LOOPBACK);
+#endif
+               return sizeof(*sin6);
+       default:
+               FAIL("bad family");
+       }
+fail:
+       return -1;
+}
+
+static int
+test(int forkit, int sfam, int cfam)
+{
+       int sfd = -1, cfd = -1, afd = -1;
+       pid_t sfdpid, cfdpid;
+       struct sockaddr_storage saddr, caddr, paddr;
+       socklen_t slen, clen, plen;
+
+       sfdpid = cfdpid = getpid();
+
+       sfd = mksocket(sfam);
+       slen = mkserver(sfam, &saddr);
+
+       if (bind(sfd, (struct sockaddr *)&saddr, slen) == -1) {
+               FAIL("bind");
+       }
+
+       if (listen(sfd, SOMAXCONN) == -1)
+               FAIL("listen");
+
+       if (forkit) {
+               switch (cfdpid = fork()) {
+               case 0: /* child */
+                       sfdpid = getppid();
+                       cfdpid = getpid();
+                       break;
+               case -1:
+                       FAIL("fork");
+               default:
+                       break;
+               }
+       }
+
+       if (cfdpid == getpid()) {
+               cfd = mksocket(cfam);
+               clen = mkclient(cfam, &caddr);
+
+               if (connect(cfd, (const struct sockaddr *)&caddr, clen) == -1)
+                       FAIL("connect");
+       }
+
+       if (sfdpid == getpid()) {
+               plen = sizeof(paddr);
+               afd = accept(sfd, (struct sockaddr *)&paddr, &plen);
+               if (afd == -1)
+                       FAIL("accept");
+
+               print("peer", (const struct sockaddr *)&paddr);
+       }
+
+       if (cfdpid == getpid()) {
+               if (write(cfd, mymsg, sizeof(mymsg)) != sizeof(mymsg))
+                       FAIL("write");
+               (void)close(cfd);
+       }
+
+       if (sfdpid == getpid()) {
+               char buf[1024];
+               if (read(afd, buf, sizeof(mymsg)) != sizeof(mymsg))
+                       FAIL("write");
+
+               if (strcmp(buf, mymsg) != 0)
+                       FAIL("compare");
+
+               (void)close(afd);
+               (void)close(sfd);
+               if (forkit && waitpid(cfdpid, NULL, 0) == -1)
+                       FAIL("waitpid");
+       }
+       (void)close(cfd);
+
+       return 0;
+fail:
+       if (sfdpid == getpid()) {
+               (void)close(afd);
+               (void)close(sfd);
+       }
+       if (cfdpid == getpid()) {
+               (void)close(cfd);
+       }
+       return -1;
+}
+
+#ifndef TEST
+
+ATF_TC(mapped_4_4);
+ATF_TC_HEAD(mapped_4_4, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Check AF_INET <- AF_INET connections");
+}
+
+ATF_TC_BODY(mapped_4_4, tc)
+{
+       test(0, AF_INET, AF_INET);
+}
+
+ATF_TC(mapped_6_4);
+ATF_TC_HEAD(mapped_6_4, tc)
+{
+
+       atf_tc_set_md_var(tc, "descr", "Check AF_INET6 <- AF_INET connections");
+}
+
+ATF_TC_BODY(mapped_6_4, tc)
+{
+       test(0, AF_INET6, AF_INET);
+}



Home | Main Index | Thread Index | Old Index