summaryrefslogtreecommitdiff
path: root/regress/sys/netinet6
diff options
context:
space:
mode:
authorpamela <pamela@cvs.openbsd.org>2020-04-13 03:09:30 +0000
committerpamela <pamela@cvs.openbsd.org>2020-04-13 03:09:30 +0000
commit19e7e769562bad68328c2e0ddef2d51a351275c9 (patch)
treecc4658158978f12864c02ebae35df62eb9a7d0b2 /regress/sys/netinet6
parenta91d8841fb78aa6b0f306fbe3c57bde8f2337bd0 (diff)
initial framework for ipv6 source address selection testing
with and OK florian, hints phessler
Diffstat (limited to 'regress/sys/netinet6')
-rw-r--r--regress/sys/netinet6/srcaddr/Makefile51
-rw-r--r--regress/sys/netinet6/srcaddr/localhost.ok1
-rw-r--r--regress/sys/netinet6/srcaddr/srcaddr.c90
3 files changed, 142 insertions, 0 deletions
diff --git a/regress/sys/netinet6/srcaddr/Makefile b/regress/sys/netinet6/srcaddr/Makefile
new file mode 100644
index 00000000000..da60091f529
--- /dev/null
+++ b/regress/sys/netinet6/srcaddr/Makefile
@@ -0,0 +1,51 @@
+# $OpenBSD: Makefile,v 1.1 2020/04/13 03:09:29 pamela Exp $
+
+RTABLE ?= 1
+VETHER ?= vether1
+PROG = srcaddr
+VETHER_LL = ${VETHER}_ll
+REXEC = route -T ${RTABLE} exec
+
+CLEANFILES += ${VETHER_LL}
+
+.if ! (make(clean) || make(cleandir) || make(obj))
+INTERFACES != sh -c "ifconfig ${VETHER} 2>/dev/null" || true
+.endif
+
+.if ! empty(INTERFACES)
+regress:
+ @echo 'vether(4) interfaces already present'
+ @echo SKIPPED
+.endif
+
+REGRESS_SETUP += setup
+setup: cleanup
+ @echo '\n======== $@ ========'
+ ${SUDO} ifconfig ${VETHER} inet6 rdomain ${RTABLE} eui64 up
+ sh -c "ifconfig ${VETHER} | awk '/inet6/ {print \$$2}' > ${VETHER_LL}"
+ ${SUDO} ifconfig lo${RTABLE} inet rdomain ${RTABLE} 127.0.0.1/8 up
+ ${SUDO} ifconfig lo${RTABLE} inet6 rdomain ${RTABLE} eui64
+
+REGRESS_CLEANUP += cleanup
+cleanup:
+ @echo '\n======== $@ ========'
+.for iface in ${VETHER} lo${RTABLE}
+ ${SUDO} ifconfig ${iface} destroy 2>/dev/null || true
+.endfor
+
+REGRESS_TARGETS += localhost
+localhost: srcaddr
+ @echo '\n======== $@ ========'
+ ${REXEC} ${.OBJDIR}/srcaddr ::1 | \
+ diff -up ${.CURDIR}/localhost.ok /dev/stdin
+
+REGRESS_TARGETS += linklocal
+linklocal: srcaddr
+ @echo '\n======== $@ ========'
+ ${REXEC} ${.OBJDIR}/srcaddr fe80::1%${VETHER} | \
+ diff -up ${VETHER_LL} /dev/stdin
+
+.PHONY: ${REGRESS_TARGETS}
+
+.include <bsd.regress.mk>
+
diff --git a/regress/sys/netinet6/srcaddr/localhost.ok b/regress/sys/netinet6/srcaddr/localhost.ok
new file mode 100644
index 00000000000..20e29b14832
--- /dev/null
+++ b/regress/sys/netinet6/srcaddr/localhost.ok
@@ -0,0 +1 @@
+::1
diff --git a/regress/sys/netinet6/srcaddr/srcaddr.c b/regress/sys/netinet6/srcaddr/srcaddr.c
new file mode 100644
index 00000000000..909645ae835
--- /dev/null
+++ b/regress/sys/netinet6/srcaddr/srcaddr.c
@@ -0,0 +1,90 @@
+/* $OpenBSD: srcaddr.c,v 1.1 2020/04/13 03:09:29 pamela Exp $ */
+
+/*
+ * Copyright (c) 2020 Pamela Mosiejczuk <pamela@openbsd.org>
+ * Copyright (c) 2020 Florian Obser <florian@openbsd.org>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <sys/types.h>
+#include <sys/socket.h>
+
+#include <err.h>
+#include <netdb.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+
+__dead void usage(void);
+
+/* given an IPv6 destination address, return the source address selected */
+int
+main(int argc, char *argv[])
+{
+ struct addrinfo hints, *res;
+ struct sockaddr_storage ss;
+ socklen_t len;
+ int ch, error, s;
+ char *target, src[NI_MAXHOST];
+
+ while ((ch = getopt(argc, argv, "")) != -1) {
+ switch (ch) {
+ default:
+ usage();
+ }
+ }
+ argc -= optind;
+ argv += optind;
+
+ if (argc != 1)
+ usage();
+
+ target = *argv;
+
+ memset(&hints, 0, sizeof(hints));
+ hints.ai_flags = AI_NUMERICHOST | AI_NUMERICSERV;
+ hints.ai_family = AF_INET6;
+ hints.ai_socktype = SOCK_DGRAM;
+
+ if ((error = getaddrinfo(target, "8888", &hints, &res)))
+ errx(1, "%s", gai_strerror(error));
+
+ s = socket(res->ai_family, res->ai_socktype, res->ai_protocol);
+ if (s == -1)
+ err(1, "socket");
+
+ if (connect(s, res->ai_addr, res->ai_addrlen) == -1)
+ err(1, "connect");
+ freeaddrinfo(res);
+
+ len = sizeof(ss);
+ if (getsockname(s, (struct sockaddr *)&ss, &len) == -1)
+ err(1, "getsockname");
+
+ if ((error = getnameinfo((struct sockaddr *)&ss, ss.ss_len, src,
+ sizeof(src), NULL, 0, NI_NUMERICHOST | NI_NUMERICSERV)))
+ errx(1, "%s", gai_strerror(error));
+
+ printf("%s\n", src);
+
+ return (0);
+}
+
+__dead void
+usage(void)
+{
+ fprintf(stderr, "usage: srcaddr destination\n");
+ exit (1);
+}