Kaydet (Commit) f5e30d8b authored tarafından Antoine Pitrou's avatar Antoine Pitrou

Issue #18756: make test_urandom_failure more robust by executing its code in a subprocess

...@@ -1020,17 +1020,26 @@ class URandomTests(unittest.TestCase): ...@@ -1020,17 +1020,26 @@ class URandomTests(unittest.TestCase):
@unittest.skipUnless(resource, "test requires the resource module") @unittest.skipUnless(resource, "test requires the resource module")
def test_urandom_failure(self): def test_urandom_failure(self):
soft_limit, hard_limit = resource.getrlimit(resource.RLIMIT_NOFILE) # Check urandom() failing when it is not able to open /dev/random.
resource.setrlimit(resource.RLIMIT_NOFILE, (1, hard_limit)) # We spawn a new process to make the test more robust (if getrlimit()
try: # failed to restore the file descriptor limit after this, the whole
with self.assertRaises(OSError) as cm: # test suite would crash; this actually happened on the OS X Tiger
# buildbot).
code = """if 1:
import errno
import os
import resource
soft_limit, hard_limit = resource.getrlimit(resource.RLIMIT_NOFILE)
resource.setrlimit(resource.RLIMIT_NOFILE, (1, hard_limit))
try:
os.urandom(16) os.urandom(16)
self.assertEqual(cm.exception.errno, errno.EMFILE) except OSError as e:
finally: assert e.errno == errno.EMFILE, e.errno
# We restore the old limit as soon as possible. If doing it else:
# using addCleanup(), code running in between would fail raise AssertionError("OSError not raised")
# creating any file descriptor. """
resource.setrlimit(resource.RLIMIT_NOFILE, (soft_limit, hard_limit)) assert_python_ok('-c', code)
@contextlib.contextmanager @contextlib.contextmanager
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment