| Server IP : 54.233.248.239 / Your IP : 172.28.1.13 Web Server : Apache System : Linux ip-172-28-29-189 6.5.0-1014-aws #14~22.04.1-Ubuntu SMP Thu Feb 15 15:27:06 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.2.34-43+ubuntu22.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/lib/modules/6.8.0-1042-aws/build/tools/testing/selftests/net/ |
Upload File : |
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
#
# ns: h1 | ns: h2
# 192.168.0.1/24 |
# eth0 |
# | 192.168.1.1/32
# veth0 <---|---> veth1
# Validate source address selection for route without gateway
source lib.sh
PAUSE_ON_FAIL=no
VERBOSE=0
ret=0
################################################################################
# helpers
log_test()
{
local rc=$1
local expected=$2
local msg="$3"
if [ ${rc} -eq ${expected} ]; then
printf "TEST: %-60s [ OK ]\n" "${msg}"
nsuccess=$((nsuccess+1))
else
ret=1
nfail=$((nfail+1))
printf "TEST: %-60s [FAIL]\n" "${msg}"
if [ "${PAUSE_ON_FAIL}" = "yes" ]; then
echo
echo "hit enter to continue, 'q' to quit"
read a
[ "$a" = "q" ] && exit 1
fi
fi
[ "$VERBOSE" = "1" ] && echo
}
run_cmd()
{
local cmd="$*"
local out
local rc
if [ "$VERBOSE" = "1" ]; then
echo "COMMAND: $cmd"
fi
out=$(eval $cmd 2>&1)
rc=$?
if [ "$VERBOSE" = "1" -a -n "$out" ]; then
echo "$out"
fi
[ "$VERBOSE" = "1" ] && echo
return $rc
}
################################################################################
# config
setup()
{
setup_ns h1 h2
# Add a fake eth0 to support an ip address
ip -n $h1 link add name eth0 type dummy
ip -n $h1 link set eth0 up
ip -n $h1 address add 192.168.0.1/24 dev eth0
# Configure veths (same @mac, arp off)
ip -n $h1 link add name veth0 type veth peer name veth1 netns $h2
ip -n $h1 link set veth0 up
ip -n $h2 link set veth1 up
# Configure @IP in the peer netns
ip -n $h2 address add 192.168.1.1/32 dev veth1
ip -n $h2 route add default dev veth1
# Add a nexthop without @gw and use it in a route
ip -n $h1 nexthop add id 1 dev veth0
ip -n $h1 route add 192.168.1.1 nhid 1
}
cleanup()
{
cleanup_ns $h1 $h2
}
trap cleanup EXIT
################################################################################
# main
while getopts :pv o
do
case $o in
p) PAUSE_ON_FAIL=yes;;
v) VERBOSE=1;;
esac
done
setup
run_cmd ip -netns $h1 route get 192.168.1.1
log_test $? 0 "nexthop: get route with nexthop without gw"
run_cmd ip netns exec $h1 ping -c1 192.168.1.1
log_test $? 0 "nexthop: ping through nexthop without gw"
exit $ret