mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
Use an event variable to wait for the server to be ready, rather than sleep(0.1).
This commit is contained in:
parent
6ae6ba09ea
commit
efdca3e071
1 changed files with 5 additions and 3 deletions
|
@ -7,12 +7,13 @@ from unittest import TestCase
|
||||||
from test import test_support
|
from test import test_support
|
||||||
|
|
||||||
|
|
||||||
def server(evt):
|
def server(evt, ready):
|
||||||
serv = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
serv = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||||
serv.settimeout(3)
|
serv.settimeout(3)
|
||||||
serv.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
serv.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||||
serv.bind(("", 9091))
|
serv.bind(("", 9091))
|
||||||
serv.listen(5)
|
serv.listen(5)
|
||||||
|
ready.set()
|
||||||
try:
|
try:
|
||||||
conn, addr = serv.accept()
|
conn, addr = serv.accept()
|
||||||
except socket.timeout:
|
except socket.timeout:
|
||||||
|
@ -25,8 +26,9 @@ class GeneralTests(TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.evt = threading.Event()
|
self.evt = threading.Event()
|
||||||
threading.Thread(target=server, args=(self.evt,)).start()
|
ready = threading.Event()
|
||||||
time.sleep(.1)
|
threading.Thread(target=server, args=(self.evt, ready)).start()
|
||||||
|
ready.wait()
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
self.evt.wait()
|
self.evt.wait()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue