diff options
Diffstat (limited to 'Lib/dos-8x3/test_for.py')
-rw-r--r-- | Lib/dos-8x3/test_for.py | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/Lib/dos-8x3/test_for.py b/Lib/dos-8x3/test_for.py new file mode 100644 index 0000000..67e30df --- /dev/null +++ b/Lib/dos-8x3/test_for.py @@ -0,0 +1,68 @@ +"""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 + +try: + os.fork +except AttributeError: + raise ImportError, "os.fork not defined -- skipping test_fork1" + +LONGSLEEP = 2 + +SHORTSLEEP = 0.5 + +NUM_THREADS = 4 + +alive = {} + +stop = 0 + +def f(id): + while not stop: + alive[id] = os.getpid() + try: + time.sleep(SHORTSLEEP) + except IOError: + pass + +def main(): + for i in range(NUM_THREADS): + thread.start_new(f, (i,)) + + time.sleep(LONGSLEEP) + + a = alive.keys() + a.sort() + assert a == range(NUM_THREADS) + + prefork_lives = alive.copy() + + cpid = os.fork() + + if cpid == 0: + # Child + time.sleep(LONGSLEEP) + n = 0 + for key in alive.keys(): + if alive[key] != prefork_lives[key]: + 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) + global stop + # Tell threads to die + stop = 1 + time.sleep(2*SHORTSLEEP) # Wait for threads to die + +main() |