mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
Issue9670: Merge backout from 3.2.
This commit is contained in:
commit
4e6aba6f63
3 changed files with 0 additions and 47 deletions
|
@ -689,36 +689,6 @@ class ThreadingExceptionTests(BaseTestCase):
|
|||
lock = threading.Lock()
|
||||
self.assertRaises(RuntimeError, lock.release)
|
||||
|
||||
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)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue