Module Name: src Committed By: ozaki-r Date: Wed Sep 20 09:36:20 UTC 2017
Modified Files: src/distrib/sets/lists/tests: mi src/tests/net/route: Makefile Added Files: src/tests/net/route: t_rtcache.sh Log Message: Add tests of rtcache invalidation To generate a diff of this commit: cvs rdiff -u -r1.761 -r1.762 src/distrib/sets/lists/tests/mi cvs rdiff -u -r1.5 -r1.6 src/tests/net/route/Makefile cvs rdiff -u -r0 -r1.1 src/tests/net/route/t_rtcache.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.761 src/distrib/sets/lists/tests/mi:1.762 --- src/distrib/sets/lists/tests/mi:1.761 Wed Aug 16 13:53:20 2017 +++ src/distrib/sets/lists/tests/mi Wed Sep 20 09:36:20 2017 @@ -1,4 +1,4 @@ -# $NetBSD: mi,v 1.761 2017/08/16 13:53:20 joerg Exp $ +# $NetBSD: mi,v 1.762 2017/09/20 09:36:20 ozaki-r Exp $ # # Note: don't delete entries from here - mark them as "obsolete" instead. # @@ -3379,6 +3379,7 @@ ./usr/tests/net/route/t_flags tests-net-tests atf,rump ./usr/tests/net/route/t_flags6 tests-net-tests atf,rump ./usr/tests/net/route/t_route tests-net-tests atf,rump +./usr/tests/net/route/t_rtcache tests-net-tests atf,rump ./usr/tests/net/sys tests-net-tests compattestfile,atf ./usr/tests/net/sys/Atffile tests-net-tests compattestfile,atf ./usr/tests/net/sys/Kyuafile tests-net-tests compattestfile,atf,kyua Index: src/tests/net/route/Makefile diff -u src/tests/net/route/Makefile:1.5 src/tests/net/route/Makefile:1.6 --- src/tests/net/route/Makefile:1.5 Thu Nov 24 09:05:17 2016 +++ src/tests/net/route/Makefile Wed Sep 20 09:36:20 2017 @@ -1,11 +1,11 @@ -# $NetBSD: Makefile,v 1.5 2016/11/24 09:05:17 ozaki-r Exp $ +# $NetBSD: Makefile,v 1.6 2017/09/20 09:36:20 ozaki-r Exp $ # .include <bsd.own.mk> TESTSDIR= ${TESTSBASE}/net/route -.for name in change flags flags6 route +.for name in change flags flags6 route rtcache TESTS_SH+= t_${name} TESTS_SH_SRC_t_${name}= ../net_common.sh t_${name}.sh .endfor Added files: Index: src/tests/net/route/t_rtcache.sh diff -u /dev/null src/tests/net/route/t_rtcache.sh:1.1 --- /dev/null Wed Sep 20 09:36:20 2017 +++ src/tests/net/route/t_rtcache.sh Wed Sep 20 09:36:20 2017 @@ -0,0 +1,167 @@ +# $NetBSD: t_rtcache.sh,v 1.1 2017/09/20 09:36:20 ozaki-r 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. +# + +SOCK_SRC=unix://rtcache_src +SOCK_FWD=unix://rtcache_fwd +SOCK_DST1=unix://rtcache_dst1 +SOCK_DST2=unix://rtcache_dst2 + +BUS_SRC=./src +BUS_DST1=./dst1 +BUS_DST2=./dst2 + +DEBUG=${DEBUG:-false} + +atf_test_case rtcache_invalidation cleanup +rtcache_invalidation_head() +{ + + atf_set "descr" "Tests for rtcache invalidation" + atf_set "require.progs" "rump_server" +} + +rtcache_invalidation_body() +{ + local ip_src=10.0.0.2 + local ip_gwsrc=10.0.0.1 + local ip_gwdst1=10.0.1.1 + local ip_gwdst2=10.0.2.1 + local ip_dst1=10.0.1.2 + local ip_dst2=10.0.2.2 + local ip_dst=10.0.3.1 + local subnet_src=10.0.0.0 + local subnet_dst=10.0.3.0 + + rump_server_start $SOCK_SRC + rump_server_start $SOCK_FWD + rump_server_start $SOCK_DST1 + rump_server_start $SOCK_DST2 + + rump_server_add_iface $SOCK_SRC shmif0 $BUS_SRC + + rump_server_add_iface $SOCK_FWD shmif0 $BUS_SRC + rump_server_add_iface $SOCK_FWD shmif1 $BUS_DST1 + rump_server_add_iface $SOCK_FWD shmif2 $BUS_DST2 + + rump_server_add_iface $SOCK_DST1 shmif0 $BUS_DST1 + rump_server_add_iface $SOCK_DST2 shmif0 $BUS_DST2 + + export RUMP_SERVER=$SOCK_SRC + atf_check -s exit:0 rump.sysctl -q -w net.inet.ip.dad_count=0 + atf_check -s exit:0 rump.ifconfig shmif0 $ip_src/24 + atf_check -s exit:0 -o ignore rump.route add default $ip_gwsrc + + export RUMP_SERVER=$SOCK_FWD + atf_check -s exit:0 rump.sysctl -q -w net.inet.ip.forwarding=1 + atf_check -s exit:0 rump.sysctl -q -w net.inet.ip.dad_count=0 + atf_check -s exit:0 rump.ifconfig shmif0 $ip_gwsrc/24 + atf_check -s exit:0 rump.ifconfig shmif1 $ip_gwdst1/24 + atf_check -s exit:0 rump.ifconfig shmif2 $ip_gwdst2/24 + + export RUMP_SERVER=$SOCK_DST1 + atf_check -s exit:0 rump.sysctl -q -w net.inet.ip.dad_count=0 + atf_check -s exit:0 rump.ifconfig shmif0 $ip_dst1/24 + atf_check -s exit:0 -o ignore rump.route add default $ip_gwdst1 + atf_check -s exit:0 rump.ifconfig shmif0 $ip_dst/24 alias + + export RUMP_SERVER=$SOCK_DST2 + atf_check -s exit:0 rump.sysctl -q -w net.inet.ip.dad_count=0 + atf_check -s exit:0 rump.ifconfig shmif0 $ip_dst2/24 + atf_check -s exit:0 -o ignore rump.route add default $ip_gwdst2 + atf_check -s exit:0 rump.ifconfig shmif0 $ip_dst/24 alias + + export RUMP_SERVER=$SOCK_SRC + atf_check -s exit:0 -o ignore rump.ping -n -w 3 -c 1 $ip_dst1 + atf_check -s exit:0 -o ignore rump.ping -n -w 3 -c 1 $ip_dst2 + # It fails because there is no route to $ip_dst + atf_check -s not-exit:0 -o ignore rump.ping -n -w 3 -c 1 $ip_dst + + extract_new_packets $BUS_DST1 > ./outfile + + export RUMP_SERVER=$SOCK_FWD + # Add the default route so that $ip_dst @ dst1 is reachable now + atf_check -s exit:0 -o ignore rump.route add default $ip_dst1 + export RUMP_SERVER=$SOCK_DST1 + # ...but don't response ICMP requests to avoid rtcache pollution + atf_check -s exit:0 -o ignore \ + rump.route add -net $subnet_src/24 127.0.0.1 -blackhole + + export RUMP_SERVER=$SOCK_SRC + # ping fails expectedly + atf_check -s not-exit:0 -o ignore rump.ping -n -w 3 -c 1 $ip_dst + + # An ICMP request should come to dst1 + extract_new_packets $BUS_DST1 > ./outfile + atf_check -s exit:0 -o match:"$ip_src > $ip_dst: ICMP echo request" \ + cat ./outfile + + export RUMP_SERVER=$SOCK_FWD + # Teach the subnet of $ip_dst is at dst2 + atf_check -s exit:0 -o ignore rump.route add -net $subnet_dst/24 $ip_dst2 + export RUMP_SERVER=$SOCK_DST2 + # ...but don't response ICMP requests to avoid rtcache pollution + atf_check -s exit:0 -o ignore \ + rump.route add -net $subnet_src/24 127.0.0.1 -blackhole + + export RUMP_SERVER=$SOCK_SRC + # ping fails expectedly + atf_check -s not-exit:0 -o ignore rump.ping -n -w 3 -c 1 $ip_dst + + # An ICMP request should come to dst2. If rtcaches aren't invalidated + # correctly, the ICMP request should appear at dst1 + extract_new_packets $BUS_DST1 > ./outfile + atf_check -s exit:0 -o not-match:"$ip_src > $ip_dst: ICMP echo request" \ + cat ./outfile + + export RUMP_SERVER=$SOCK_FWD + # Delete the route so the packets heading to $ip_dst should go dst1 again + atf_check -s exit:0 -o ignore rump.route delete -net $subnet_dst/24 $ip_dst2 + + export RUMP_SERVER=$SOCK_SRC + # ping fails expectedly + atf_check -s not-exit:0 -o ignore rump.ping -n -w 3 -c 1 $ip_dst + + # An ICMP request should come to dst1 + extract_new_packets $BUS_DST1 > ./outfile + atf_check -s exit:0 -o match:"$ip_src > $ip_dst: ICMP echo request" \ + cat ./outfile + + rump_server_destroy_ifaces +} + +rtcache_invalidation_cleanup() +{ + + $DEBUG && dump + cleanup +} + +atf_init_test_cases() +{ + + atf_add_test_case rtcache_invalidation +}