]> granicus.if.org Git - python/commitdiff
Replace a Lock with a better suited Event.
authorAntoine Pitrou <solipsis@pitrou.net>
Sun, 25 Apr 2010 21:15:50 +0000 (21:15 +0000)
committerAntoine Pitrou <solipsis@pitrou.net>
Sun, 25 Apr 2010 21:15:50 +0000 (21:15 +0000)
Lib/test/test_httpservers.py

index 287ad532e6707b3a99b52868d2eb4e4f529b0f72..e392aeedfec02b57700f58bd5df3daba9f27afe3 100644 (file)
@@ -33,14 +33,14 @@ class TestServerThread(threading.Thread):
         threading.Thread.__init__(self)
         self.request_handler = request_handler
         self.test_object = test_object
-        self.test_object.lock.acquire()
 
     def run(self):
         self.server = HTTPServer(('', 0), self.request_handler)
         self.test_object.PORT = self.server.socket.getsockname()[1]
-        self.test_object.lock.release()
+        self.test_object.server_started.set()
+        self.test_object = None
         try:
-            self.server.serve_forever()
+            self.server.serve_forever(0.05)
         finally:
             self.server.server_close()
 
@@ -52,13 +52,12 @@ class BaseTestCase(unittest.TestCase):
     def setUp(self):
         self._threads = test_support.threading_setup()
         os.environ = test_support.EnvironmentVarGuard()
-        self.lock = threading.Lock()
+        self.server_started = threading.Event()
         self.thread = TestServerThread(self, self.request_handler)
         self.thread.start()
-        self.lock.acquire()
+        self.server_started.wait()
 
     def tearDown(self):
-        self.lock.release()
         self.thread.stop()
         os.environ.__exit__()
         test_support.threading_cleanup(*self._threads)