blob: 062f957950af3d99804b9f8ec30a283d433e9420 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
ALL_TESTS="
test_set_remote
test_change_mc_remote
"
source lib.sh
check_remotes()
{
local what=$1; shift
local N=$(bridge fdb sh dev vx | grep 00:00:00:00:00:00 | wc -l)
((N == 2))
check_err $? "expected 2 remotes after $what, got $N"
}
# Check FDB default-remote handling across "ip link set".
test_set_remote()
{
RET=0
ip_link_add vx up type vxlan id 2000 dstport 4789
bridge fdb ap dev vx 00:00:00:00:00:00 dst 192.0.2.20 self permanent
bridge fdb ap dev vx 00:00:00:00:00:00 dst 192.0.2.30 self permanent
check_remotes "fdb append"
ip link set dev vx type vxlan remote 192.0.2.30
check_remotes "link set"
log_test 'FDB default-remote handling across "ip link set"'
}
fmt_remote()
{
local addr=$1; shift
if [[ $addr == 224.* ]]; then
echo "group $addr"
else
echo "remote $addr"
fi
}
change_remote()
{
local remote=$1; shift
ip link set dev vx type vxlan $(fmt_remote $remote) dev v1
}
check_membership()
{
local check_vec=("$@")
local memberships
memberships=$(
netstat -n --groups |
sed -n '/^v1\b/p' |
grep -o '[^ ]*$'
)
check_err $? "Couldn't obtain group memberships"
local item
for item in "${check_vec[@]}"; do
eval "local $item"
echo "$memberships" | grep -q "\b$group\b"
check_err_fail $fail $? "$group is_ex reported in IGMP query response"
done
}
test_change_mc_remote()
{
check_command netstat || return
ip_link_add v1 up type veth peer name v2
ip_link_set_up v2
RET=0
ip_link_add vx up type vxlan dstport 4789 \
local 192.0.2.1 $(fmt_remote 224.1.1.1) dev v1 vni 1000
check_membership "group=224.1.1.1 fail=0" \
"group=224.1.1.2 fail=1" \
"group=224.1.1.3 fail=1"
log_test "MC group report after VXLAN creation"
RET=0
change_remote 224.1.1.2
check_membership "group=224.1.1.1 fail=1" \
"group=224.1.1.2 fail=0" \
"group=224.1.1.3 fail=1"
log_test "MC group report after changing VXLAN remote MC->MC"
RET=0
change_remote 192.0.2.2
check_membership "group=224.1.1.1 fail=1" \
"group=224.1.1.2 fail=1" \
"group=224.1.1.3 fail=1"
log_test "MC group report after changing VXLAN remote MC->UC"
}
trap defer_scopes_cleanup EXIT
tests_run
exit $EXIT_STATUS
|