Home | History | Annotate | Download | only in multi-diffnic
      1 #!/bin/sh
      2 
      3 ################################################################################
      4 ##                                                                            ##
      5 ## Copyright (c) International Business Machines  Corp., 2005                 ##
      6 ##                                                                            ##
      7 ## This program is free software;  you can redistribute it and#or modify      ##
      8 ## it under the terms of the GNU General Public License as published by       ##
      9 ## the Free Software Foundation; either version 2 of the License, or          ##
     10 ## (at your option) any later version.                                        ##
     11 ##                                                                            ##
     12 ## This program is distributed in the hope that it will be useful, but        ##
     13 ## WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY ##
     14 ## or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License   ##
     15 ## for more details.                                                          ##
     16 ##                                                                            ##
     17 ## You should have received a copy of the GNU General Public License          ##
     18 ## along with this program;  if not, write to the Free Software               ##
     19 ## Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA    ##
     20 ##                                                                            ##
     21 ##                                                                            ##
     22 ################################################################################
     23 #
     24 # File:
     25 #   udp4-multi-diffnic01
     26 #
     27 # Description:
     28 #   Verify that the kernel is not crashed with receiving and sending UDP
     29 #   datagram at differnt NIC with the following conditions
     30 #     - The version of IP is IPv4
     31 #     - IPsec is not used
     32 #
     33 #   *) This script may be read by the other test case
     34 #
     35 # Setup:
     36 #   See ltp-yyyymmdd/testcases/network/stress/README
     37 #
     38 # Author:
     39 #   Mitsuru Chinen <mitch (at] jp.ibm.com>
     40 #
     41 # History:
     42 #	Oct 19 2005 - Created (Mitsuru Chinen)
     43 #
     44 #-----------------------------------------------------------------------
     45 # Uncomment line below for debug output.
     46 #trace_logic=${trace_logic:-"set -x"}
     47 $trace_logic
     48 
     49 # The test case ID, the test case count and the total number of test case
     50 TCID=${TCID:-udp4-multi-diffnic01}
     51 TST_TOTAL=1
     52 TST_COUNT=1
     53 export TCID
     54 export TST_COUNT
     55 export TST_TOTAL
     56 
     57 # Test description
     58 tst_resm TINFO "Verify that the kernel is not crashed with receiving and sending UDP datagram at the differnt NICs with the following conditions"
     59 
     60 # Make sure the value of LTPROOT
     61 LTPROOT=${LTPROOT:-`(cd ../../../../.. ; pwd)`}
     62 export LTPROOT
     63 
     64 # Check the environmanet variable
     65 . check_envval || exit $TST_TOTAL
     66 
     67 # Dulation of the test [sec]
     68 NS_DURATION=${NS_DURATION:-3600}      # 1 hour
     69 
     70 #The number of the test link where tests run
     71 LINK_NUM=${LINK_NUM:-0}
     72 
     73 # The version of IP
     74 IP_VER=${IP_VER:-4}
     75 
     76 # true, if ipsec is used
     77 DO_IPSEC=${DO_IPSEC:-false}
     78 
     79 # The value of SPI
     80 SPI=${SPI:-1000}
     81 
     82 # IPsec Protocol ( ah / esp / ipcomp )
     83 IPSEC_PROTO=${IPSEC_PROTO:-ah}
     84 
     85 # IPsec Mode ( transport / tunnel )
     86 IPSEC_MODE=${IPSEC_MODE:-transport}
     87 
     88 
     89 #-----------------------------------------------------------------------
     90 #
     91 # Function: do_cleanup
     92 #
     93 # Description:
     94 #   Recover the system configuration
     95 #
     96 #-----------------------------------------------------------------------
     97 do_cleanup()
     98 {
     99     # Kill the udp traffic server
    100     killall_udp_traffic
    101 
    102     # Unset SAD/SPD
    103     output_ipsec_conf flush | setkey -c >/dev/null 2>&1
    104     $LTP_RSH $RHOST ${LTPROOT}/'testcases/bin/output_ipsec_conf flush | PATH=/sbin:/usr/sbin:$PATH setkey -c' >/dev/null 2>&1
    105 
    106     # Clean up each interface
    107     link_num=0
    108     while [ $link_num -lt $link_total ]; do
    109 	# Initialize the interfaces
    110 	initialize_if lhost ${link_num}
    111 	initialize_if rhost ${link_num}
    112 	link_num=`expr $link_num + 1`
    113     done
    114 }
    115 
    116 
    117 #-----------------------------------------------------------------------
    118 #
    119 # Setup
    120 #
    121 
    122 # Unset the maximum number of processes
    123 ulimit -u unlimited
    124 
    125 # Output the informaion
    126 tst_resm TINFO "- Test duration is $NS_DURATION [sec]"
    127 
    128 link_total=`echo $LHOST_HWADDRS | wc -w`
    129 rhost_link_total=`echo $RHOST_HWADDRS | wc -w`
    130 if [ $link_total -ne $rhost_link_total ]; then
    131     tst_resm TBROK "The number of element in LHOST_HWADDRS differs from RHOST_HWADDRS"
    132     exit 1
    133 fi
    134 if [ $link_total -lt 2 ]; then
    135     tst_resm TBROK "This test case requires plural NICs."
    136     exit 1
    137 fi
    138 tst_resm TINFO "- Target number of the connection is $link_total"
    139 
    140 tst_resm TINFO "- Version of IP is IPv${IP_VER}"
    141 
    142 if $DO_IPSEC ; then
    143     message=`check_setkey`
    144     if [ $? -ne 0 ]; then
    145 	tst_resm TBROK "$message"
    146 	exit 1
    147     fi
    148 
    149     case $IPSEC_PROTO in
    150 	ah)
    151 	tst_resm TINFO "- IPsec [ AH / $IPSEC_MODE ]"
    152 	;;
    153 	esp)
    154 	tst_resm TINFO "- IPsec [ ESP / $IPSEC_MODE ]"
    155 	;;
    156 	ipcomp)
    157 	tst_resm TINFO "- IPcomp [ $IPSEC_MODE ]"
    158 	;;
    159     esac
    160 fi
    161 
    162 # Initialize the system configuration
    163 do_cleanup
    164 
    165 # Call do_cleanup function before exit
    166 trap do_cleanup 0
    167 
    168 # Loop for NIC configuration
    169 link_num=0
    170 lhost_addrs=""
    171 while [ $link_num -lt $link_total ]; do
    172     # name of interface of the local/remote host
    173     lhost_ifname=`get_ifname lhost $link_num`
    174     if [ $? -ne 0 ]; then
    175 	tst_resm TBROK "Failed to get the interface name at the local host"
    176 	exit $TST_TOTAL
    177     fi
    178     rhost_ifname=`get_ifname rhost $link_num`
    179     if [ $? -ne 0 ]; then
    180 	tst_resm TBROK "Failed to get the interface name at the remtoe host"
    181 	exit $TST_TOTAL
    182     fi
    183 
    184     # Set the IP address to each interface
    185     case $IP_VER in
    186 	4)
    187 	network_part="10.0.${link_num}"
    188 	network_mask=24
    189 	lhost_host_part="2"     # local host
    190 	rhost_host_part="1"     # remote host
    191 	set_ipv4addr lhost $link_num $network_part $lhost_host_part
    192 	if [ $? -ne 0 ]; then
    193 	    tst_resm TBROK "Failed to set IPv4 address at the local host"
    194 	    exit 1
    195 	fi
    196 	set_ipv4addr rhost $link_num $network_part $rhost_host_part
    197 	if [ $? -ne 0 ]; then
    198 	    tst_resm TBROK "Failed to set IPv4 address at the remote host"
    199 	    exit 1
    200 	fi
    201 
    202 	# IPv4 address of the local/remote host
    203 	lhost_addr="${network_part}.${lhost_host_part}"
    204 	rhost_addr="${network_part}.${rhost_host_part}"
    205 	lhost_addrs="${lhost_addrs} ${lhost_addr}"
    206 	;;
    207 
    208 	6)
    209 	network_part="fd00:1:0:`printf %x ${link_num}`"
    210 	network_mask=64
    211 	lhost_host_part=":2"     # local host
    212 	rhost_host_part=":1"     # remote host
    213 	add_ipv6addr lhost $link_num $network_part $lhost_host_part
    214 	if [ $? -ne 0 ]; then
    215 	    tst_resm TBROK "Failed to set IPv6 address at the local host"
    216 	    exit 1
    217 	fi
    218 	add_ipv6addr rhost $link_num $network_part $rhost_host_part
    219 	if [ $? -ne 0 ]; then
    220 	    tst_resm TBROK "Failed to set IPv6 address at the remote host"
    221 	    exit 1
    222 	fi
    223 	lhost_addr="${network_part}:${lhost_host_part}"
    224 	rhost_addr="${network_part}:${rhost_host_part}"
    225 	lhost_addrs="${lhost_addrs} ${lhost_addr}"
    226 	;;
    227 
    228 	*)
    229 	tst_resm TBROK "Unknown IP version"
    230 	;;
    231     esac
    232 
    233     # Configure SAD/SPD
    234     if $DO_IPSEC ; then
    235 	ipsec_log=`mktemp -p $TMPDIR`
    236 
    237 	# Set SAD/SPD according to the variables
    238 	output_ipsec_conf src \
    239 	    $IPSEC_PROTO $IPSEC_MODE $SPI $lhost_addr $rhost_addr \
    240 		| setkey -c 2>&1 | tee $ipsec_log
    241 	if [ $? -ne 0 -o -s $ipsec_log ]; then
    242 	    rm -f $ipsec_log
    243 	    tst_resm TBROK "Failed to configure SAD/SPD on the local host."
    244 	    exit 1
    245 	fi
    246 
    247 	$LTP_RSH $RHOST ${LTPROOT}/testcases/bin/output_ipsec_conf dst $IPSEC_PROTO $IPSEC_MODE $SPI $lhost_addr $rhost_addr' | PATH=/sbin:/usr/sbin:$PATH setkey -c' 2>&1 | tee $ipsec_log
    248 	if [ $? -ne 0 -o -s $ipsec_log ]; then
    249 	    rm -f $ipsec_log
    250 	    tst_resm TBROK "Failed to configure SAD/SPD on the remote host."
    251 	    exit 1
    252 	fi
    253 	rm -f $ipsec_log
    254     fi
    255 
    256     # Make sure the connectivity
    257     case $IP_VER in
    258 	4)
    259 	ret=`$LTP_RSH $RHOST ${LTPROOT}/testcases/bin/check_icmpv4_connectivity $rhost_ifname $lhost_addr' ; echo $?'`
    260 	if [ $ret -ne 0 ]; then
    261 	    tst_resm TBROK "There is no IPv4 connectivity on Link${link_num}"
    262 	    exit 1
    263 	fi
    264 	;;
    265 
    266 	6)
    267 	ret=`$LTP_RSH $RHOST ${LTPROOT}/testcases/bin/check_icmpv6_connectivity $rhost_ifname $lhost_addr' ; echo $?'`
    268 	if [ $ret -ne 0 ]; then
    269 	    tst_resm TBROK "There is no IPv6 connectivity on Link${link_num}"
    270 	    exit 1
    271 	fi
    272 	;;
    273     esac
    274 
    275     link_num=`expr $link_num + 1`
    276 done
    277 
    278 
    279 #-----------------------------------------------------------------------
    280 #
    281 # Main
    282 #
    283 #
    284 
    285 # Find the available consecutive ports
    286 server_port=`find_portbundle udp 1025 1`
    287 if [ $? -ne 0 ]; then
    288     tst_resm TBROK "No port is available."
    289     exit 1
    290 fi
    291 
    292 # Run a UDP traffic server
    293 info_file=`mktemp -p $TMPDIR`
    294 ns-udpserver -b -f $IP_VER -p $server_port -o $info_file
    295 if [ $? -ne 0 ]; then
    296     tst_resm TFAIL "Failed to run a UDP traffic server"
    297     exit 1
    298 fi
    299 
    300 # Collect the information of the server
    301 while true ; do
    302     if [ -s $info_file ]; then
    303 	break
    304     fi
    305 done
    306 server_pid=`grep PID: $info_file | cut -f 2 -d ' '`
    307 rm -f $info_file
    308 
    309 # Main loop
    310 connection_num=0
    311 while [ $connection_num -lt $link_total ]; do
    312     field=`expr $connection_num + 1`
    313     lhost_addr=`echo $lhost_addrs | cut -d ' ' -f $field`
    314 
    315     # Run a client
    316     ret=`$LTP_RSH $RHOST ${LTPROOT}/testcases/bin/ns-udpclient -b -f $IP_VER -S $lhost_addr -p $server_port' ; echo $?'`
    317     if [ $ret -ne 0 ]; then
    318 	tst_resm TFAIL "Failed to run client on Link${connection_num}"
    319 	exit 1
    320     fi
    321     connection_num=`expr $connection_num + 1`
    322 done
    323 
    324 
    325 # Watch the UDP traffic server
    326 start_epoc=`date +%s`
    327 while true ; do
    328     current_epoc=`date +%s`
    329     elapse_epoc=`expr $current_epoc - $start_epoc`
    330 
    331     if [ $elapse_epoc -ge $NS_DURATION ]; then
    332 	break
    333     else
    334 	ps auxw | fgrep ns-udpserver | fgrep -l $server_pid >/dev/null 2>&1
    335 	if [ $? -ne 0 ]; then
    336 	    tst_resm TFAIL "udp traffic server is dead in $elapse_epoc [sec]"
    337 	    exit 1
    338 	fi
    339     fi
    340     sleep 1
    341 done
    342 
    343 
    344 #-----------------------------------------------------------------------
    345 #
    346 # Clean up
    347 #
    348 
    349 tst_resm TPASS "Test is finished successfully."
    350 exit 0
    351