diff options
author | Ned Deily <nad@acm.org> | 2011-04-09 21:53:47 (GMT) |
---|---|---|
committer | Ned Deily <nad@acm.org> | 2011-04-09 21:53:47 (GMT) |
commit | 2604e33f3002c48437df2f013a085197be8aba8d (patch) | |
tree | 4e7f49adee6015a274ced2d3b2a931ee0880ed93 | |
parent | 15012a67d25dbd1cee5e014be5f5f999c96c9c13 (diff) | |
parent | 45e47e58edf101e7865d4bdaa2261ce1421a4209 (diff) | |
download | cpython-2604e33f3002c48437df2f013a085197be8aba8d.zip cpython-2604e33f3002c48437df2f013a085197be8aba8d.tar.gz cpython-2604e33f3002c48437df2f013a085197be8aba8d.tar.bz2 |
Issue9670: Merge backout to 3.2.
-rw-r--r-- | Lib/test/test_threading.py | 30 | ||||
-rw-r--r-- | Misc/NEWS | 5 | ||||
-rw-r--r-- | Python/thread_pthread.h | 12 |
3 files changed, 0 insertions, 47 deletions
diff --git a/Lib/test/test_threading.py b/Lib/test/test_threading.py index 32f9e99..5f99b2e 100644 --- a/Lib/test/test_threading.py +++ b/Lib/test/test_threading.py @@ -677,36 +677,6 @@ class ThreadingExceptionTests(BaseTestCase): thread.start() 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): locktype = staticmethod(threading.Lock) @@ -10,11 +10,6 @@ What's New in Python 3.2.1? 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 (EINTR), for example if the program is stopped with CTRL+z on Mac OS X. Patch written by Charles-Francois Natali. diff --git a/Python/thread_pthread.h b/Python/thread_pthread.h index f120291..ffc791c 100644 --- a/Python/thread_pthread.h +++ b/Python/thread_pthread.h @@ -18,18 +18,6 @@ #ifndef THREAD_STACK_SIZE #define THREAD_STACK_SIZE 0 /* use default stack size */ #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 */ #define THREAD_STACK_MIN 0x8000 /* 32kB */ #else /* !_POSIX_THREAD_ATTR_STACKSIZE */ |