From 360b9c9026a748505302a84d161fe1a05f8ee0fc Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Thu, 7 Jun 2018 00:55:02 +0200 Subject: [PATCH] bpo-33789: test_asyncio: Fix ResourceWarning * Close sockets and streams to fix ResourceWarning warnings * Catch also OSError to hide a traceback on an expected handshake error --- Lib/test/test_asyncio/functional.py | 9 +++++++-- Lib/test/test_asyncio/test_sslproto.py | 5 +++++ 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/Lib/test/test_asyncio/functional.py b/Lib/test/test_asyncio/functional.py index fbec462c1dbfbd..386cfcdb9814f6 100644 --- a/Lib/test/test_asyncio/functional.py +++ b/Lib/test/test_asyncio/functional.py @@ -150,9 +150,14 @@ def start_tls(self, ssl_context, *, server_hostname=server_hostname, do_handshake_on_connect=False) - ssl_sock.do_handshake() + try: + ssl_sock.do_handshake() + except: + ssl_sock.close() + raise + finally: + self.__sock.close() - self.__sock.close() self.__sock = ssl_sock def __getattr__(self, name): diff --git a/Lib/test/test_asyncio/test_sslproto.py b/Lib/test/test_asyncio/test_sslproto.py index d02d441a8309cd..78ab1eb8223148 100644 --- a/Lib/test/test_asyncio/test_sslproto.py +++ b/Lib/test/test_asyncio/test_sslproto.py @@ -604,6 +604,8 @@ def server(sock): server_side=True) except ssl.SSLError: pass + except OSError: + pass finally: sock.close() @@ -640,6 +642,7 @@ def server(sock): except ssl.SSLError: pass finally: + orig_sock.close() sock.close() async def client(addr): @@ -653,6 +656,8 @@ async def client(addr): writer.write(b'B') with self.assertRaises(ssl.SSLError): await reader.readline() + + writer.close() return 'OK' with self.tcp_server(server,