blob: 60b89e8439aa293fe293bd6423ee8e227a14a9a3 [file] [log] [blame]
Neal Norwitz05a45592006-03-20 06:30:08 +00001"""This test checks for correct wait4() behavior.
2"""
3
4import os
Neal Norwitz84bc19a2006-07-07 06:03:15 +00005import time
Neal Norwitz05a45592006-03-20 06:30:08 +00006from test.fork_wait import ForkWait
Benjamin Petersonbec087f2009-03-26 21:10:30 +00007from test.test_support import run_unittest, reap_children
Neal Norwitz05a45592006-03-20 06:30:08 +00008
9try:
10 os.fork
11except AttributeError:
Benjamin Petersonbec087f2009-03-26 21:10:30 +000012 raise unittest.SkipTest, "os.fork not defined -- skipping test_wait4"
Neal Norwitz05a45592006-03-20 06:30:08 +000013
14try:
15 os.wait4
16except AttributeError:
Benjamin Petersonbec087f2009-03-26 21:10:30 +000017 raise unittest.SkipTest, "os.wait4 not defined -- skipping test_wait4"
Neal Norwitz05a45592006-03-20 06:30:08 +000018
19class Wait4Test(ForkWait):
20 def wait_impl(self, cpid):
Neal Norwitz84bc19a2006-07-07 06:03:15 +000021 for i in range(10):
22 # wait4() shouldn't hang, but some of the buildbots seem to hang
23 # in the forking tests. This is an attempt to fix the problem.
24 spid, status, rusage = os.wait4(cpid, os.WNOHANG)
25 if spid == cpid:
26 break
27 time.sleep(1.0)
Neal Norwitz05a45592006-03-20 06:30:08 +000028 self.assertEqual(spid, cpid)
29 self.assertEqual(status, 0, "cause = %d, exit = %d" % (status&0xff, status>>8))
30 self.assertTrue(rusage)
31
32def test_main():
33 run_unittest(Wait4Test)
Neal Norwitzb15ac312006-06-29 04:10:08 +000034 reap_children()
Neal Norwitz05a45592006-03-20 06:30:08 +000035
36if __name__ == "__main__":
37 test_main()