Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src add l2tp(4) basic test.
details: https://anonhg.NetBSD.org/src/rev/929d0ea95b6f
branches: trunk
changeset: 351500:929d0ea95b6f
user: knakahara <knakahara%NetBSD.org@localhost>
date: Thu Feb 16 08:44:47 2017 +0000
description:
add l2tp(4) basic test.
diffstat:
distrib/sets/lists/tests/mi | 6 +-
etc/mtree/NetBSD.dist.tests | 3 +-
tests/net/Makefile | 7 +-
tests/net/if_l2tp/Makefile | 13 +
tests/net/if_l2tp/t_l2tp.sh | 440 ++++++++++++++++++++++++++++++++++++++++++++
5 files changed, 464 insertions(+), 5 deletions(-)
diffs (truncated from 519 to 300 lines):
diff -r abe2b219b653 -r 929d0ea95b6f distrib/sets/lists/tests/mi
--- a/distrib/sets/lists/tests/mi Thu Feb 16 08:39:10 2017 +0000
+++ b/distrib/sets/lists/tests/mi Thu Feb 16 08:44:47 2017 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.720 2017/02/11 18:47:36 nakayama Exp $
+# $NetBSD: mi,v 1.721 2017/02/16 08:44:47 knakahara Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@@ -3252,6 +3252,10 @@
./usr/tests/net/if_gif/Atffile tests-net-tests atf,rump
./usr/tests/net/if_gif/Kyuafile tests-net-tests atf,rump,kyua
./usr/tests/net/if_gif/t_gif tests-net-tests atf,rump
+./usr/tests/net/if_l2tp tests-net-tests compattestfile,atf
+./usr/tests/net/if_l2tp/Atffile tests-net-tests atf,rump
+./usr/tests/net/if_l2tp/Kyuafile tests-net-tests atf,rump,kyua
+./usr/tests/net/if_l2tp/t_l2tp tests-net-tests atf,rump
./usr/tests/net/if_loop tests-net-tests compattestfile,atf
./usr/tests/net/if_loop/Atffile tests-net-tests atf,rump
./usr/tests/net/if_loop/Kyuafile tests-net-tests atf,rump,kyua
diff -r abe2b219b653 -r 929d0ea95b6f etc/mtree/NetBSD.dist.tests
--- a/etc/mtree/NetBSD.dist.tests Thu Feb 16 08:39:10 2017 +0000
+++ b/etc/mtree/NetBSD.dist.tests Thu Feb 16 08:44:47 2017 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: NetBSD.dist.tests,v 1.139 2017/01/02 20:37:12 martin Exp $
+# $NetBSD: NetBSD.dist.tests,v 1.140 2017/02/16 08:44:47 knakahara Exp $
./usr/libdata/debug/usr/tests
./usr/libdata/debug/usr/tests/atf
@@ -339,6 +339,7 @@
./usr/tests/net/if
./usr/tests/net/if_bridge
./usr/tests/net/if_gif
+./usr/tests/net/if_l2tp
./usr/tests/net/if_loop
./usr/tests/net/if_pppoe
./usr/tests/net/if_tap
diff -r abe2b219b653 -r 929d0ea95b6f tests/net/Makefile
--- a/tests/net/Makefile Thu Feb 16 08:39:10 2017 +0000
+++ b/tests/net/Makefile Thu Feb 16 08:44:47 2017 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.30 2016/11/26 03:19:48 ozaki-r Exp $
+# $NetBSD: Makefile,v 1.31 2017/02/16 08:44:47 knakahara Exp $
.include <bsd.own.mk>
@@ -6,8 +6,9 @@
TESTS_SUBDIRS= fdpass in_cksum net sys
.if (${MKRUMP} != "no") && !defined(BSD_MK_COMPAT_FILE)
-TESTS_SUBDIRS+= arp bpf bpfilter carp icmp if if_bridge if_gif if_loop
-TESTS_SUBDIRS+= if_pppoe if_tap if_tun mcast mpls ndp npf route if_vlan
+TESTS_SUBDIRS+= arp bpf bpfilter carp icmp if if_bridge if_gif if_l2tp
+TESTS_SUBDIRS+= if_loop if_pppoe if_tap if_tun mcast mpls ndp npf route
+TESTS_SUBDIRS+= if_vlan
.if (${MKSLJIT} != "no")
TESTS_SUBDIRS+= bpfjit
.endif
diff -r abe2b219b653 -r 929d0ea95b6f tests/net/if_l2tp/Makefile
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/net/if_l2tp/Makefile Thu Feb 16 08:44:47 2017 +0000
@@ -0,0 +1,13 @@
+# $NetBSD: Makefile,v 1.1 2017/02/16 08:44:47 knakahara Exp $
+#
+
+.include <bsd.own.mk>
+
+TESTSDIR= ${TESTSBASE}/net/if_l2tp
+
+.for name in l2tp
+TESTS_SH+= t_${name}
+TESTS_SH_SRC_t_${name}= ../net_common.sh t_${name}.sh
+.endfor
+
+.include <bsd.test.mk>
diff -r abe2b219b653 -r 929d0ea95b6f tests/net/if_l2tp/t_l2tp.sh
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/net/if_l2tp/t_l2tp.sh Thu Feb 16 08:44:47 2017 +0000
@@ -0,0 +1,440 @@
+# $NetBSD: t_l2tp.sh,v 1.1 2017/02/16 08:44:47 knakahara Exp $
+#
+# Copyright (c) 2017 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.
+#
+
+LAC1SOCK=unix://commsock1
+LAC2SOCK=unix://commsock2
+CLIENT1SOCK=unix://commsock3
+CLIENT2SOCK=unix://commsock4
+
+WAN_LINK=bus0
+LAC1_LAN_LINK=bus1
+LAC2_LAN_LINK=bus2
+
+LAC1_WANIP=10.0.0.1
+LAC1_SESSION=1234
+CLIENT1_LANIP=192.168.1.1
+LAC2_WANIP=10.0.0.2
+LAC2_SESSION=4321
+CLIENT2_LANIP=192.168.1.2
+
+LAC1_WANIP6=fc00::1
+CLIENT1_LANIP6=fc00:1::1
+LAC2_WANIP6=fc00::2
+CLIENT2_LANIP6=fc00:1::2
+
+TIMEOUT=5
+DEBUG=${DEBUG:-false}
+
+setup_lac()
+{
+ sock=${1}
+ lanlink=${2}
+ wan=${3}
+ wan_mode=${4}
+
+
+ rump_server_add_iface ${sock} shmif0 ${lanlink}
+ rump_server_add_iface ${sock} shmif1 ${WAN_LINK}
+
+ export RUMP_SERVER=${sock}
+
+ if [ ${wan_mode} = "ipv6" ]; then
+ atf_check -s exit:0 rump.ifconfig shmif1 inet6 ${wan}
+ else
+ atf_check -s exit:0 rump.ifconfig shmif1 inet ${wan} netmask 0xff000000
+ fi
+ atf_check -s exit:0 rump.ifconfig shmif0 up
+ atf_check -s exit:0 rump.ifconfig shmif1 up
+
+ unset RUMP_SERVER
+}
+
+test_lac()
+{
+ sock=${1}
+ wan=${2}
+ wan_mode=${3}
+
+ export RUMP_SERVER=${sock}
+
+ atf_check -s exit:0 -o match:shmif0 rump.ifconfig
+ atf_check -s exit:0 -o match:shmif1 rump.ifconfig
+ if [ ${wan_mode} = "ipv6" ]; then
+ atf_check -s exit:0 -o ignore rump.ping6 -n -c 1 -X $TIMEOUT ${wan}
+ else
+ atf_check -s exit:0 -o ignore rump.ping -n -c 1 -w $TIMEOUT ${wan}
+ fi
+
+ unset RUMP_SERVER
+}
+
+setup_client()
+{
+ sock=${1}
+ lanlink=${2}
+ lan=${3}
+ lan_mode=${4}
+
+ rump_server_add_iface ${sock} shmif0 ${lanlink}
+
+ export RUMP_SERVER=${sock}
+ if [ ${lan_mode} = "ipv6" ]; then
+ atf_check -s exit:0 rump.ifconfig shmif0 inet6 ${lan}
+ else
+ atf_check -s exit:0 rump.ifconfig shmif0 inet ${lan} netmask 0xffffff00
+ fi
+ atf_check -s exit:0 rump.ifconfig shmif0 up
+
+ unset RUMP_SERVER
+}
+
+test_client()
+{
+ sock=${1}
+ lan=${2}
+ lan_mode=${3}
+
+ export RUMP_SERVER=${sock}
+
+ atf_check -s exit:0 -o match:shmif0 rump.ifconfig
+ if [ ${lan_mode} = "ipv6" ]; then
+ atf_check -s exit:0 -o ignore rump.ping6 -n -c 1 -X $TIMEOUT ${lan}
+ else
+ atf_check -s exit:0 -o ignore rump.ping -n -c 1 -w $TIMEOUT ${lan}
+ fi
+
+ unset RUMP_SERVER
+}
+
+setup()
+{
+ lan_mode=${1}
+ wan_mode=${2}
+
+ rump_server_start $LAC1SOCK netinet6 bridge l2tp
+ rump_server_start $LAC2SOCK netinet6 bridge l2tp
+ rump_server_start $CLIENT1SOCK netinet6 bridge l2tp
+ rump_server_start $CLIENT2SOCK netinet6 bridge l2tp
+
+ client1_lan=""
+ client2_lan=""
+ if [ ${lan_mode} = "ipv6" ]; then
+ client1_lan=${CLIENT1_LANIP6}
+ client2_lan=${CLIENT2_LANIP6}
+ else
+ client1_lan=${CLIENT1_LANIP}
+ client2_lan=${CLIENT2_LANIP}
+ fi
+
+ if [ ${wan_mode} = "ipv6" ]; then
+ setup_lac $LAC1SOCK $LAC1_LAN_LINK $LAC1_WANIP6 ${wan_mode}
+ setup_lac $LAC2SOCK $LAC2_LAN_LINK $LAC2_WANIP6 ${wan_mode}
+ setup_client $CLIENT1SOCK $LAC1_LAN_LINK \
+ ${client1_lan} ${lan_mode}
+ setup_client $CLIENT2SOCK $LAC2_LAN_LINK \
+ ${client2_lan} ${lan_mode}
+ else
+ setup_lac $LAC1SOCK $LAC1_LAN_LINK $LAC1_WANIP ${wan_mode}
+ setup_lac $LAC2SOCK $LAC2_LAN_LINK $LAC2_WANIP ${wan_mode}
+ setup_client $CLIENT1SOCK $LAC1_LAN_LINK \
+ ${client1_lan} ${lan_mode}
+ setup_client $CLIENT2SOCK $LAC2_LAN_LINK \
+ ${client2_lan} ${lan_mode}
+ fi
+}
+
+test_setup()
+{
+ lan_mode=${1}
+ wan_mode=${2}
+
+ client1_lan=""
+ client2_lan=""
+ if [ ${lan_mode} = "ipv6" ]; then
+ client1_lan=$CLIENT1_LANIP6
+ client2_lan=$CLIENT2_LANIP6
+ else
+ client1_lan=$CLIENT1_LANIP
+ client2_lan=$CLIENT2_LANIP
+ fi
+ if [ ${wan_mode} = "ipv6" ]; then
+ test_lac ${LAC1SOCK} $LAC1_WANIP6 ${wan_mode}
+ test_lac ${LAC2SOCK} $LAC2_WANIP6 ${wan_mode}
+ test_client ${CLIENT1SOCK} ${client1_lan} ${lan_mode}
+ test_client ${CLIENT2SOCK} ${client2_lan} ${lan_mode}
+ else
+ test_lac ${LAC1SOCK} $LAC1_WANIP ${wan_mode}
+ test_lac ${LAC2SOCK} $LAC2_WANIP ${wan_mode}
+ test_client ${CLIENT1SOCK} ${client1_lan} ${lan_mode}
+ test_client ${CLIENT2SOCK} ${client2_lan} ${lan_mode}
+ fi
+}
+
+setup_if_l2tp()
+{
+ sock=${1}
+ src=${2}
+ dst=${3}
+ src_session=${4}
+ dst_session=${5}
+
+ export RUMP_SERVER=${sock}
+
+ atf_check -s exit:0 rump.ifconfig l2tp0 create
+ atf_check -s exit:0 rump.ifconfig l2tp0 tunnel ${src} ${dst}
+ atf_check -s exit:0 rump.ifconfig l2tp0 session ${src_session} ${dst_session}
+ atf_check -s exit:0 rump.ifconfig l2tp0 up
+
+ atf_check -s exit:0 rump.ifconfig bridge0 create
+ atf_check -s exit:0 rump.ifconfig bridge0 up
+ export LD_PRELOAD=/usr/lib/librumphijack.so
+ atf_check -s exit:0 brconfig bridge0 add shmif0
+ atf_check -s exit:0 brconfig bridge0 add l2tp0
+ unset LD_PRELOAD
+
+ $DEBUG && rump.ifconfig -v l2tp0
+ $DEBUG && rump.ifconfig -v bridge0
+
Home |
Main Index |
Thread Index |
Old Index