diff options
author | cinap_lenrek <cinap_lenrek@localhost> | 2011-05-03 11:25:13 +0000 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@localhost> | 2011-05-03 11:25:13 +0000 |
commit | 458120dd40db6b4df55a4e96b650e16798ef06a0 (patch) | |
tree | 8f82685be24fef97e715c6f5ca4c68d34d5074ee /sys/lib/python/test/test_wait4.py | |
parent | 3a742c699f6806c1145aea5149bf15de15a0afd7 (diff) |
add hg and python
Diffstat (limited to 'sys/lib/python/test/test_wait4.py')
-rw-r--r-- | sys/lib/python/test/test_wait4.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/sys/lib/python/test/test_wait4.py b/sys/lib/python/test/test_wait4.py new file mode 100644 index 000000000..9f7fc14a6 --- /dev/null +++ b/sys/lib/python/test/test_wait4.py @@ -0,0 +1,37 @@ +"""This test checks for correct wait4() behavior. +""" + +import os +import time +from test.fork_wait import ForkWait +from test.test_support import TestSkipped, run_unittest, reap_children + +try: + os.fork +except AttributeError: + raise TestSkipped, "os.fork not defined -- skipping test_wait4" + +try: + os.wait4 +except AttributeError: + raise TestSkipped, "os.wait4 not defined -- skipping test_wait4" + +class Wait4Test(ForkWait): + def wait_impl(self, cpid): + for i in range(10): + # wait4() 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.wait4(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)) + self.assertTrue(rusage) + +def test_main(): + run_unittest(Wait4Test) + reap_children() + +if __name__ == "__main__": + test_main() |