]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-45187: Fix dangling threads in test_socket.CreateServerFunctionalTest (GH-28422)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Fri, 17 Sep 2021 19:16:03 +0000 (12:16 -0700)
committerGitHub <noreply@github.com>
Fri, 17 Sep 2021 19:16:03 +0000 (12:16 -0700)
(cherry picked from commit 51ebb7f4f5e9bdcf8279a1d91be9569706f6bead)

Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
Lib/test/test_socket.py

index b6da4d09feece69957f8ad90235295de4a6c6ef0..5c15648b605c67d3abc4dd63caecfd69c0cc6da1 100755 (executable)
@@ -6492,13 +6492,6 @@ class CreateServerTest(unittest.TestCase):
 class CreateServerFunctionalTest(unittest.TestCase):
     timeout = support.LOOPBACK_TIMEOUT
 
-    def setUp(self):
-        self.thread = None
-
-    def tearDown(self):
-        if self.thread is not None:
-            self.thread.join(self.timeout)
-
     def echo_server(self, sock):
         def run(sock):
             with sock:
@@ -6512,8 +6505,9 @@ class CreateServerFunctionalTest(unittest.TestCase):
 
         event = threading.Event()
         sock.settimeout(self.timeout)
-        self.thread = threading.Thread(target=run, args=(sock, ))
-        self.thread.start()
+        thread = threading.Thread(target=run, args=(sock, ))
+        thread.start()
+        self.addCleanup(thread.join, self.timeout)
         event.set()
 
     def echo_client(self, addr, family):