selftests: mptcp: simult flows: mark 'unbalanced' tests as flaky
authorMatthieu Baerts (NGI0) <matttbe@kernel.org>
Fri, 24 May 2024 16:30:57 +0000 (18:30 +0200)
committerJakub Kicinski <kuba@kernel.org>
Tue, 28 May 2024 00:12:50 +0000 (17:12 -0700)
These tests are flaky since their introduction. This might be less or
not visible depending on the CI running the tests, especially if it is
also busy doing other tasks in parallel.

A first analysis shown that the transfer can be slowed down when there
are some re-injections at the MPTCP level. Such re-injections can of
course happen, and disturb the transfer, but it looks strange to have
them in this lab. That could be caused by the kernel having access to
less CPU cycles -- e.g. when other activities are executed in parallel
-- or by a misinterpretation on the MPTCP packet scheduler side.

While this is being investigated, the tests are marked as flaky not to
create noises in other CIs.

Fixes: 219d04992b68 ("mptcp: push pending frames when subflow has free space")
Link: https://github.com/multipath-tcp/mptcp_net-next/issues/475
Reviewed-by: Mat Martineau <martineau@kernel.org>
Signed-off-by: Matthieu Baerts (NGI0) <matttbe@kernel.org>
Link: https://lore.kernel.org/r/20240524-upstream-net-20240524-selftests-mptcp-flaky-v1-2-a352362f3f8e@kernel.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
tools/testing/selftests/net/mptcp/simult_flows.sh

index 4b14b4412166b5db79ea6be28c009b536a8136b8..f74e1c3c126d18821ebba2968ed3f25b9f90c506 100755 (executable)
@@ -244,7 +244,7 @@ run_test()
        do_transfer $small $large $time
        lret=$?
        mptcp_lib_result_code "${lret}" "${msg}"
-       if [ $lret -ne 0 ]; then
+       if [ $lret -ne 0 ] && ! mptcp_lib_subtest_is_flaky; then
                ret=$lret
                [ $bail -eq 0 ] || exit $ret
        fi
@@ -254,7 +254,7 @@ run_test()
        do_transfer $large $small $time
        lret=$?
        mptcp_lib_result_code "${lret}" "${msg}"
-       if [ $lret -ne 0 ]; then
+       if [ $lret -ne 0 ] && ! mptcp_lib_subtest_is_flaky; then
                ret=$lret
                [ $bail -eq 0 ] || exit $ret
        fi
@@ -290,7 +290,7 @@ run_test 10 10 0 0 "balanced bwidth"
 run_test 10 10 1 25 "balanced bwidth with unbalanced delay"
 
 # we still need some additional infrastructure to pass the following test-cases
-run_test 10 3 0 0 "unbalanced bwidth"
+MPTCP_LIB_SUBTEST_FLAKY=1 run_test 10 3 0 0 "unbalanced bwidth"
 run_test 10 3 1 25 "unbalanced bwidth with unbalanced delay"
 run_test 10 3 25 1 "unbalanced bwidth with opposed, unbalanced delay"