]> granicus.if.org Git - python/commitdiff
Issue9670: Back out changeset b0d2b696da19; test fails on other platforms
authorNed Deily <nad@acm.org>
Sat, 9 Apr 2011 21:59:30 +0000 (14:59 -0700)
committerNed Deily <nad@acm.org>
Sat, 9 Apr 2011 21:59:30 +0000 (14:59 -0700)
and on OS X with pydebug.

Lib/test/test_threading.py
Misc/NEWS
Python/thread_pthread.h

index 4c9f093745bd5b85b2dd12afb6da3c2d562a04c9..0062634f7e722b51aa2515d030a77351ce4adeb8 100644 (file)
@@ -666,36 +666,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)
index 034f821ba8db19c416392b4cbe4f66685bed8915..ee75bdad2c73755cb5632d2222824d14d6b41cf0 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -9,11 +9,6 @@ What's New in Python 2.7.2?
 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.
index b58e7a18c7305c1867fde1e98eb5814d09920b5e..ef49a308497a2e53ede4475c2f8684e271f77abf 100644 (file)
 #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 */