selftests: mptcp: add mptcp_lib_wait_local_port_listen
authorGeliang Tang <geliang.tang@suse.com>
Tue, 28 Nov 2023 23:18:59 +0000 (15:18 -0800)
committerJakub Kicinski <kuba@kernel.org>
Thu, 30 Nov 2023 04:06:19 +0000 (20:06 -0800)
To avoid duplicated code in different MPTCP selftests, we can add
and use helpers defined in mptcp_lib.sh.

wait_local_port_listen() helper is defined in diag.sh, mptcp_connect.sh,
mptcp_join.sh and simult_flows.sh, export it into mptcp_lib.sh and
rename it with mptcp_lib_ prefix. Use this new helper in all these
scripts.

Note: We only have IPv4 connections in this helper, not looking at IPv6
(tcp6) but that's OK because we only have IPv4 connections here in diag.sh.

Reviewed-by: Matthieu Baerts <matttbe@kernel.org>
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
Signed-off-by: Mat Martineau <martineau@kernel.org>
Link: https://lore.kernel.org/r/20231128-send-net-next-2023107-v4-15-8d6b94150f6b@kernel.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
tools/testing/selftests/net/mptcp/diag.sh
tools/testing/selftests/net/mptcp/mptcp_connect.sh
tools/testing/selftests/net/mptcp/mptcp_join.sh
tools/testing/selftests/net/mptcp/mptcp_lib.sh
tools/testing/selftests/net/mptcp/simult_flows.sh

index 85a8ee9395b39af8e373675f727132abb81f4c49..95b498efacd1f21c84bd75838cf73f1370665fe1 100755 (executable)
@@ -182,23 +182,6 @@ chk_msk_inuse()
        __chk_nr get_msk_inuse $expected "$msg" 0
 }
 
-# $1: ns, $2: port
-wait_local_port_listen()
-{
-       local listener_ns="${1}"
-       local port="${2}"
-
-       local port_hex i
-
-       port_hex="$(printf "%04X" "${port}")"
-       for i in $(seq 10); do
-               ip netns exec "${listener_ns}" cat /proc/net/tcp | \
-                       awk "BEGIN {rc=1} {if (\$2 ~ /:${port_hex}\$/ && \$4 ~ /0A/) {rc=0; exit}} END {exit rc}" &&
-                       break
-               sleep 0.1
-       done
-}
-
 wait_connected()
 {
        local listener_ns="${1}"
@@ -222,7 +205,7 @@ echo "a" | \
                ip netns exec $ns \
                        ./mptcp_connect -p 10000 -l -t ${timeout_poll} -w 20 \
                                0.0.0.0 >/dev/null &
-wait_local_port_listen $ns 10000
+mptcp_lib_wait_local_port_listen $ns 10000
 chk_msk_nr 0 "no msk on netns creation"
 chk_msk_listen 10000
 
@@ -245,7 +228,7 @@ echo "a" | \
                ip netns exec $ns \
                        ./mptcp_connect -p 10001 -l -s TCP -t ${timeout_poll} -w 20 \
                                0.0.0.0 >/dev/null &
-wait_local_port_listen $ns 10001
+mptcp_lib_wait_local_port_listen $ns 10001
 echo "b" | \
        timeout ${timeout_test} \
                ip netns exec $ns \
@@ -266,7 +249,7 @@ for I in `seq 1 $NR_CLIENTS`; do
                                ./mptcp_connect -p $((I+10001)) -l -w 20 \
                                        -t ${timeout_poll} 0.0.0.0 >/dev/null &
 done
-wait_local_port_listen $ns $((NR_CLIENTS + 10001))
+mptcp_lib_wait_local_port_listen $ns $((NR_CLIENTS + 10001))
 
 for I in `seq 1 $NR_CLIENTS`; do
        echo "b" | \
index 537f180aa51e43118cf35146d8224495006d6ec3..7898d62fce0b5b3e7460a251274924cb59b97079 100755 (executable)
@@ -310,23 +310,6 @@ do_ping()
        return 0
 }
 
-# $1: ns, $2: port
-wait_local_port_listen()
-{
-       local listener_ns="${1}"
-       local port="${2}"
-
-       local port_hex i
-
-       port_hex="$(printf "%04X" "${port}")"
-       for i in $(seq 10); do
-               ip netns exec "${listener_ns}" cat /proc/net/tcp* | \
-                       awk "BEGIN {rc=1} {if (\$2 ~ /:${port_hex}\$/ && \$4 ~ /0A/) {rc=0; exit}} END {exit rc}" &&
-                       break
-               sleep 0.1
-       done
-}
-
 do_transfer()
 {
        local listener_ns="$1"
@@ -408,7 +391,7 @@ do_transfer()
                                $extra_args $local_addr < "$sin" > "$sout" &
        local spid=$!
 
-       wait_local_port_listen "${listener_ns}" "${port}"
+       mptcp_lib_wait_local_port_listen "${listener_ns}" "${port}"
 
        local start
        start=$(date +%s%3N)
index 420e4b3f9ad0650df7bb5d145cfaf89df8a3ca6e..8362ea454af3877f3c50a161b8b7538ea886edf7 100755 (executable)
@@ -580,24 +580,6 @@ link_failure()
        done
 }
 
-# $1: ns, $2: port
-wait_local_port_listen()
-{
-       local listener_ns="${1}"
-       local port="${2}"
-
-       local port_hex
-       port_hex="$(printf "%04X" "${port}")"
-
-       local i
-       for i in $(seq 10); do
-               ip netns exec "${listener_ns}" cat /proc/net/tcp* | \
-                       awk "BEGIN {rc=1} {if (\$2 ~ /:${port_hex}\$/ && \$4 ~ /0A/) {rc=0; exit}} END {exit rc}" &&
-                       break
-               sleep 0.1
-       done
-}
-
 rm_addr_count()
 {
        mptcp_lib_get_counter "${1}" "MPTcpExtRmAddr"
@@ -1082,7 +1064,7 @@ do_transfer()
        fi
        local spid=$!
 
-       wait_local_port_listen "${listener_ns}" "${port}"
+       mptcp_lib_wait_local_port_listen "${listener_ns}" "${port}"
 
        extra_cl_args="$extra_args $extra_cl_args"
        if [ "$test_linkfail" -eq 0 ];then
index 86f4003ab6f62d21462ebd1696391d7b14072dbd..022262a2cfe0ee59976d398f665c8057dfaea0d7 100644 (file)
@@ -280,3 +280,21 @@ mptcp_lib_check_transfer() {
 
        return 0
 }
+
+# $1: ns, $2: port
+mptcp_lib_wait_local_port_listen() {
+       local listener_ns="${1}"
+       local port="${2}"
+
+       local port_hex
+       port_hex="$(printf "%04X" "${port}")"
+
+       local _
+       for _ in $(seq 10); do
+               ip netns exec "${listener_ns}" cat /proc/net/tcp* | \
+                       awk "BEGIN {rc=1} {if (\$2 ~ /:${port_hex}\$/ && \$4 ~ /0A/) \
+                            {rc=0; exit}} END {exit rc}" &&
+                       break
+               sleep 0.1
+       done
+}
index ce9203b817f88c906089955795e0ec4150ec3a10..ae8ad5d6fb9dac680573b4207a67781e18773c09 100755 (executable)
@@ -123,23 +123,6 @@ setup()
        grep -q ' kmemleak_init$\| lockdep_init$\| kasan_init$\| prove_locking$' /proc/kallsyms && slack=$((slack+550))
 }
 
-# $1: ns, $2: port
-wait_local_port_listen()
-{
-       local listener_ns="${1}"
-       local port="${2}"
-
-       local port_hex i
-
-       port_hex="$(printf "%04X" "${port}")"
-       for i in $(seq 10); do
-               ip netns exec "${listener_ns}" cat /proc/net/tcp* | \
-                       awk "BEGIN {rc=1} {if (\$2 ~ /:${port_hex}\$/ && \$4 ~ /0A/) {rc=0; exit}} END {exit rc}" &&
-                       break
-               sleep 0.1
-       done
-}
-
 do_transfer()
 {
        local cin=$1
@@ -179,7 +162,7 @@ do_transfer()
                                0.0.0.0 < "$sin" > "$sout" &
        local spid=$!
 
-       wait_local_port_listen "${ns3}" "${port}"
+       mptcp_lib_wait_local_port_listen "${ns3}" "${port}"
 
        timeout ${timeout_test} \
                ip netns exec ${ns1} \