diff options
| author | Ned Deily <nad@acm.org> | 2011-05-28 00:36:12 -0700 | 
|---|---|---|
| committer | Ned Deily <nad@acm.org> | 2011-05-28 00:36:12 -0700 | 
| commit | 056f5b9dadd834c26fc6deb87a831b6a3d9f4bf7 (patch) | |
| tree | a563c655664f1f18e2eb349064b8d0e276bf4104 /Lib/test/test_threading.py | |
| parent | a290bac5b1cc415ce4efd50525870c0c505c9840 (diff) | |
| parent | 9a7c524dc613595e0d88b3e22b0e49b69467ffc4 (diff) | |
| download | cpython-git-056f5b9dadd834c26fc6deb87a831b6a3d9f4bf7.tar.gz | |
Issue #9670: Increase the default stack size for secondary threads on
Mac OS X and FreeBSD to reduce the chances of a crash instead of a
"maximum recursion depth" RuntimeError exception.
(patch by Ronald Oussoren)
Diffstat (limited to 'Lib/test/test_threading.py')
| -rw-r--r-- | Lib/test/test_threading.py | 32 | 
1 files changed, 32 insertions, 0 deletions
| diff --git a/Lib/test/test_threading.py b/Lib/test/test_threading.py index 04c3598cba..416d95f68d 100644 --- a/Lib/test/test_threading.py +++ b/Lib/test/test_threading.py @@ -12,6 +12,7 @@ import unittest  import weakref  import os  from test.script_helper import assert_python_ok, assert_python_failure +import subprocess  from test import lock_tests @@ -691,6 +692,37 @@ class ThreadingExceptionTests(BaseTestCase):          thread.start()          self.assertRaises(RuntimeError, setattr, thread, "daemon", True) +    @unittest.skipUnless(sys.platform == 'darwin', 'test macosx problem') +    def test_recursion_limit(self): +        # Issue 9670 +        # test that excessive recursion within a non-main thread causes +        # an exception rather than crashing the interpreter on platforms +        # like Mac OS X or FreeBSD which have small default stack sizes +        # for threads +        script = """if True: +            import threading + +            def recurse(): +                return recurse() + +            def outer(): +                try: +                    recurse() +                except RuntimeError: +                    pass + +            w = threading.Thread(target=outer) +            w.start() +            w.join() +            print('end of main thread') +            """ +        expected_output = "end of main thread\n" +        p = subprocess.Popen([sys.executable, "-c", script], +                             stdout=subprocess.PIPE) +        stdout, stderr = p.communicate() +        data = stdout.decode().replace('\r', '') +        self.assertEqual(p.returncode, 0, "Unexpected error") +        self.assertEqual(data, expected_output)  class LockTests(lock_tests.LockTests):      locktype = staticmethod(threading.Lock) | 
