Skip to content

Commit f8fded7

Browse files
idoschkuba-moo
authored andcommitted
selftests: net: Fix flaky neighbor garbage collection test
The purpose of the "Periodic garbage collection" test case is to make sure that "extern_valid" neighbors are not flushed during periodic garbage collection, unlike regular neighbor entries. The test case is currently doing the following: 1. Changing the base reachable time to 10 seconds so that periodic garbage collection will run every 5 seconds. 2. Changing the garbage collection stale time to 5 seconds so that neighbors that have not been used in the last 5 seconds will be considered for removal. 3. Waiting for the base reachable time change to take effect. 4. Adding an "extern_valid" neighbor, a non-"extern_valid" neighbor and a bunch of other neighbors so that the threshold ("thresh1") will be crossed and stale neighbors will be flushed during garbage collection. 5. Waiting for 10 seconds to give garbage collection a chance to run. 6. Checking that the "extern_valid" neighbor was not flushed and that the non-"extern_valid" neighbor was flushed. The test sometimes fails in the netdev CI because the non-"extern_valid" neighbor was not flushed. I am unable to reproduce this locally, but my theory that since we do not know exactly when the periodic garbage collection runs, it is possible for it to run at a time when the non-"extern_valid" neighbor is still not considered stale. Fix by moving the addition of the two neighbors before step 3 and by reducing the garbage collection stale time to 1 second, to ensure that both neighbors are considered stale when garbage collection runs. Fixes: 171f2ee ("selftests: net: Add a selftest for externally validated neighbor entries") Reported-by: Jakub Kicinski <[email protected]> Closes: https://lore.kernel.org/netdev/[email protected]/ Signed-off-by: Ido Schimmel <[email protected]> Link: https://patch.msgid.link/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
1 parent 0105101 commit f8fded7

File tree

1 file changed

+3
-3
lines changed

1 file changed

+3
-3
lines changed

tools/testing/selftests/net/test_neigh.sh

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -289,11 +289,11 @@ extern_valid_common()
289289
orig_base_reachable=$(ip -j ntable show name "$tbl_name" | jq '.[] | select(has("thresh1")) | .["base_reachable"]')
290290
run_cmd "ip ntable change name $tbl_name thresh1 10 base_reachable 10000"
291291
orig_gc_stale=$(ip -n "$ns1" -j ntable show name "$tbl_name" dev veth0 | jq '.[]["gc_stale"]')
292-
run_cmd "ip -n $ns1 ntable change name $tbl_name dev veth0 gc_stale 5000"
293-
# Wait orig_base_reachable/2 for the new interval to take effect.
294-
run_cmd "sleep $(((orig_base_reachable / 1000) / 2 + 2))"
292+
run_cmd "ip -n $ns1 ntable change name $tbl_name dev veth0 gc_stale 1000"
295293
run_cmd "ip -n $ns1 neigh add $ip_addr lladdr $mac nud stale dev veth0 extern_valid"
296294
run_cmd "ip -n $ns1 neigh add ${subnet}3 lladdr $mac nud stale dev veth0"
295+
# Wait orig_base_reachable/2 for the new interval to take effect.
296+
run_cmd "sleep $(((orig_base_reachable / 1000) / 2 + 2))"
297297
for i in {1..20}; do
298298
run_cmd "ip -n $ns1 neigh add ${subnet}$((i + 4)) nud none dev veth0"
299299
done

0 commit comments

Comments
 (0)