Merged revisions 80480 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r80480 | antoine.pitrou | 2010-04-25 23:15:50 +0200 (dim., 25 avril 2010) | 3 lines

  Replace a Lock with a better suited Event.
........
This commit is contained in:
Antoine Pitrou 2010-04-25 22:19:43 +00:00
parent 3bcba8e288
commit 08911bd33e
1 changed files with 5 additions and 6 deletions

View File

@ -34,14 +34,14 @@ class TestServerThread(threading.Thread):
threading.Thread.__init__(self) threading.Thread.__init__(self)
self.request_handler = request_handler self.request_handler = request_handler
self.test_object = test_object self.test_object = test_object
self.test_object.lock.acquire()
def run(self): def run(self):
self.server = HTTPServer(('', 0), self.request_handler) self.server = HTTPServer(('', 0), self.request_handler)
self.test_object.PORT = self.server.socket.getsockname()[1] 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: try:
self.server.serve_forever() self.server.serve_forever(0.05)
finally: finally:
self.server.server_close() self.server.server_close()
@ -53,13 +53,12 @@ class BaseTestCase(unittest.TestCase):
def setUp(self): def setUp(self):
self._threads = support.threading_setup() self._threads = support.threading_setup()
os.environ = support.EnvironmentVarGuard() os.environ = support.EnvironmentVarGuard()
self.lock = threading.Lock() self.server_started = threading.Event()
self.thread = TestServerThread(self, self.request_handler) self.thread = TestServerThread(self, self.request_handler)
self.thread.start() self.thread.start()
self.lock.acquire() self.server_started.wait()
def tearDown(self): def tearDown(self):
self.lock.release()
self.thread.stop() self.thread.stop()
os.environ.__exit__() os.environ.__exit__()
support.threading_cleanup(*self._threads) support.threading_cleanup(*self._threads)