diff options
author | Guido van Rossum <guido@python.org> | 2000-02-25 19:25:05 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2000-02-25 19:25:05 (GMT) |
commit | f7221c3a7d889a854a6b5e4a8d8012d93742e6b6 (patch) | |
tree | 1b9a6404f91365a232e66f7c46e2575f5ea4fe54 /Lib/test/test_fork1.py | |
parent | 4985e409397f805b54e35658de1df55cd0343284 (diff) | |
download | cpython-f7221c3a7d889a854a6b5e4a8d8012d93742e6b6.zip cpython-f7221c3a7d889a854a6b5e4a8d8012d93742e6b6.tar.gz cpython-f7221c3a7d889a854a6b5e4a8d8012d93742e6b6.tar.bz2 |
Test case for fork1() behavior.
Only the main thread should survive in the child after a fork().
Diffstat (limited to 'Lib/test/test_fork1.py')
-rw-r--r-- | Lib/test/test_fork1.py | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/Lib/test/test_fork1.py b/Lib/test/test_fork1.py new file mode 100644 index 0000000..361664e --- /dev/null +++ b/Lib/test/test_fork1.py @@ -0,0 +1,54 @@ +"""This test checks for correct fork() behavior. + +We want fork1() semantics -- only the forking thread survives in the +child after a fork(). + +On some systems (e.g. Solaris without posix threads) we find that all +active threads survive in the child after a fork(); this is an error. + +""" + +import os, sys, time, thread + +LONGSLEEP = 2 + +SHORTSLEEP = 0.5 + +alive = {} + +def f(id): + while 1: + alive[id] = os.getpid() + try: + time.sleep(SHORTSLEEP) + except IOError: + pass + +def main(): + for i in range(4): + thread.start_new(f, (i,)) + + time.sleep(LONGSLEEP) + + a = alive.keys() + a.sort() + assert a == range(4) + + cpid = os.fork() + + if cpid == 0: + # Child + time.sleep(LONGSLEEP) + n = 0 + pid = os.getpid() + for key in alive.keys(): + if alive[key] == pid: + n = n+1 + os._exit(n) + else: + # Parent + spid, status = os.waitpid(cpid, 0) + assert spid == cpid + assert status == 0, "cause = %d, exit = %d" % (status&0xff, status>>8) + +main() |