]> git.ipfire.org Git - thirdparty/tornado.git/commitdiff
asyncio: Support Python 3.4.2 for compatibility with Debian jessie 2306/head
authorBen Darnell <ben@bendarnell.com>
Sun, 11 Mar 2018 17:20:26 +0000 (13:20 -0400)
committerBen Darnell <ben@bendarnell.com>
Sun, 11 Mar 2018 18:46:23 +0000 (14:46 -0400)
The ensure_future function was not introduced until 3.4.4, and
some exceptions were changed from AssertionError to RuntimeError in
3.4.3.

Fixes #2301

tornado/gen.py
tornado/ioloop.py
tornado/platform/asyncio.py
tornado/test/asyncio_test.py

index 762b44f9c91c1d6bf1c41c2e662bd065ed00edf7..0ef7c9fc50eff331ec6b5c0c953f83e3a75b7c09 100644 (file)
@@ -1292,7 +1292,12 @@ except ImportError:
                         break
         raise Return(_r)
 else:
-    _wrap_awaitable = asyncio.ensure_future
+    try:
+        _wrap_awaitable = asyncio.ensure_future
+    except AttributeError:
+        # asyncio.ensure_future was introduced in Python 3.4.4, but
+        # Debian jessie still ships with 3.4.2 so try the old name.
+        _wrap_awaitable = getattr(asyncio, 'async')
 
 
 def convert_yielded(yielded):
index b3fc35676960dbb9d929c0ed724997eedc0091a0..839e7ee54ef0431ff961e360f7537a008856aed6 100644 (file)
@@ -281,7 +281,7 @@ class IOLoop(Configurable):
         else:
             try:
                 loop = asyncio.get_event_loop()
-            except RuntimeError:
+            except (RuntimeError, AssertionError):
                 if not instance:
                     return None
                 raise
index 0d7eea3e57f4235ca5957e70dfccb2ee1caef657..b2ad9fe6ef030193689ebef8e719e60495bb5839 100644 (file)
@@ -104,7 +104,7 @@ class BaseAsyncIOLoop(IOLoop):
     def start(self):
         try:
             old_loop = asyncio.get_event_loop()
-        except RuntimeError:
+        except (RuntimeError, AssertionError):
             old_loop = None
         try:
             self._setup_logging()
@@ -211,7 +211,7 @@ class AsyncIOLoop(BaseAsyncIOLoop):
         if not self.is_current:
             try:
                 self.old_asyncio = asyncio.get_event_loop()
-            except RuntimeError:
+            except (RuntimeError, AssertionError):
                 self.old_asyncio = None
             self.is_current = True
         asyncio.set_event_loop(self.asyncio_loop)
@@ -270,7 +270,9 @@ class AnyThreadEventLoopPolicy(asyncio.DefaultEventLoopPolicy):
     def get_event_loop(self):
         try:
             return super().get_event_loop()
-        except RuntimeError:
+        except (RuntimeError, AssertionError):
+            # This was an AssertionError in python 3.4.2 (which ships with debian jessie)
+            # and changed to a RuntimeError in 3.4.3.
             # "There is no current event loop in thread %r"
             loop = self.new_event_loop()
             self.set_event_loop(loop)
index bbabb5212075bd4b1e560290d4aaccc8413bb1fd..41fda20d43fa94fca72065f470aca8cc7ebbdf09 100644 (file)
@@ -150,7 +150,7 @@ class AnyThreadEventLoopPolicyTest(unittest.TestCase):
     def run_policy_test(self, accessor, expected_type):
         # With the default policy, non-main threads don't get an event
         # loop.
-        self.assertRaises(RuntimeError,
+        self.assertRaises((RuntimeError, AssertionError),
                           self.executor.submit(accessor).result)
         # Set the policy and we can get a loop.
         asyncio.set_event_loop_policy(AnyThreadEventLoopPolicy())