diff options
| author | Victor Stinner <victor.stinner@gmail.com> | 2015-01-29 17:50:58 +0100 | 
|---|---|---|
| committer | Victor Stinner <victor.stinner@gmail.com> | 2015-01-29 17:50:58 +0100 | 
| commit | 978a9afc6af6c137065bdcf7ae4ef5450e5b2ec2 (patch) | |
| tree | 54eb1a4cdf09be18b62c40e0e203a347c37c4cd6 /Lib/asyncio/unix_events.py | |
| parent | 3c0cf05901ea5cca0694734fd4a64b2bc267cb41 (diff) | |
| download | cpython-git-978a9afc6af6c137065bdcf7ae4ef5450e5b2ec2.tar.gz | |
Issue #23243, asyncio: Emit a ResourceWarning when an event loop or a transport
is not explicitly closed. Close also explicitly transports in test_sslproto.
Diffstat (limited to 'Lib/asyncio/unix_events.py')
| -rw-r--r-- | Lib/asyncio/unix_events.py | 19 | 
1 files changed, 19 insertions, 0 deletions
| diff --git a/Lib/asyncio/unix_events.py b/Lib/asyncio/unix_events.py index 7e1265a091..b06f1b2330 100644 --- a/Lib/asyncio/unix_events.py +++ b/Lib/asyncio/unix_events.py @@ -8,6 +8,7 @@ import stat  import subprocess  import sys  import threading +import warnings  from . import base_events @@ -353,6 +354,15 @@ class _UnixReadPipeTransport(transports.ReadTransport):          if not self._closing:              self._close(None) +    # On Python 3.3 and 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 sys.version_info >= (3, 4): +        def __del__(self): +            if self._pipe is not None: +                warnings.warn("unclosed transport %r" % self, ResourceWarning) +                self._pipe.close() +      def _fatal_error(self, exc, message='Fatal error on pipe transport'):          # should be called by exception handler only          if (isinstance(exc, OSError) and exc.errno == errno.EIO): @@ -529,6 +539,15 @@ class _UnixWritePipeTransport(transports._FlowControlMixin,              # write_eof is all what we needed to close the write pipe              self.write_eof() +    # On Python 3.3 and 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 sys.version_info >= (3, 4): +        def __del__(self): +            if self._pipe is not None: +                warnings.warn("unclosed transport %r" % self, ResourceWarning) +                self._pipe.close() +      def abort(self):          self._close(None) | 
