#!/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 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() { ip netns add h1 ip -n h1 link set lo up ip netns add h2 ip -n h2 link set lo up # 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() { ip netns del h1 2>/dev/null ip netns del h2 2>/dev/null } trap cleanup EXIT ################################################################################ # main while getopts :pv o do case $o in p) PAUSE_ON_FAIL=yes;; v) VERBOSE=1;; esac done cleanup 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