Module Name: src
Committed By: martin
Date: Wed Nov 22 16:45:35 UTC 2017
Modified Files:
src/tests/net/if_vlan [netbsd-8]: t_vlan.sh
Log Message:
Pull up following revision(s) (requested by msaitoh in ticket #380):
tests/net/if_vlan/t_vlan.sh: revision 1.2
tests/net/if_vlan/t_vlan.sh: revision 1.3
tests/net/if_vlan/t_vlan.sh: revision 1.4
tests/net/if_vlan/t_vlan.sh: revision 1.5
Add test cases for vlan(4)
From s-yamaguchi@IIJ
Add counter check to vlan(4) ATF. Implemented by s-yamaguchi@IIJ, thanks.
Add a test case for duplicated VLAN ID.
Add test case of vlan(4)'s re-configure without destroy
(see also if_vlan.c rev. 1.104). Written by s-yamaguchi@iij.
To generate a diff of this commit:
cvs rdiff -u -r1.1 -r1.1.8.1 src/tests/net/if_vlan/t_vlan.sh
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/tests/net/if_vlan/t_vlan.sh
diff -u src/tests/net/if_vlan/t_vlan.sh:1.1 src/tests/net/if_vlan/t_vlan.sh:1.1.8.1
--- src/tests/net/if_vlan/t_vlan.sh:1.1 Sat Nov 26 03:19:49 2016
+++ src/tests/net/if_vlan/t_vlan.sh Wed Nov 22 16:45:35 2017
@@ -1,4 +1,4 @@
-# $NetBSD: t_vlan.sh,v 1.1 2016/11/26 03:19:49 ozaki-r Exp $
+# $NetBSD: t_vlan.sh,v 1.1.8.1 2017/11/22 16:45:35 martin Exp $
#
# Copyright (c) 2016 Internet Initiative Japan Inc.
# All rights reserved.
@@ -28,11 +28,56 @@
BUS=bus
SOCK_LOCAL=unix://commsock1
SOCK_REMOTE=unix://commsock2
-IP_LOCAL=10.0.0.1
-IP_REMOTE=10.0.0.2
+IP_LOCAL0=10.0.0.1
+IP_LOCAL1=10.0.1.1
+IP_REMOTE0=10.0.0.2
+IP_REMOTE1=10.0.1.2
+IP6_LOCAL0=fc00:0::1
+IP6_LOCAL1=fc00:1::1
+IP6_REMOTE0=fc00:0::2
+IP6_REMOTE1=fc00:1::2
DEBUG=${DEBUG:-false}
+vlan_create_destroy_body_common()
+{
+ export RUMP_SERVER=${SOCK_LOCAL}
+
+ atf_check -s exit:0 rump.ifconfig vlan0 create
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+ atf_check -s exit:0 rump.ifconfig vlan0 down
+ atf_check -s exit:0 rump.ifconfig vlan0 destroy
+
+ atf_check -s exit:0 rump.ifconfig shmif0 create
+ atf_check -s exit:0 rump.ifconfig vlan0 create
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 1 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+ atf_check -s exit:0 rump.ifconfig vlan0 destroy
+
+ # more than one vlan interface with a same parent interface
+ atf_check -s exit:0 rump.ifconfig shmif1 create
+ atf_check -s exit:0 rump.ifconfig vlan0 create
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan1 create
+ atf_check -s exit:0 rump.ifconfig vlan1 vlan 11 vlanif shmif0
+
+ # more than one interface with another parent interface
+ atf_check -s exit:0 rump.ifconfig vlan2 create
+ atf_check -s exit:0 rump.ifconfig vlan2 vlan 12 vlanif shmif1
+ atf_check -s exit:0 rump.ifconfig vlan3 create
+ atf_check -s exit:0 rump.ifconfig vlan3 vlan 13 vlanif shmif1
+ atf_check -s exit:0 rump.ifconfig shmif0 destroy
+ atf_check -s exit:0 -o not-match:'shmif0' rump.ifconfig vlan0
+ atf_check -s exit:0 -o not-match:'shmif0' rump.ifconfig vlan1
+ atf_check -s exit:0 -o match:'shmif1' rump.ifconfig vlan2
+ atf_check -s exit:0 -o match:'shmif1' rump.ifconfig vlan3
+ atf_check -s exit:0 rump.ifconfig vlan0 destroy
+ atf_check -s exit:0 rump.ifconfig vlan1 destroy
+ atf_check -s exit:0 rump.ifconfig vlan2 destroy
+ atf_check -s exit:0 rump.ifconfig vlan3 destroy
+
+}
+
atf_test_case vlan_create_destroy cleanup
vlan_create_destroy_head()
{
@@ -43,17 +88,12 @@ vlan_create_destroy_head()
vlan_create_destroy_body()
{
-
rump_server_start $SOCK_LOCAL vlan
- export RUMP_SERVER=${SOCK_LOCAL}
-
- atf_check -s exit:0 rump.ifconfig vlan0 create
- atf_check -s exit:0 rump.ifconfig vlan0 up
- atf_check -s exit:0 rump.ifconfig vlan0 down
- atf_check -s exit:0 rump.ifconfig vlan0 destroy
+ vlan_create_destroy_body_common
}
+
vlan_create_destroy_cleanup()
{
@@ -61,20 +101,47 @@ vlan_create_destroy_cleanup()
cleanup
}
-atf_test_case vlan_basic cleanup
-vlan_basic_head()
+atf_test_case vlan_create_destroy6 cleanup
+vlan_create_destroy6_head()
{
- atf_set "descr" "tests of communications over vlan interfaces"
+ atf_set "descr" "tests of creation and deletion of vlan interface with IPv6"
atf_set "require.progs" "rump_server"
}
-vlan_basic_body()
+vlan_create_destroy6_body()
{
- rump_server_start $SOCK_LOCAL vlan
+ rump_server_start $SOCK_LOCAL vlan netinet6
+
+ vlan_create_destroy_body_common
+}
+
+vlan_create_destroy6_cleanup()
+{
+
+ $DEBUG && dump
+ cleanup
+}
+
+vlan_basic_body_common()
+{
+ local outfile=./out
+ local af=inet
+ local prefix=24
+ local local0=$IP_LOCAL0
+ local remote0=$IP_REMOTE0
+ local ping_cmd="rump.ping -n -w 1 -c 1"
+
+ if [ x"$1" = x"inet6" ]; then
+ af="inet6"
+ prefix=64
+ local0=$IP6_LOCAL0
+ remote0=$IP6_REMOTE0
+ ping_cmd="rump.ping6 -n -c 1"
+ fi
+
rump_server_add_iface $SOCK_LOCAL shmif0 $BUS
- rump_server_start $SOCK_REMOTE vlan
rump_server_add_iface $SOCK_REMOTE shmif0 $BUS
export RUMP_SERVER=$SOCK_LOCAL
@@ -85,19 +152,67 @@ vlan_basic_body()
export RUMP_SERVER=$SOCK_LOCAL
atf_check -s exit:0 rump.ifconfig vlan0 create
atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
- atf_check -s exit:0 rump.ifconfig vlan0 $IP_LOCAL/24
+ atf_check -s exit:0 rump.ifconfig vlan0 $af $local0/$prefix
atf_check -s exit:0 rump.ifconfig vlan0 up
atf_check -s exit:0 rump.ifconfig -w 10
export RUMP_SERVER=$SOCK_REMOTE
atf_check -s exit:0 rump.ifconfig vlan0 create
atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
- atf_check -s exit:0 rump.ifconfig vlan0 $IP_REMOTE/24
+ atf_check -s exit:0 rump.ifconfig vlan0 $af $remote0/$prefix
atf_check -s exit:0 rump.ifconfig vlan0 up
atf_check -s exit:0 rump.ifconfig -w 10
+ extract_new_packets $BUS > $outfile
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 -o ignore $ping_cmd $remote0
+
+ extract_new_packets $BUS > $outfile
+ atf_check -s exit:0 -o match:'vlan 10' cat $outfile
+
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 20 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 $af $local0/$prefix
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+ atf_check -s exit:0 rump.ifconfig -w 10
+
+ extract_new_packets $BUS > $outfile
+ atf_check -s not-exit:0 -o ignore $ping_cmd $remote0
+
+ extract_new_packets $BUS > $outfile
+ atf_check -s exit:0 -o match:'vlan 20' cat $outfile
+
export RUMP_SERVER=$SOCK_LOCAL
- atf_check -s exit:0 -o ignore rump.ping -n -w 1 -c 1 $IP_REMOTE
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 $af $local0/$prefix
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+ atf_check -s exit:0 rump.ifconfig -w 10
+
+ atf_check -s exit:0 -o ignore rump.ifconfig -z vlan0
+ atf_check -s exit:0 -o ignore $ping_cmd $remote0
+ rump.ifconfig -v vlan0 > $outfile
+
+ atf_check -s exit:0 -o not-match:' 0 packets' cat $outfile
+ atf_check -s exit:0 -o not-match:' 0 bytes' cat $outfile
+}
+
+atf_test_case vlan_basic cleanup
+vlan_basic_head()
+{
+
+ atf_set "descr" "tests of communications over vlan interfaces"
+ atf_set "require.progs" "rump_server"
+}
+
+vlan_basic_body()
+{
+ rump_server_start $SOCK_LOCAL vlan
+ rump_server_start $SOCK_REMOTE vlan
+
+ vlan_basic_body_common inet
+
}
vlan_basic_cleanup()
@@ -107,9 +222,302 @@ vlan_basic_cleanup()
cleanup
}
+atf_test_case vlan_basic6 cleanup
+vlan_basic6_head()
+{
+
+ atf_set "descr" "tests of communications over vlan interfaces using IPv6"
+ atf_set "require.progs" "rump_server"
+}
+
+vlan_basic6_body()
+{
+ rump_server_start $SOCK_LOCAL vlan netinet6
+ rump_server_start $SOCK_REMOTE vlan netinet6
+
+ vlan_basic_body_common inet6
+}
+
+vlan_basic6_cleanup()
+{
+
+ $DEBUG && dump
+ cleanup
+}
+
+vlanid_config_and_ping()
+{
+ local vlanid=$1
+ shift
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan $vlanid vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 $IP_LOCAL0/24
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+
+ export RUMP_SERVER=$SOCK_REMOTE
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan $vlanid vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 $IP_REMOTE0/24
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 -o ignore rump.ping -n -w 1 -c 1 $IP_REMOTE0
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+
+ export RUMP_SERVER=$SOCK_REMOTE
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+}
+
+vlanid_config_and_ping6()
+{
+ local vlanid=$1
+ shift
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan $vlanid vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 inet6 $IP6_LOCAL0/64
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+
+ export RUMP_SERVER=$SOCK_REMOTE
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan $vlanid vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 inet6 $IP6_REMOTE0/64
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 -o ignore rump.ping6 -n -c 1 $IP6_REMOTE0
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+
+ export RUMP_SERVER=$SOCK_REMOTE
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+}
+
+vlan_vlanid_body_common()
+{
+ local af=inet
+ local prefix=24
+ local sysctl_param="net.inet.ip.dad_count=0"
+ local ping_cmd="rump.ping -n -w 1 -c 1"
+ local config_and_ping=vlanid_config_and_ping
+ local local0=$IP_LOCAL0
+ local local1=$IP_LOCAL1
+ local remote0=$IP_REMOTE0
+ local remote1=$IP_REMOTE1
+
+ if [ x"$1" = x"inet6" ]; then
+ af=inet6
+ prefix=64
+ sysctl_param="net.inet6.ip6.dad_count=0"
+ ping_cmd="rump.ping6 -n -c 1"
+ config_and_ping=vlanid_config_and_ping6
+ local0=$IP6_LOCAL0
+ local1=$IP6_LOCAL1
+ remote0=$IP6_REMOTE0
+ remote1=$IP6_REMOTE1
+ fi
+
+ rump_server_add_iface $SOCK_LOCAL shmif0 $BUS
+ rump_server_add_iface $SOCK_REMOTE shmif0 $BUS
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 -o ignore rump.sysctl -w $sysctl_param
+ atf_check -s exit:0 rump.ifconfig shmif0 up
+ atf_check -s exit:0 rump.ifconfig vlan0 create
+
+ export RUMP_SERVER=$SOCK_REMOTE
+ atf_check -s exit:0 -o ignore rump.sysctl -w $sysctl_param
+ atf_check -s exit:0 rump.ifconfig shmif0 up
+ atf_check -s exit:0 rump.ifconfig vlan0 create
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s not-exit:0 -e ignore\
+ rump.ifconfig vlan0 vlan -1 vlanif shmif0
+
+ $config_and_ping 0 # reserved vlan id
+ $config_and_ping 1
+ $config_and_ping 4094
+ $config_and_ping 4095 #reserved vlan id
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s not-exit:0 -e ignore \
+ rump.ifconfig vlan0 vlan 4096 vlanif shmif0
+
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 1 vlanif shmif0
+ atf_check -s not-exit:0 -e ignore \
+ rump.ifconfig vlan0 vlan 2 vlanif shmif0
+
+ atf_check -s not-exit:0 -e ignore \
+ rump.ifconfig vlan0 vlan 1 vlanif shmif1
+
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+ atf_check -s not-exit:0 -e ignore \
+ rump.ifconfig vlan0 $local0/$prefix
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 $af $local0/$prefix
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+ atf_check -s exit:0 rump.ifconfig vlan1 create
+ atf_check -s exit:0 rump.ifconfig vlan1 vlan 11 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan1 $af $local1/$prefix
+ atf_check -s exit:0 rump.ifconfig vlan1 up
+
+ export RUMP_SERVER=$SOCK_REMOTE
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 $af $remote0/$prefix
+ atf_check -s exit:0 rump.ifconfig vlan0 up
+ atf_check -s exit:0 rump.ifconfig vlan1 create
+ atf_check -s exit:0 rump.ifconfig vlan1 vlan 11 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan1 $af $remote1/$prefix
+ atf_check -s exit:0 rump.ifconfig vlan1 up
+
+ export RUMP_SERVER=$SOCK_LOCAL
+ atf_check -s exit:0 -o ignore $ping_cmd $remote0
+ atf_check -s exit:0 -o ignore $ping_cmd $remote1
+}
+
+atf_test_case vlan_vlanid cleanup
+vlan_vlanid_head()
+{
+
+ atf_set "descr" "tests of configuration for vlan id"
+ atf_set "require.progs" "rump_server"
+}
+
+vlan_vlanid_body()
+{
+ rump_server_start $SOCK_LOCAL vlan
+ rump_server_start $SOCK_REMOTE vlan
+
+ vlan_vlanid_body_common inet
+}
+
+vlan_vlanid_cleanup()
+{
+
+ $DEBUG && dump
+ cleanup
+}
+
+atf_test_case vlan_vlanid6 cleanup
+vlan_vlanid6_head()
+{
+
+ atf_set "descr" "tests of configuration for vlan id using IPv6"
+ atf_set "require.progs" "rump_server"
+}
+
+
+vlan_vlanid6_body()
+{
+ rump_server_start $SOCK_LOCAL vlan netinet6
+ rump_server_start $SOCK_REMOTE vlan netinet6
+
+ vlan_vlanid_body_common inet6
+}
+
+vlan_vlanid6_cleanup()
+{
+
+ $DEBUG && dump
+ cleanup
+}
+
+vlan_configs_body_common()
+{
+ export RUMP_SERVER=${SOCK_LOCAL}
+
+ atf_check -s exit:0 rump.ifconfig shmif0 create
+ atf_check -s exit:0 rump.ifconfig shmif1 create
+ atf_check -s exit:0 rump.ifconfig vlan0 create
+
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif shmif0
+
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 -e ignore rump.ifconfig vlan0 -vlanif shmif1
+ atf_check -s exit:0 -e ignore rump.ifconfig vlan0 -vlanif shmif2
+
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s exit:0 -e match:'Invalid argument' \
+ rump.ifconfig vlan0 mtu 1497
+ atf_check -s exit:0 rump.ifconfig vlan0 mtu 1496
+ atf_check -s exit:0 rump.ifconfig vlan0 mtu 42
+ atf_check -s exit:0 -e match:'Invalid argument' \
+ rump.ifconfig vlan0 mtu 41
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif
+
+ atf_check -s exit:0 rump.ifconfig vlan1 create
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+ atf_check -s not-exit:0 -e match:'File exists' \
+ rump.ifconfig vlan1 vlan 10 vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan1 vlan 10 vlanif shmif1
+
+ atf_check -s exit:0 rump.ifconfig vlan1 -vlanif shmif1
+ atf_check -s exit:0 rump.ifconfig vlan1 vlan 10 vlanif shmif1
+
+ atf_check -s exit:0 rump.ifconfig vlan0 -vlanif shmif0
+ atf_check -s exit:0 rump.ifconfig vlan0 vlan 10 vlanif shmif0
+}
+
+atf_test_case vlan_configs cleanup
+vlan_configs_head()
+{
+ atf_set "descr" "tests of configuration except vlan id"
+ atf_set "require.progs" "rump_server"
+}
+
+vlan_configs_body()
+{
+
+ rump_server_start $SOCK_LOCAL vlan
+
+ vlan_configs_body_common
+
+}
+
+vlan_configs_cleanup()
+{
+
+ $DEBUG && dump
+ cleanup
+}
+
+atf_test_case vlan_configs6 cleanup
+vlan_configs6_head()
+{
+ atf_set "descr" "tests of configuration except vlan id using IPv6"
+ atf_set "require.progs" "rump_server"
+}
+
+vlan_configs6_body()
+{
+ rump_server_start $SOCK_LOCAL vlan netinet6
+
+ vlan_configs_body_common
+}
+
+vlan_configs6_cleanup()
+{
+ $DEBUG && dump
+ cleanup
+}
+
atf_init_test_cases()
{
atf_add_test_case vlan_create_destroy
atf_add_test_case vlan_basic
+ atf_add_test_case vlan_vlanid
+ atf_add_test_case vlan_configs
+
+ atf_add_test_case vlan_create_destroy6
+ atf_add_test_case vlan_basic6
+ atf_add_test_case vlan_vlanid6
+ atf_add_test_case vlan_configs6
}