mirror of https://github.com/python/cpython.git
Issue #9670: merge with 3.2
This commit is contained in:
commit
15012a67d2
|
@ -677,6 +677,36 @@ def test_daemonize_active_thread(self):
|
||||||
thread.start()
|
thread.start()
|
||||||
self.assertRaises(RuntimeError, setattr, thread, "daemon", True)
|
self.assertRaises(RuntimeError, setattr, thread, "daemon", True)
|
||||||
|
|
||||||
|
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):
|
class LockTests(lock_tests.LockTests):
|
||||||
locktype = staticmethod(threading.Lock)
|
locktype = staticmethod(threading.Lock)
|
||||||
|
|
|
@ -10,6 +10,11 @@ What's New in Python 3.2.1?
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- 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.
|
||||||
|
(original patch by Ronald Oussoren)
|
||||||
|
|
||||||
- Issue #11650: PyOS_StdioReadline() retries fgets() if it was interrupted
|
- Issue #11650: PyOS_StdioReadline() retries fgets() if it was interrupted
|
||||||
(EINTR), for example if the program is stopped with CTRL+z on Mac OS X. Patch
|
(EINTR), for example if the program is stopped with CTRL+z on Mac OS X. Patch
|
||||||
written by Charles-Francois Natali.
|
written by Charles-Francois Natali.
|
||||||
|
|
|
@ -18,6 +18,18 @@
|
||||||
#ifndef THREAD_STACK_SIZE
|
#ifndef THREAD_STACK_SIZE
|
||||||
#define THREAD_STACK_SIZE 0 /* use default stack size */
|
#define THREAD_STACK_SIZE 0 /* use default stack size */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if (defined(__APPLE__) || defined(__FreeBSD__)) && defined(THREAD_STACK_SIZE) && THREAD_STACK_SIZE == 0
|
||||||
|
/* The default stack size for new threads on OSX is small enough that
|
||||||
|
* we'll get hard crashes instead of 'maximum recursion depth exceeded'
|
||||||
|
* exceptions.
|
||||||
|
*
|
||||||
|
* The default stack size below is the minimal stack size where a
|
||||||
|
* simple recursive function doesn't cause a hard crash.
|
||||||
|
*/
|
||||||
|
#undef THREAD_STACK_SIZE
|
||||||
|
#define THREAD_STACK_SIZE 0x100000
|
||||||
|
#endif
|
||||||
/* for safety, ensure a viable minimum stacksize */
|
/* for safety, ensure a viable minimum stacksize */
|
||||||
#define THREAD_STACK_MIN 0x8000 /* 32kB */
|
#define THREAD_STACK_MIN 0x8000 /* 32kB */
|
||||||
#else /* !_POSIX_THREAD_ATTR_STACKSIZE */
|
#else /* !_POSIX_THREAD_ATTR_STACKSIZE */
|
||||||
|
|
Loading…
Reference in New Issue