asyncio: Log an error if a Task is destroyed while it is still pending

This commit is contained in:
Victor Stinner 2014-06-24 22:37:53 +02:00
parent 4c945fe9e9
commit a02f81ff17
4 changed files with 60 additions and 4 deletions

View file

@ -32,6 +32,7 @@
_DEBUG = (not sys.flags.ignore_environment
and bool(os.environ.get('PYTHONASYNCIODEBUG')))
_PY34 = (sys.version_info >= (3, 4))
_PY35 = (sys.version_info >= (3, 5))
@ -181,6 +182,18 @@ def __init__(self, coro, *, loop=None):
self._loop.call_soon(self._step)
self.__class__._all_tasks.add(self)
# On Python 3.3 or older, objects with a destructor part of a reference
# cycle are never destroyed. It's not more the case on Python 3.4 thanks to
# the PEP 442.
if _PY34:
def __del__(self):
if self._state == futures._PENDING:
self._loop.call_exception_handler({
'task': self,
'message': 'Task was destroyed but it is pending!',
})
futures.Future.__del__(self)
def __repr__(self):
res = super().__repr__()
if (self._must_cancel and