diff options
author | pamela <pamela@cvs.openbsd.org> | 2020-04-13 03:09:30 +0000 |
---|---|---|
committer | pamela <pamela@cvs.openbsd.org> | 2020-04-13 03:09:30 +0000 |
commit | 19e7e769562bad68328c2e0ddef2d51a351275c9 (patch) | |
tree | cc4658158978f12864c02ebae35df62eb9a7d0b2 /regress/sys/netinet6 | |
parent | a91d8841fb78aa6b0f306fbe3c57bde8f2337bd0 (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/Makefile | 51 | ||||
-rw-r--r-- | regress/sys/netinet6/srcaddr/localhost.ok | 1 | ||||
-rw-r--r-- | regress/sys/netinet6/srcaddr/srcaddr.c | 90 |
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); +} |