3 # This test is for checking rtnetlink callpaths, and get as much coverage as possible.
10 # set global exit status, but never reset nonzero one.
13 if [ $ret -eq 0 ]; then
20 ip link add name "$devdummy" type dummy
22 ip link set "$devdummy" up
28 ip link del dev "$devdummy"
32 # add a bridge with vlans on top
36 vlandev="testbr-vlan1"
39 ip link add name "$devbr" type bridge
42 ip link set dev "$devdummy" master "$devbr"
45 ip link set "$devbr" up
48 ip link add link "$devbr" name "$vlandev" type vlan id 1
50 ip addr add dev "$vlandev" 10.200.7.23/30
52 ip -6 addr add dev "$vlandev" dead:42::1234/64
54 ip -d link > /dev/null
56 ip r s t all > /dev/null
58 ip -6 addr del dev "$vlandev" dead:42::1234/64
61 ip link del dev "$vlandev"
63 ip link del dev "$devbr"
66 if [ $ret -ne 0 ];then
67 echo "FAIL: bridge setup"
70 echo "PASS: bridge setup"
81 ip tunnel add $gredev mode gre remote $rem local $loc ttl 1
83 ip link set $gredev up
85 ip addr add 10.23.7.10 dev $gredev
87 ip route add 10.23.8.0/30 dev $gredev
89 ip addr add dev "$devdummy" 10.23.7.11/24
95 ip addr del dev "$devdummy" 10.23.7.11/24
101 if [ $ret -ne 0 ];then
102 echo "FAIL: gre tunnel endpoint"
105 echo "PASS: gre tunnel endpoint"
108 # tc uses rtnetlink too, for full tc testing
109 # please see tools/testing/selftests/tc-testing.
115 tc qdisc add dev "$dev" root handle 1: htb
117 tc class add dev "$dev" parent 1: classid 1:10 htb rate 1mbit
119 tc filter add dev "$dev" parent 1:0 prio 5 handle ffe: protocol ip u32 divisor 256
121 tc filter add dev "$dev" parent 1:0 prio 5 handle ffd: protocol ip u32 divisor 256
123 tc filter add dev "$dev" parent 1:0 prio 5 handle ffc: protocol ip u32 divisor 256
125 tc filter add dev "$dev" protocol ip parent 1: prio 5 handle ffe:2:3 u32 ht ffe:2: match ip src 10.0.0.3 flowid 1:10
127 tc filter add dev "$dev" protocol ip parent 1: prio 5 handle ffe:2:2 u32 ht ffe:2: match ip src 10.0.0.2 flowid 1:10
129 tc filter show dev "$dev" parent 1:0 > /dev/null
131 tc filter del dev "$dev" protocol ip parent 1: prio 5 handle ffe:2:3 u32
133 tc filter show dev "$dev" parent 1:0 > /dev/null
135 tc qdisc del dev "$dev" root handle 1: htb
138 if [ $ret -ne 0 ];then
139 echo "FAIL: tc htb hierarchy"
142 echo "PASS: tc htb hierarchy"
146 kci_test_polrouting()
149 ip rule add fwmark 1 lookup 100
151 ip route add local 0.0.0.0/0 dev lo table 100
153 ip r s t all > /dev/null
155 ip rule del fwmark 1 lookup 100
157 ip route del local 0.0.0.0/0 dev lo table 100
160 if [ $ret -ne 0 ];then
161 echo "FAIL: policy route test"
164 echo "PASS: policy routing"
171 ip route get 127.0.0.1 > /dev/null
173 ip route get 127.0.0.1 dev "$devdummy" > /dev/null
175 ip route get ::1 > /dev/null
177 ip route get fe80::1 dev "$devdummy" > /dev/null
179 ip route get 127.0.0.1 from 127.0.0.1 oif lo tos 0x1 mark 0x1 > /dev/null
181 ip route get ::1 from ::1 iif lo oif lo tos 0x1 mark 0x1 > /dev/null
183 ip addr add dev "$devdummy" 10.23.7.11/24
185 ip route get 10.23.7.11 from 10.23.7.12 iif "$devdummy" > /dev/null
187 ip addr del dev "$devdummy" 10.23.7.11/24
190 if [ $ret -ne 0 ];then
191 echo "FAIL: route get"
195 echo "PASS: route get"
200 for i in $(seq 10 100) ;do
201 lft=$(((RANDOM%3) + 1))
202 ip addr add 10.23.11.$i/32 dev "$devdummy" preferred_lft $lft valid_lft $((lft+1))
208 ip addr show dev "$devdummy" | grep "10.23.11."
209 if [ $? -eq 0 ]; then
210 echo "FAIL: preferred_lft addresses remaining"
215 echo "PASS: preferred_lft addresses have expired"
222 ip addrlabel add prefix dead::/64 dev lo label 1
225 ip addrlabel list |grep -q "prefix dead::/64 dev lo label 1"
228 ip addrlabel del prefix dead::/64 dev lo label 1 2> /dev/null
231 ip addrlabel add prefix dead::/64 label 1 2> /dev/null
234 ip addrlabel del prefix dead::/64 label 1 2> /dev/null
237 # concurrent add/delete
238 for i in $(seq 1 1000); do
239 ip addrlabel add prefix 1c3::/64 label 12345 2>/dev/null
242 for i in $(seq 1 1000); do
243 ip addrlabel del prefix 1c3::/64 label 12345 2>/dev/null
248 ip addrlabel del prefix 1c3::/64 label 12345 2>/dev/null
250 if [ $ret -ne 0 ];then
251 echo "FAIL: ipv6 addrlabel"
255 echo "PASS: ipv6 addrlabel"
261 if [ $ret -ne 0 ];then
262 echo "FAIL: cannot add dummy interface"
277 #check for needed privileges
278 if [ "$(id -u)" -ne 0 ];then
279 echo "SKIP: Need root privileges"
284 $x -Version 2>/dev/null >/dev/null
286 echo "SKIP: Could not run test without the $x tool"