]> git.baikalelectronics.ru Git - kernel.git/commitdiff
mptcp: more stable diag self-tests
authorPaolo Abeni <pabeni@redhat.com>
Fri, 7 Aug 2020 16:31:00 +0000 (18:31 +0200)
committerDavid S. Miller <davem@davemloft.net>
Sat, 8 Aug 2020 00:25:38 +0000 (17:25 -0700)
During diag self-tests we introduce long wait in the mptcp test
program to give the script enough time to access the sockets
dump.

Such wait is introduced after shutting down one sockets end. Since
commit 93d3b913d64c ("mptcp: Use full MPTCP-level disconnect state
machine") if both sides shutdown the socket is correctly transitioned
into CLOSED status.

As a side effect some sockets are not dumped via the diag interface,
because the socket state (CLOSED) does not match the default filter, and
this cause self-tests instability.

Address the issue moving the above mentioned wait before shutting
down the socket.

Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/68
Fixes: 6aaaa43642d2 ("selftests/mptcp: add diag interface tests")
Tested-and-acked-by: Matthieu Baerts <matthieu.baerts@tessares.net>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
tools/testing/selftests/net/mptcp/mptcp_connect.c

index cad6f73a5fd01d49fdef2f6a7a710a60f14f4599..090620c3e10c52a736ebf90cc7ca7da8e7c3b212 100644 (file)
@@ -406,10 +406,11 @@ static int copyfd_io_poll(int infd, int peerfd, int outfd)
 
                                /* ... but we still receive.
                                 * Close our write side, ev. give some time
-                                * for address notification
+                                * for address notification and/or checking
+                                * the current status
                                 */
-                               if (cfg_join)
-                                       usleep(400000);
+                               if (cfg_wait)
+                                       usleep(cfg_wait);
                                shutdown(peerfd, SHUT_WR);
                        } else {
                                if (errno == EINTR)
@@ -427,7 +428,7 @@ static int copyfd_io_poll(int infd, int peerfd, int outfd)
        }
 
        /* leave some time for late join/announce */
-       if (cfg_wait)
+       if (cfg_join)
                usleep(cfg_wait);
 
        close(peerfd);