diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2011-02-21 21:55:48 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2011-02-21 21:55:48 (GMT) |
commit | ce58dc7b166a4859f7e6e3483ac59fa679d78be9 (patch) | |
tree | 1d64ce745bfba451255ca99da741cb8acfd6be23 | |
parent | 5ed8b2c737a71d6fd56757bd9fe108f2cf886664 (diff) | |
download | cpython-ce58dc7b166a4859f7e6e3483ac59fa679d78be9.zip cpython-ce58dc7b166a4859f7e6e3483ac59fa679d78be9.tar.gz cpython-ce58dc7b166a4859f7e6e3483ac59fa679d78be9.tar.bz2 |
Issue #10826: Prevent sporadic failure in test_subprocess on Solaris due
to open door files.
-rw-r--r-- | Lib/test/subprocessdata/fd_status.py | 24 | ||||
-rw-r--r-- | Lib/test/test_subprocess.py | 7 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 15 insertions, 19 deletions
diff --git a/Lib/test/subprocessdata/fd_status.py b/Lib/test/subprocessdata/fd_status.py index 083b2f9..1f61e13 100644 --- a/Lib/test/subprocessdata/fd_status.py +++ b/Lib/test/subprocessdata/fd_status.py @@ -3,22 +3,22 @@ file descriptors on stdout.""" import errno import os -import fcntl try: _MAXFD = os.sysconf("SC_OPEN_MAX") except: _MAXFD = 256 -def isopen(fd): - """Return True if the fd is open, and False otherwise""" - try: - fcntl.fcntl(fd, fcntl.F_GETFD, 0) - except IOError as e: - if e.errno == errno.EBADF: - return False - raise - return True - if __name__ == "__main__": - print(','.join(str(fd) for fd in range(0, _MAXFD) if isopen(fd))) + fds = [] + for fd in range(0, _MAXFD): + try: + st = os.fstat(fd) + except OSError as e: + if e.errno == errno.EBADF: + continue + raise + # Ignore Solaris door files + if st.st_mode & 0xF000 != 0xd000: + fds.append(fd) + print(','.join(map(str, fds))) diff --git a/Lib/test/test_subprocess.py b/Lib/test/test_subprocess.py index cf6684d..4b58308 100644 --- a/Lib/test/test_subprocess.py +++ b/Lib/test/test_subprocess.py @@ -1156,9 +1156,6 @@ class POSIXProcessTestCase(BaseTestCase): open_fds = set() - if support.verbose: - print(" -- maxfd =", subprocess.MAXFD) - for x in range(5): fds = os.pipe() self.addCleanup(os.close, fds[0]) @@ -1173,10 +1170,6 @@ class POSIXProcessTestCase(BaseTestCase): remaining_fds = set(map(int, output.split(b','))) to_be_closed = open_fds - {fd} - # Temporary debug output for intermittent failures - if support.verbose: - print(" -- fds that should have been closed:", to_be_closed) - print(" -- fds that remained open:", remaining_fds) self.assertIn(fd, remaining_fds, "fd to be passed not passed") self.assertFalse(remaining_fds & to_be_closed, @@ -45,6 +45,9 @@ Build Tests ----- +- Issue #10826: Prevent sporadic failure in test_subprocess on Solaris due + to open door files. + - Issue #10990: Prevent tests from clobbering a set trace function. |