Module Name:    src
Committed By:   ozaki-r
Date:           Mon Nov  7 00:54:48 UTC 2016

Modified Files:
        src/distrib/sets/lists/tests: mi
        src/tests/net/net: Makefile
Added Files:
        src/tests/net/net: t_mtudisc6.sh

Log Message:
Add basic tests for IPv6 Path MTU Discovery


To generate a diff of this commit:
cvs rdiff -u -r1.694 -r1.695 src/distrib/sets/lists/tests/mi
cvs rdiff -u -r1.17 -r1.18 src/tests/net/net/Makefile
cvs rdiff -u -r0 -r1.1 src/tests/net/net/t_mtudisc6.sh

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/distrib/sets/lists/tests/mi
diff -u src/distrib/sets/lists/tests/mi:1.694 src/distrib/sets/lists/tests/mi:1.695
--- src/distrib/sets/lists/tests/mi:1.694	Sun Nov  6 17:09:19 2016
+++ src/distrib/sets/lists/tests/mi	Mon Nov  7 00:54:48 2016
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.694 2016/11/06 17:09:19 alnsn Exp $
+# $NetBSD: mi,v 1.695 2016/11/07 00:54:48 ozaki-r Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 #
@@ -3249,6 +3249,7 @@
 ./usr/tests/net/net/t_ipv6address		tests-net-tests		atf,rump
 ./usr/tests/net/net/t_ipv6_lifetime		tests-net-tests		atf,rump
 ./usr/tests/net/net/t_mtudisc			tests-net-tests		atf,rump
+./usr/tests/net/net/t_mtudisc6			tests-net-tests		atf,rump
 ./usr/tests/net/net/t_ping6_opts		tests-net-tests		atf,rump
 ./usr/tests/net/net/t_pktinfo			tests-net-tests		compattestfile,atf
 ./usr/tests/net/net/t_raw			tests-net-tests		atf,rump

Index: src/tests/net/net/Makefile
diff -u src/tests/net/net/Makefile:1.17 src/tests/net/net/Makefile:1.18
--- src/tests/net/net/Makefile:1.17	Mon Oct 31 10:38:25 2016
+++ src/tests/net/net/Makefile	Mon Nov  7 00:54:48 2016
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.17 2016/10/31 10:38:25 ozaki-r Exp $
+# $NetBSD: Makefile,v 1.18 2016/11/07 00:54:48 ozaki-r Exp $
 #
 
 .include <bsd.own.mk>
@@ -16,6 +16,7 @@ TESTS_SH+=	t_ipaddress
 TESTS_SH+=	t_ipv6address
 TESTS_SH+=	t_ipv6_lifetime
 TESTS_SH+=	t_mtudisc
+TESTS_SH+=	t_mtudisc6
 TESTS_SH+=	t_ping6_opts
 .endif
 

Added files:

Index: src/tests/net/net/t_mtudisc6.sh
diff -u /dev/null src/tests/net/net/t_mtudisc6.sh:1.1
--- /dev/null	Mon Nov  7 00:54:48 2016
+++ src/tests/net/net/t_mtudisc6.sh	Mon Nov  7 00:54:48 2016
@@ -0,0 +1,232 @@
+#	$NetBSD: t_mtudisc6.sh,v 1.1 2016/11/07 00:54:48 ozaki-r Exp $
+#
+# Copyright (c) 2016 Internet Initiative Japan Inc.
+# All rights reserved.
+#
+# 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.
+#
+
+inetserver="rump_server -lrumpnet -lrumpnet_net -lrumpnet_netinet"
+inetserver="$inetserver -lrumpnet_netinet6 -lrumpnet_shmif"
+inetserver="$inetserver -lrumpdev"
+HIJACKING="env LD_PRELOAD=/usr/lib/librumphijack.so RUMPHIJACK=sysctl=yes"
+
+SOCKLOCAL=unix://commsock1
+SOCKGATEWAY=unix://commsock2
+SOCKREMOTE=unix://commsock3
+HTTPD_PID=httpd.pid
+HTML_FILE=index.html
+
+DEBUG=${DEBUG:-false}
+
+atf_test_case mtudisc6_basic cleanup
+
+mtudisc6_basic_head()
+{
+
+	atf_set "descr" "Tests for IPv6 Path MTU Dicorvery basic behavior"
+	atf_set "require.progs" "rump_server"
+}
+
+setup_server()
+{
+	local sock=$1
+	local if=$2
+	local bus=$3
+	local ip=$4
+
+	export RUMP_SERVER=$sock
+
+	atf_check -s exit:0 rump.ifconfig $if create
+	atf_check -s exit:0 rump.ifconfig $if linkstr $bus
+	atf_check -s exit:0 rump.ifconfig $if inet6 $ip
+	atf_check -s exit:0 rump.ifconfig $if up
+	atf_check -s exit:0 rump.ifconfig -w 10
+
+	$DEBUG && rump.ifconfig $if
+}
+
+extract_new_packets()
+{
+	local bus=$1
+	local old=./old
+
+	if [ ! -f $old ]; then
+		old=/dev/null
+	fi
+
+	shmif_dumpbus -p - $bus 2>/dev/null| \
+	    tcpdump -n -e -r - 2>/dev/null > ./new
+	diff -u $old ./new |grep '^+' |cut -d '+' -f 2 > ./diff
+	mv -f ./new ./old
+	cat ./diff
+}
+
+setup_httpd()
+{
+	local sock=$1
+	local ip=$2
+	local data="0123456789"
+
+	export RUMP_SERVER=$sock
+
+	touch $HTML_FILE
+	for i in `seq 1 512`
+	do
+		echo $data >> $HTML_FILE
+	done
+
+	# start httpd in daemon mode
+	atf_check -s exit:0 env LD_PRELOAD=/usr/lib/librumphijack.so \
+	    /usr/libexec/httpd -P $HTTPD_PID -i $ip -b -s $(pwd)
+
+	$DEBUG && rump.netstat -a
+
+	sleep 5
+}
+
+do_http_get()
+{
+	local ip=$1
+	local ret=$2
+	local timeout=5
+
+	# get the webpage
+	atf_check -s exit:$ret env LD_PRELOAD=/usr/lib/librumphijack.so	\
+	    ftp -q $timeout -o ./out "http://[$ip]/$HTML_FILE";
+}
+
+mtudisc6_basic_body()
+{
+	local pkt=
+	local local_ip=fc00:0:0:1::2
+	local gateway_local_ip=fc00:0:0:1::1
+	local gateway_remote_ip=fc00:0:0:2::1
+	local remote_ip=fc00:0:0:2::2
+	local prefixlen=64
+
+	atf_check -s exit:0 ${inetserver} $SOCKLOCAL
+	atf_check -s exit:0 ${inetserver} $SOCKGATEWAY
+	atf_check -s exit:0 ${inetserver} $SOCKREMOTE
+
+	#
+	# Setup servers
+	#
+	# [local server]       [gateway server]      [remote server]
+	#       |                 |        |                |
+	# shmif0(1500) -- shmif1(1280)  shmif0(1500) -- shmif0(1500)
+	#
+
+	# Assign IP addresses
+	setup_server $SOCKLOCAL shmif0 bus1 $local_ip/$prefixlen
+	setup_server $SOCKGATEWAY shmif0 bus1 $gateway_local_ip/$prefixlen
+	setup_server $SOCKGATEWAY shmif1 bus2 $gateway_remote_ip/$prefixlen
+	setup_server $SOCKREMOTE shmif0 bus2 $remote_ip/$prefixlen
+
+	### Setup gateway server
+	export RUMP_SERVER=$SOCKGATEWAY
+
+	# Set MTU of shmif0 to 1280
+	export RUMP_SERVER=$SOCKGATEWAY
+	atf_check -s exit:0 rump.ifconfig shmif0 mtu 1280
+
+	# Enable IPv6 forwarding
+	atf_check -s exit:0 rump.sysctl -w -q net.inet6.ip6.forwarding=1
+
+	### Setup remote server
+	export RUMP_SERVER=$SOCKREMOTE
+
+	# Start httpd daemon
+	setup_httpd $SOCKREMOTE $remote_ip
+
+	# Teach the peer that local serer is behind gateway server
+	atf_check -s exit:0 -o ignore \
+	    rump.route add -inet6 $local_ip/128 $gateway_remote_ip
+
+	# Check path MTU size on remote server
+	atf_check -s exit:0 \
+	    -o match:"^$local_ip +$gateway_remote_ip +UGHS +- +- +- +shmif0" \
+	    rump.netstat -nr -f inet6
+
+	### Setup local server
+	export RUMP_SERVER=$SOCKLOCAL
+
+	# Teach the peer that remote serer is behind gateway server
+	atf_check -s exit:0 -o ignore \
+	    rump.route add -inet6 $remote_ip/128 $gateway_local_ip
+
+	# Don't accept fragmented packets
+	atf_check -s exit:0 -o ignore \
+	    rump.sysctl -w -q net.inet6.ip6.maxfragpackets=0
+
+	#
+	# Test enabled path MTU discorvery
+	#
+	# Get the webpage (expect: success)
+	export RUMP_SERVER=$SOCKLOCAL
+	do_http_get $remote_ip 0
+	$DEBUG && extract_new_packets bus2 > ./out
+	$DEBUG && cat ./out
+
+	# Check path MTU size on remote server
+	export RUMP_SERVER=$SOCKREMOTE
+	atf_check -s exit:0 \
+	    -o match:"^$local_ip +$gateway_remote_ip +UGHS +- +- +1280 +shmif0" \
+	    rump.netstat -nr -f inet6
+}
+
+dump_server()
+{
+	local sock=$1
+
+	export RUMP_SERVER=$sock
+	rump.netstat -nr -f inet6
+	rump.ndp -n -a
+	rump.ifconfig
+	$HIJACKING dmesg
+}
+
+dump()
+{
+
+	dump_server $SOCKLOCAL
+	dump_server $SOCKGATEWAY
+	dump_server $SOCKREMOTE
+	shmif_dumpbus -p - bus1 2>/dev/null| tcpdump -n -e -r -
+	shmif_dumpbus -p - bus2 2>/dev/null| tcpdump -n -e -r -
+}
+
+mtudisc6_basic_cleanup()
+{
+
+	$DEBUG && dump
+	kill "$(cat ${HTTPD_PID})"
+	env RUMP_SERVER=$SOCKLOCAL rump.halt
+	env RUMP_SERVER=$SOCKGATEWAY rump.halt
+	env RUMP_SERVER=$SOCKREMOTE rump.halt
+}
+
+atf_init_test_cases()
+{
+
+	atf_add_test_case mtudisc6_basic
+}

Reply via email to