]> granicus.if.org Git - python/commitdiff
Don't use a sleep to wait for the server to be ready; this caused
authorGuido van Rossum <guido@python.org>
Mon, 23 Jul 2007 01:49:28 +0000 (01:49 +0000)
committerGuido van Rossum <guido@python.org>
Mon, 23 Jul 2007 01:49:28 +0000 (01:49 +0000)
problems on my OSX laptop.  use a condition variable instead.

Lib/test/test_poplib.py

index 35ff636b14a81d7db67f2b12abbc1ef12d9389af..ef8565c57fc3af726d261e31111336607faedb8e 100644 (file)
@@ -7,12 +7,13 @@ from unittest import TestCase
 from test import test_support
 
 
-def server(evt):
+def server(ready, evt):
     serv = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
     serv.settimeout(3)
     serv.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
     serv.bind(("", 9091))
     serv.listen(5)
+    ready.set()
     try:
         conn, addr = serv.accept()
     except socket.timeout:
@@ -28,8 +29,9 @@ class GeneralTests(TestCase):
 
     def setUp(self):
         self.evt = threading.Event()
-        threading.Thread(target=server, args=(self.evt,)).start()
-        time.sleep(.1)
+        self.ready = threading.Event()
+        threading.Thread(target=server, args=(self.ready, self.evt,)).start()
+        self.ready.wait()
 
     def tearDown(self):
         self.evt.wait()