From 7f9b1faeeed5de140c99940679732d54247862b9 Mon Sep 17 00:00:00 2001 From: Liz Fong-Jones Date: Tue, 24 Mar 2020 11:55:55 -0400 Subject: [PATCH] If <3.7 and no get_running_loop, return false. (#107) Some people have contextvars backported, so it's no longer a useful 3.7 canary; instead just probe directly for the method we use. --- beeline/__init__.py | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/beeline/__init__.py b/beeline/__init__.py index 6f91e0d..3582492 100644 --- a/beeline/__init__.py +++ b/beeline/__init__.py @@ -21,16 +21,16 @@ try: import asyncio - # The async functionality uses the contextvars module, added in - # Python 3.7 - import contextvars - assert contextvars + try: + asyncio.get_running_loop() # pylint: disable=no-member + except RuntimeError: + pass from beeline.aiotrace import AsyncioTracer, traced_impl, untraced assert untraced def in_async_code(): - """Return wether we are running inside an asynchronous task. + """Return whether we are running inside an asynchronous task. We use this information to determine which tracer implementation to use. @@ -42,9 +42,8 @@ def in_async_code(): except RuntimeError: return False -except ImportError: - # Use these non-async versions if we don't have asyncio or - # contextvars. +except (ImportError, AttributeError): + # Use these non-async versions if we don't have asyncio. from beeline.trace import traced_impl def in_async_code():