| """This test checks for correct wait3() behavior. | |
| """ | |
| import os | |
| import time | |
| import unittest | |
| from test.fork_wait import ForkWait | |
| from test.test_support import run_unittest, reap_children | |
| try: | |
| os.fork | |
| except AttributeError: | |
| raise unittest.SkipTest, "os.fork not defined -- skipping test_wait3" | |
| try: | |
| os.wait3 | |
| except AttributeError: | |
| raise unittest.SkipTest, "os.wait3 not defined -- skipping test_wait3" | |
| class Wait3Test(ForkWait): | |
| def wait_impl(self, cpid): | |
| for i in range(10): | |
| # wait3() 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, rusage = os.wait3(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)) | |
| self.assertTrue(rusage) | |
| def test_main(): | |
| run_unittest(Wait3Test) | |
| reap_children() | |
| if __name__ == "__main__": | |
| test_main() |