Skip to content

Commit

Permalink
selftests: mptcp: add fastclose testcase
Browse files Browse the repository at this point in the history
This patch added the self test for MP_FASTCLOSE. Reused the argument
addr_nr_ns2 of do_transfer() to pass the extra arguments '-I 2' to
mptcp_connect commands. Then mptcp_connect disconnected the
connections to trigger the MP_FASTCLOSE sending and receiving. Used
chk_fclose_nr to check the MP_FASTCLOSE mibs and used chk_rst_nr to
check the MP_RST mibs. This test used the test_linkfail value to make
1024KB test files.

The output looks like this:

Created /tmp/tmp.XB8sfv1hJ0 (size 1024 KB) containing data sent by client
Created /tmp/tmp.RtTDbzqrXI (size 1024 KB) containing data sent by server
001 fastclose test                syn[ ok ] - synack[ ok ] - ack[ ok ]
                                  ctx[ ok ] - fclzrx[ ok ]
                                  rtx[ ok ] - rstrx [ ok ]   invert

Signed-off-by: Geliang Tang <[email protected]>
Signed-off-by: Mat Martineau <[email protected]>
Signed-off-by: Jakub Kicinski <[email protected]>
  • Loading branch information
geliangtang authored and kuba-moo committed Mar 5, 2022
1 parent 34b572b commit 01542c9
Showing 1 changed file with 21 additions and 1 deletion.
22 changes: 21 additions & 1 deletion tools/testing/selftests/net/mptcp/mptcp_join.sh
Original file line number Diff line number Diff line change
Expand Up @@ -452,6 +452,12 @@ do_transfer()
extra_args="-r ${speed:6}"
fi

if [[ "${addr_nr_ns2}" = "fastclose_"* ]]; then
# disconnect
extra_args="$extra_args -I ${addr_nr_ns2:10}"
addr_nr_ns2=0
fi

local local_addr
if is_v6 "${connect_addr}"; then
local_addr="::"
Expand Down Expand Up @@ -2196,6 +2202,15 @@ fullmesh_tests()
chk_rm_nr 0 1
}

fastclose_tests()
{
reset
run_tests $ns1 $ns2 10.0.1.1 1024 0 fastclose_2
chk_join_nr "fastclose test" 0 0 0
chk_fclose_nr 1 1
chk_rst_nr 1 1 invert
}

all_tests()
{
subflows_tests
Expand All @@ -2213,6 +2228,7 @@ all_tests()
checksum_tests
deny_join_id0_tests
fullmesh_tests
fastclose_tests
}

# [$1: error message]
Expand All @@ -2239,6 +2255,7 @@ usage()
echo " -S checksum_tests"
echo " -d deny_join_id0_tests"
echo " -m fullmesh_tests"
echo " -z fastclose_tests"
echo " -c capture pcap files"
echo " -C enable data checksum"
echo " -i use ip mptcp"
Expand Down Expand Up @@ -2270,7 +2287,7 @@ if [ $do_all_tests -eq 1 ]; then
exit $ret
fi

while getopts 'fesltra64bpkdmchCSi' opt; do
while getopts 'fesltra64bpkdmchzCSi' opt; do
case $opt in
f)
subflows_tests
Expand Down Expand Up @@ -2317,6 +2334,9 @@ while getopts 'fesltra64bpkdmchCSi' opt; do
m)
fullmesh_tests
;;
z)
fastclose_tests
;;
c)
;;
C)
Expand Down

0 comments on commit 01542c9

Please sign in to comment.