bpo-30106: Fix test_asyncore.test_quick_connect() (#1234)

test_quick_connect() runs a thread up to 50 seconds, whereas the
socket is connected in 0.2 second and then the thread is expected to
end in less than 3 second. On Linux, the thread ends quickly because
select() seems to always return quickly. On FreeBSD, sometimes
select() fails with timeout and so the thread runs much longer than
expected.

Fix the thread timeout to fix a race condition in the test.
This commit is contained in:
Victor Stinner 2017-04-21 13:51:53 +02:00 committed by GitHub
parent 35f3d240ee
commit a2c877c398
1 changed files with 2 additions and 1 deletions

View File

@ -781,8 +781,9 @@ class BaseTestAPI:
self.skipTest("test specific to AF_INET and AF_INET6")
server = BaseServer(self.family, self.addr)
# run the thread 500 ms: the socket should be connected in 200 ms
t = threading.Thread(target=lambda: asyncore.loop(timeout=0.1,
count=500))
count=5))
t.start()
try:
with socket.socket(self.family, socket.SOCK_STREAM) as s: