summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAllison Henderson <achender@kernel.org>2026-05-03 22:41:41 -0700
committerJakub Kicinski <kuba@kernel.org>2026-05-05 19:19:54 -0700
commitec91483634fe9ae30ba50bc20e2050ce7eec2e8e (patch)
tree5bb37c37c65ef7d7377ecc8e237535a14d1a3654
parentc726bc68fffd2fe031eff258abd1283b063d0880 (diff)
selftests: rds: Stop tcpdump on timeout
The timeout signal handler for the rds selftests currently just exits when the time limit is exceeded, and forgets to stop the network dumps. Fix this by hoisting the tcpdump terminate commands into a helper function, and call it from the signal handler before exiting Bound proc.wait() with a timeout (and fall back to proc.kill()) so an unresponsive tcpdump cannot hang the timeout path itself. We also pop() tcpdump_procs as we iterate, so stop_pcaps() is safe to call from both the normal cleanup path and the signal handler, since the second invocation simply has nothing to do Signed-off-by: Allison Henderson <achender@kernel.org> Link: https://patch.msgid.link/20260504054143.4027538-9-achender@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org>
-rwxr-xr-xtools/testing/selftests/net/rds/test.py24
1 files changed, 19 insertions, 5 deletions
diff --git a/tools/testing/selftests/net/rds/test.py b/tools/testing/selftests/net/rds/test.py
index a7be57ef6ece..faf751863478 100755
--- a/tools/testing/selftests/net/rds/test.py
+++ b/tools/testing/selftests/net/rds/test.py
@@ -68,11 +68,29 @@ def netns_socket(netns, *sock_args):
u1.close()
return socket.fromfd(fds[0], *sock_args)
+def stop_pcaps():
+ """Stop tcpdump processes.
+
+ We use pop() here to drain the list in the event that the test
+ completes after the signal handler is fired. List will be empty
+ if logdir is not set
+ """
+ print("Stopping network packet captures")
+ while tcpdump_procs:
+ proc = tcpdump_procs.pop()
+ proc.terminate()
+ try:
+ proc.wait(timeout=5)
+ except subprocess.TimeoutExpired:
+ proc.kill()
+ proc.wait()
+
def signal_handler(_sig, _frame):
"""
Test timed out signal handler
"""
print('Test timed out')
+ stop_pcaps()
sys.exit(1)
#Parse out command line arguments. We take an optional
@@ -255,11 +273,7 @@ for s in sockets:
print(f"getsockopt(): {nr_success}/{nr_error}")
-if logdir is not None:
- print("Stopping network packet captures")
- for p in tcpdump_procs:
- p.terminate()
- p.wait()
+stop_pcaps()
# We're done sending and receiving stuff, now let's check if what
# we received is what we sent.