mirror of
https://github.com/python/cpython.git
synced 2025-12-04 00:30:19 +00:00
The hppa ubuntu box sometimes hangs forever in these tests. My guess
is that the wait is failing for some reason. Use WNOHANG, so we won't wait until the buildbot kills the test suite. I haven't been able to reproduce the failure, so I'm not sure if this will help or not. Hopefully, this change will cause the test to fail, rather than hang. That will be better since we will get the rest of the test results. It may also help us debug the real problem.
This commit is contained in:
parent
9602cc2aa4
commit
10b835c401
4 changed files with 32 additions and 5 deletions
|
|
@ -2,6 +2,7 @@
|
|||
"""
|
||||
|
||||
import os
|
||||
import time
|
||||
from test.fork_wait import ForkWait
|
||||
from test.test_support import TestSkipped, run_unittest
|
||||
|
||||
|
|
@ -12,7 +13,14 @@ except AttributeError:
|
|||
|
||||
class ForkTest(ForkWait):
|
||||
def wait_impl(self, cpid):
|
||||
spid, status = os.waitpid(cpid, 0)
|
||||
for i in range(10):
|
||||
# waitpid() shouldn't hang, but some of the buildbots seem to hang
|
||||
# in the forking tests. This is an attempt to fix the problem.
|
||||
spid, status = os.waitpid(cpid, os.WNOHANG)
|
||||
if spid == cpid:
|
||||
break
|
||||
time.sleep(1.0)
|
||||
|
||||
self.assertEqual(spid, cpid)
|
||||
self.assertEqual(status, 0, "cause = %d, exit = %d" % (status&0xff, status>>8))
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue