1f74e6e49SBjoern A. Zeeb#- 2f74e6e49SBjoern A. Zeeb# SPDX-License-Identifier: BSD-2-Clause 3f74e6e49SBjoern A. Zeeb# 4f74e6e49SBjoern A. Zeeb# Copyright (c) 2019 Netflix, Inc. 5f74e6e49SBjoern A. Zeeb# 6f74e6e49SBjoern A. Zeeb# Redistribution and use in source and binary forms, with or without 7f74e6e49SBjoern A. Zeeb# modification, are permitted provided that the following conditions 8f74e6e49SBjoern A. Zeeb# are met: 9f74e6e49SBjoern A. Zeeb# 1. Redistributions of source code must retain the above copyright 10f74e6e49SBjoern A. Zeeb# notice, this list of conditions and the following disclaimer. 11f74e6e49SBjoern A. Zeeb# 2. Redistributions in binary form must reproduce the above copyright 12f74e6e49SBjoern A. Zeeb# notice, this list of conditions and the following disclaimer in the 13f74e6e49SBjoern A. Zeeb# documentation and/or other materials provided with the distribution. 14f74e6e49SBjoern A. Zeeb# 15f74e6e49SBjoern A. Zeeb# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16f74e6e49SBjoern A. Zeeb# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17f74e6e49SBjoern A. Zeeb# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18f74e6e49SBjoern A. Zeeb# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19f74e6e49SBjoern A. Zeeb# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20f74e6e49SBjoern A. Zeeb# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21f74e6e49SBjoern A. Zeeb# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22f74e6e49SBjoern A. Zeeb# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23f74e6e49SBjoern A. Zeeb# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24f74e6e49SBjoern A. Zeeb# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25f74e6e49SBjoern A. Zeeb# SUCH DAMAGE. 26f74e6e49SBjoern A. Zeeb# 27f74e6e49SBjoern A. Zeeb 28f74e6e49SBjoern A. Zeeb. $(atf_get_srcdir)/frag6.subr 29f74e6e49SBjoern A. Zeeb 30f74e6e49SBjoern A. Zeebfrag6_15_pre_test() { 31f74e6e49SBjoern A. Zeeb 32f74e6e49SBjoern A. Zeeb local jname ifname 33f74e6e49SBjoern A. Zeeb jname=$1 34f74e6e49SBjoern A. Zeeb 35f74e6e49SBjoern A. Zeeb case "${jname}" in 36f74e6e49SBjoern A. Zeeb "") echo "ERROR: jname is empty"; return ;; 37f74e6e49SBjoern A. Zeeb esac 38f74e6e49SBjoern A. Zeeb 39f74e6e49SBjoern A. Zeeb # Accept 3 fragments per fragmented packet. 40f74e6e49SBjoern A. Zeeb jexec ${jname} sysctl net.inet6.ip6.maxfragsperpacket=3 41f74e6e49SBjoern A. Zeeb} 42f74e6e49SBjoern A. Zeeb 43f74e6e49SBjoern A. Zeeb 44f74e6e49SBjoern A. Zeebfrag6_15_check_stats() { 45f74e6e49SBjoern A. Zeeb 46f74e6e49SBjoern A. Zeeb local jname ifname 47f74e6e49SBjoern A. Zeeb jname=$1 48f74e6e49SBjoern A. Zeeb ifname=$2 49f74e6e49SBjoern A. Zeeb 50f74e6e49SBjoern A. Zeeb case "${jname}" in 51f74e6e49SBjoern A. Zeeb "") echo "ERROR: jname is empty"; return ;; 52f74e6e49SBjoern A. Zeeb esac 53f74e6e49SBjoern A. Zeeb case "${ifname}" in 54f74e6e49SBjoern A. Zeeb "") echo "ERROR: ifname is empty"; return ;; 55f74e6e49SBjoern A. Zeeb esac 56f74e6e49SBjoern A. Zeeb 57f74e6e49SBjoern A. Zeeb # Defaults are: IPV6_FRAGTTL 120 slowtimo ticks. 58f74e6e49SBjoern A. Zeeb # pfslowtimo() is run at hz/2. So this takes 60s. 59f74e6e49SBjoern A. Zeeb # This is awefully long for a test case. 60f74e6e49SBjoern A. Zeeb # The Python script has to wait for this already to get the ICMPv6 61f74e6e49SBjoern A. Zeeb # hence we do not sleep here anymore. 62f74e6e49SBjoern A. Zeeb 63*4527b28bSBjoern A. Zeeb nf=`jexec ${jname} sysctl -n net.inet6.ip6.frag6_nfragpackets` 64*4527b28bSBjoern A. Zeeb case ${nf} in 65*4527b28bSBjoern A. Zeeb 0) break ;; 66*4527b28bSBjoern A. Zeeb *) atf_fail "VNET frag6_nfragpackets not 0 but: ${nf}" ;; 67*4527b28bSBjoern A. Zeeb esac 68*4527b28bSBjoern A. Zeeb nf=`sysctl -n net.inet6.ip6.frag6_nfrags` 69*4527b28bSBjoern A. Zeeb case ${nf} in 70*4527b28bSBjoern A. Zeeb 0) break ;; 71*4527b28bSBjoern A. Zeeb *) atf_fail "Global frag6_nfrags not 0 but: ${nf}" ;; 72*4527b28bSBjoern A. Zeeb esac 73*4527b28bSBjoern A. Zeeb 74f74e6e49SBjoern A. Zeeb # 75f74e6e49SBjoern A. Zeeb # Check that the sysctl is set to what we expect. 76f74e6e49SBjoern A. Zeeb # 77f74e6e49SBjoern A. Zeeb sn=`jexec ${jname} sysctl -n net.inet6.ip6.maxfragsperpacket` 78f74e6e49SBjoern A. Zeeb case "${sn}" in 79f74e6e49SBjoern A. Zeeb 3) ;; 80f74e6e49SBjoern A. Zeeb *) atf_fail "Sysctl net.inet6.ip6.maxfragsperpacket is ${sn} and not 3" ;; 81f74e6e49SBjoern A. Zeeb esac 82f74e6e49SBjoern A. Zeeb 83f74e6e49SBjoern A. Zeeb # 84f74e6e49SBjoern A. Zeeb # Check selection of global UDP stats. 85f74e6e49SBjoern A. Zeeb # 86f74e6e49SBjoern A. Zeeb cat <<EOF > ${HOME}/filter-${jname}.txt 87f74e6e49SBjoern A. Zeeb <received-datagrams>0</received-datagrams> 88f74e6e49SBjoern A. Zeeb <dropped-incomplete-headers>0</dropped-incomplete-headers> 89f74e6e49SBjoern A. Zeeb <dropped-bad-data-length>0</dropped-bad-data-length> 90f74e6e49SBjoern A. Zeeb <dropped-bad-checksum>0</dropped-bad-checksum> 91f74e6e49SBjoern A. Zeeb <dropped-no-checksum>0</dropped-no-checksum> 92f74e6e49SBjoern A. Zeeb <dropped-no-socket>0</dropped-no-socket> 93f74e6e49SBjoern A. Zeeb <dropped-broadcast-multicast>0</dropped-broadcast-multicast> 94f74e6e49SBjoern A. Zeeb <dropped-full-socket-buffer>0</dropped-full-socket-buffer> 95f74e6e49SBjoern A. Zeeb <not-for-hashed-pcb>0</not-for-hashed-pcb> 96f74e6e49SBjoern A. ZeebEOF 97f74e6e49SBjoern A. Zeeb count=`jexec ${jname} netstat -s -p udp --libxo xml,pretty | grep -E -x -c -f ${HOME}/filter-${jname}.txt` 98f74e6e49SBjoern A. Zeeb rm -f ${HOME}/filter-${jname}.txt 99f74e6e49SBjoern A. Zeeb case ${count} in 100f74e6e49SBjoern A. Zeeb 9) ;; 101f74e6e49SBjoern A. Zeeb *) jexec ${jname} netstat -s -p udp --libxo xml,pretty 102f74e6e49SBjoern A. Zeeb atf_fail "Global UDP statistics do not match: ${count} != 9" ;; 103f74e6e49SBjoern A. Zeeb esac 104f74e6e49SBjoern A. Zeeb 105f74e6e49SBjoern A. Zeeb 106f74e6e49SBjoern A. Zeeb # 107f74e6e49SBjoern A. Zeeb # Check selection of global IPv6 stats. 108f74e6e49SBjoern A. Zeeb # 109f74e6e49SBjoern A. Zeeb cat <<EOF > ${HOME}/filter-${jname}.txt 110f74e6e49SBjoern A. Zeeb <dropped-below-minimum-size>0</dropped-below-minimum-size> 111f74e6e49SBjoern A. Zeeb <dropped-short-packets>0</dropped-short-packets> 112f74e6e49SBjoern A. Zeeb <dropped-bad-options>0</dropped-bad-options> 113f74e6e49SBjoern A. Zeeb <dropped-bad-version>0</dropped-bad-version> 114f74e6e49SBjoern A. Zeeb <received-fragments>8</received-fragments> 115f74e6e49SBjoern A. Zeeb <dropped-fragment>8</dropped-fragment> 116f74e6e49SBjoern A. Zeeb <dropped-fragment-after-timeout>0</dropped-fragment-after-timeout> 117f74e6e49SBjoern A. Zeeb <dropped-fragments-overflow>0</dropped-fragments-overflow> 118f74e6e49SBjoern A. Zeeb <atomic-fragments>0</atomic-fragments> 119f74e6e49SBjoern A. Zeeb <reassembled-packets>0</reassembled-packets> 120f74e6e49SBjoern A. Zeeb <forwarded-packets>0</forwarded-packets> 121f74e6e49SBjoern A. Zeeb <packets-not-forwardable>0</packets-not-forwardable> 122f74e6e49SBjoern A. Zeeb <sent-redirects>0</sent-redirects> 123f74e6e49SBjoern A. Zeeb <send-packets-fabricated-header>0</send-packets-fabricated-header> 124f74e6e49SBjoern A. Zeeb <discard-no-mbufs>0</discard-no-mbufs> 125f74e6e49SBjoern A. Zeeb <discard-no-route>0</discard-no-route> 126f74e6e49SBjoern A. Zeeb <sent-fragments>0</sent-fragments> 127f74e6e49SBjoern A. Zeeb <fragments-created>0</fragments-created> 128f74e6e49SBjoern A. Zeeb <discard-cannot-fragment>0</discard-cannot-fragment> 129f74e6e49SBjoern A. Zeeb <discard-scope-violations>0</discard-scope-violations> 130f74e6e49SBjoern A. ZeebEOF 131f74e6e49SBjoern A. Zeeb count=`jexec ${jname} netstat -s -p ip6 --libxo xml,pretty | grep -E -x -c -f ${HOME}/filter-${jname}.txt` 132f74e6e49SBjoern A. Zeeb rm -f ${HOME}/filter-${jname}.txt 133f74e6e49SBjoern A. Zeeb case ${count} in 134f74e6e49SBjoern A. Zeeb 20) ;; 135f74e6e49SBjoern A. Zeeb *) jexec ${jname} netstat -s -p ip6 --libxo xml,pretty 136f74e6e49SBjoern A. Zeeb atf_fail "Global IPv6 statistics do not match: ${count} != 20" ;; 137f74e6e49SBjoern A. Zeeb esac 138f74e6e49SBjoern A. Zeeb 139f74e6e49SBjoern A. Zeeb # 140f74e6e49SBjoern A. Zeeb # Check selection of global ICMPv6 stats. 141f74e6e49SBjoern A. Zeeb # XXX-TODO check output histogram (just too hard to parse [no multi-line-grep]) 142f74e6e49SBjoern A. Zeeb # 143f74e6e49SBjoern A. Zeeb cat <<EOF > ${HOME}/filter-${jname}.txt 144f74e6e49SBjoern A. Zeeb <icmp6-calls>1</icmp6-calls> 145f74e6e49SBjoern A. Zeeb <no-route>0</no-route> 146f74e6e49SBjoern A. Zeeb <admin-prohibited>0</admin-prohibited> 147f74e6e49SBjoern A. Zeeb <beyond-scope>0</beyond-scope> 148f74e6e49SBjoern A. Zeeb <address-unreachable>0</address-unreachable> 149f74e6e49SBjoern A. Zeeb <port-unreachable>0</port-unreachable> 150f74e6e49SBjoern A. Zeeb <packet-too-big>0</packet-too-big> 151f74e6e49SBjoern A. Zeeb <time-exceed-transmit>0</time-exceed-transmit> 152f74e6e49SBjoern A. Zeeb <time-exceed-reassembly>1</time-exceed-reassembly> 153f74e6e49SBjoern A. Zeeb <bad-header>0</bad-header> 154f74e6e49SBjoern A. Zeeb <bad-next-header>0</bad-next-header> 155f74e6e49SBjoern A. Zeeb <bad-option>0</bad-option> 156f74e6e49SBjoern A. Zeeb <redirects>0</redirects> 157f74e6e49SBjoern A. Zeeb <unknown>0</unknown> 158f74e6e49SBjoern A. Zeeb <reflect>0</reflect> 159f74e6e49SBjoern A. Zeeb <too-many-nd-options>0</too-many-nd-options> 160f74e6e49SBjoern A. Zeeb <bad-nd-options>0</bad-nd-options> 161f74e6e49SBjoern A. Zeeb <bad-neighbor-solicitation>0</bad-neighbor-solicitation> 162f74e6e49SBjoern A. Zeeb <bad-neighbor-advertisement>0</bad-neighbor-advertisement> 163f74e6e49SBjoern A. Zeeb <bad-router-solicitation>0</bad-router-solicitation> 164f74e6e49SBjoern A. Zeeb <bad-router-advertisement>0</bad-router-advertisement> 165f74e6e49SBjoern A. Zeeb <bad-redirect>0</bad-redirect> 166f74e6e49SBjoern A. ZeebEOF 167f74e6e49SBjoern A. Zeeb count=`jexec ${jname} netstat -s -p icmp6 --libxo xml,pretty | grep -E -x -c -f ${HOME}/filter-${jname}.txt` 168f74e6e49SBjoern A. Zeeb rm -f ${HOME}/filter-${jname}.txt 169f74e6e49SBjoern A. Zeeb case ${count} in 170f74e6e49SBjoern A. Zeeb 22) ;; 171f74e6e49SBjoern A. Zeeb *) jexec ${jname} netstat -s -p icmp6 --libxo xml,pretty 172f74e6e49SBjoern A. Zeeb atf_fail "Global ICMPv6 statistics do not match: ${count} != 22" ;; 173f74e6e49SBjoern A. Zeeb esac 174f74e6e49SBjoern A. Zeeb 175f74e6e49SBjoern A. Zeeb # 176f74e6e49SBjoern A. Zeeb # Check selection of interface IPv6 stats. 177f74e6e49SBjoern A. Zeeb # XXX-BZ no reassembly failed stats.# 178f74e6e49SBjoern A. Zeeb # 179f74e6e49SBjoern A. Zeeb cat <<EOF > ${HOME}/filter-${jname}.txt 180f74e6e49SBjoern A. Zeeb <dropped-invalid-header>0</dropped-invalid-header> 181f74e6e49SBjoern A. Zeeb <dropped-mtu-exceeded>0</dropped-mtu-exceeded> 182f74e6e49SBjoern A. Zeeb <dropped-no-route>0</dropped-no-route> 183f74e6e49SBjoern A. Zeeb <dropped-invalid-destination>0</dropped-invalid-destination> 184f74e6e49SBjoern A. Zeeb <dropped-unknown-protocol>0</dropped-unknown-protocol> 185f74e6e49SBjoern A. Zeeb <dropped-truncated>0</dropped-truncated> 186f74e6e49SBjoern A. Zeeb <sent-forwarded>0</sent-forwarded> 187f74e6e49SBjoern A. Zeeb <discard-packets>0</discard-packets> 188f74e6e49SBjoern A. Zeeb <discard-fragments>0</discard-fragments> 189f74e6e49SBjoern A. Zeeb <fragments-failed>0</fragments-failed> 190f74e6e49SBjoern A. Zeeb <fragments-created>0</fragments-created> 191f74e6e49SBjoern A. Zeeb <reassembly-required>8</reassembly-required> 192f74e6e49SBjoern A. Zeeb <reassembled-packets>0</reassembled-packets> 193f74e6e49SBjoern A. Zeeb <reassembly-failed>0</reassembly-failed> 194f74e6e49SBjoern A. ZeebEOF 195f74e6e49SBjoern A. Zeeb count=`jexec ${jname} netstat -s -p ip6 -I ${ifname} --libxo xml,pretty | grep -E -x -c -f ${HOME}/filter-${jname}.txt` 196f74e6e49SBjoern A. Zeeb rm -f ${HOME}/filter-${jname}.txt 197f74e6e49SBjoern A. Zeeb case ${count} in 198f74e6e49SBjoern A. Zeeb 14) ;; 199f74e6e49SBjoern A. Zeeb *) jexec ${jname} netstat -s -p ip6 -I ${ifname} --libxo xml,pretty 200f74e6e49SBjoern A. Zeeb atf_fail "Interface IPv6 statistics do not match: ${count} != 14" ;; 201f74e6e49SBjoern A. Zeeb esac 202f74e6e49SBjoern A. Zeeb 203f74e6e49SBjoern A. Zeeb # 204f74e6e49SBjoern A. Zeeb # Check selection of interface ICMPv6 stats. 205f74e6e49SBjoern A. Zeeb # 206f74e6e49SBjoern A. Zeeb cat <<EOF > ${HOME}/filter-${jname}.txt 207f74e6e49SBjoern A. Zeeb <received-errors>0</received-errors> 208f74e6e49SBjoern A. Zeeb <received-destination-unreachable>0</received-destination-unreachable> 209f74e6e49SBjoern A. Zeeb <received-admin-prohibited>0</received-admin-prohibited> 210f74e6e49SBjoern A. Zeeb <received-time-exceeded>0</received-time-exceeded> 211f74e6e49SBjoern A. Zeeb <received-bad-parameter>0</received-bad-parameter> 212f74e6e49SBjoern A. Zeeb <received-packet-too-big>0</received-packet-too-big> 213f74e6e49SBjoern A. Zeeb <received-echo-requests>0</received-echo-requests> 214f74e6e49SBjoern A. Zeeb <received-echo-replies>0</received-echo-replies> 215f74e6e49SBjoern A. Zeeb <received-router-solicitation>0</received-router-solicitation> 216f74e6e49SBjoern A. Zeeb <received-router-advertisement>0</received-router-advertisement> 217f74e6e49SBjoern A. Zeeb <sent-errors>1</sent-errors> 218f74e6e49SBjoern A. Zeeb <sent-destination-unreachable>0</sent-destination-unreachable> 219f74e6e49SBjoern A. Zeeb <sent-admin-prohibited>0</sent-admin-prohibited> 220f74e6e49SBjoern A. Zeeb <sent-time-exceeded>1</sent-time-exceeded> 221f74e6e49SBjoern A. Zeeb <sent-bad-parameter>0</sent-bad-parameter> 222f74e6e49SBjoern A. Zeeb <sent-packet-too-big>0</sent-packet-too-big> 223f74e6e49SBjoern A. Zeeb <sent-echo-requests>0</sent-echo-requests> 224f74e6e49SBjoern A. Zeeb <sent-echo-replies>0</sent-echo-replies> 225f74e6e49SBjoern A. Zeeb <sent-router-solicitation>0</sent-router-solicitation> 226f74e6e49SBjoern A. Zeeb <sent-router-advertisement>0</sent-router-advertisement> 227f74e6e49SBjoern A. Zeeb <sent-redirects>0</sent-redirects> 228f74e6e49SBjoern A. ZeebEOF 229f74e6e49SBjoern A. Zeeb count=`jexec ${jname} netstat -s -p icmp6 -I ${ifname} --libxo xml,pretty | grep -E -x -c -f ${HOME}/filter-${jname}.txt` 230f74e6e49SBjoern A. Zeeb rm -f ${HOME}/filter-${jname}.txt 231f74e6e49SBjoern A. Zeeb case ${count} in 232f74e6e49SBjoern A. Zeeb 21) ;; 233f74e6e49SBjoern A. Zeeb *) jexec ${jname} netstat -s -p icmp6 -I ${ifname} --libxo xml,pretty 234f74e6e49SBjoern A. Zeeb atf_fail "Interface ICMPv6 statistics do not match: ${count} != 21" ;; 235f74e6e49SBjoern A. Zeeb esac 236f74e6e49SBjoern A. Zeeb} 237f74e6e49SBjoern A. Zeeb 238f74e6e49SBjoern A. Zeebatf_test_case "frag6_15" "cleanup" 239f74e6e49SBjoern A. Zeebfrag6_15_head() { 240f74e6e49SBjoern A. Zeeb frag6_head 15 241f74e6e49SBjoern A. Zeeb} 242f74e6e49SBjoern A. Zeeb 243f74e6e49SBjoern A. Zeebfrag6_15_body() { 244f74e6e49SBjoern A. Zeeb frag6_body 15 frag6_15_check_stats frag6_15_pre_test 245f74e6e49SBjoern A. Zeeb} 246f74e6e49SBjoern A. Zeeb 247f74e6e49SBjoern A. Zeebfrag6_15_cleanup() { 248f74e6e49SBjoern A. Zeeb frag6_cleanup 15 249f74e6e49SBjoern A. Zeeb 250f74e6e49SBjoern A. Zeeb # No need to restore the sysctl back to default as the jail is gone. 251f74e6e49SBjoern A. Zeeb} 252f74e6e49SBjoern A. Zeeb 253f74e6e49SBjoern A. Zeebatf_init_test_cases() 254f74e6e49SBjoern A. Zeeb{ 255f74e6e49SBjoern A. Zeeb atf_add_test_case "frag6_15" 256f74e6e49SBjoern A. Zeeb} 257