diff options
author | Gregory P. Smith <greg@krypto.org> | 2012-09-29 18:40:38 (GMT) |
---|---|---|
committer | Gregory P. Smith <greg@krypto.org> | 2012-09-29 18:40:38 (GMT) |
commit | 3905171f1ea778c60c74dd4b0318b894eda94d7f (patch) | |
tree | 1ff7802b4526cf3c617b89fa9c0ca3974627db67 /Lib/test/subprocessdata | |
parent | 53202504852bc97fc70c5715e936d22c5c5ba1e1 (diff) | |
download | cpython-3905171f1ea778c60c74dd4b0318b894eda94d7f.zip cpython-3905171f1ea778c60c74dd4b0318b894eda94d7f.tar.gz cpython-3905171f1ea778c60c74dd4b0318b894eda94d7f.tar.bz2 |
Fixes issue #15756: subprocess.poll() now properly handles errno.ECHILD
to return a returncode of 0 when the child has already exited or cannot
be waited on.
Diffstat (limited to 'Lib/test/subprocessdata')
-rw-r--r-- | Lib/test/subprocessdata/sigchild_ignore.py | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/Lib/test/subprocessdata/sigchild_ignore.py b/Lib/test/subprocessdata/sigchild_ignore.py index 6072aec..86320fb 100644 --- a/Lib/test/subprocessdata/sigchild_ignore.py +++ b/Lib/test/subprocessdata/sigchild_ignore.py @@ -1,6 +1,15 @@ -import signal, subprocess, sys +import signal, subprocess, sys, time # On Linux this causes os.waitpid to fail with OSError as the OS has already # reaped our child process. The wait() passing the OSError on to the caller # and causing us to exit with an error is what we are testing against. signal.signal(signal.SIGCHLD, signal.SIG_IGN) subprocess.Popen([sys.executable, '-c', 'print("albatross")']).wait() +# Also ensure poll() handles an errno.ECHILD appropriately. +p = subprocess.Popen([sys.executable, '-c', 'print("albatross")']) +num_polls = 0 +while p.poll() is None: + # Waiting for the process to finish. + time.sleep(0.01) # Avoid being a CPU busy loop. + num_polls += 1 + if num_polls > 3000: + raise RuntimeError('poll should have returned 0 within 30 seconds') |