blob: 54580a90266931cb1171b512b9b9943498bc217f [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
Antoine Pitrou0c503c22013-07-04 21:03:10 +02006import sys
Neal Norwitz05a45592006-03-20 06:30:08 +00007from test.fork_wait import ForkWait
R. David Murray840ac922009-03-31 23:45:39 +00008from test.test_support import run_unittest, reap_children, get_attribute
Neal Norwitz05a45592006-03-20 06:30:08 +00009
R. David Murray840ac922009-03-31 23:45:39 +000010# If either of these do not exist, skip this test.
11get_attribute(os, 'fork')
12get_attribute(os, 'wait4')
Neal Norwitz05a45592006-03-20 06:30:08 +000013
Neal Norwitz05a45592006-03-20 06:30:08 +000014
15class Wait4Test(ForkWait):
16 def wait_impl(self, cpid):
Antoine Pitrou0c503c22013-07-04 21:03:10 +020017 option = os.WNOHANG
18 if sys.platform.startswith('aix'):
19 # Issue #11185: wait4 is broken on AIX and will always return 0
20 # with WNOHANG.
21 option = 0
Neal Norwitz84bc19a2006-07-07 06:03:15 +000022 for i in range(10):
23 # wait4() shouldn't hang, but some of the buildbots seem to hang
24 # in the forking tests. This is an attempt to fix the problem.
Antoine Pitrou0c503c22013-07-04 21:03:10 +020025 spid, status, rusage = os.wait4(cpid, option)
Neal Norwitz84bc19a2006-07-07 06:03:15 +000026 if spid == cpid:
27 break
28 time.sleep(1.0)
Neal Norwitz05a45592006-03-20 06:30:08 +000029 self.assertEqual(spid, cpid)
30 self.assertEqual(status, 0, "cause = %d, exit = %d" % (status&0xff, status>>8))
31 self.assertTrue(rusage)
32
33def test_main():
34 run_unittest(Wait4Test)
Neal Norwitzb15ac312006-06-29 04:10:08 +000035 reap_children()
Neal Norwitz05a45592006-03-20 06:30:08 +000036
37if __name__ == "__main__":
38 test_main()