Commit 415bc46a authored by Yury Selivanov's avatar Yury Selivanov Committed by GitHub

bpo-33769: start_tls: Fix error message; cancel callbacks on error (GH-7403)

In addition to that, mark SSLTransport as "closed" in its "abort()" method to prevent bogus warnings.
parent e9e39760
...@@ -1097,7 +1097,7 @@ class BaseEventLoop(events.AbstractEventLoop): ...@@ -1097,7 +1097,7 @@ class BaseEventLoop(events.AbstractEventLoop):
if not getattr(transport, '_start_tls_compatible', False): if not getattr(transport, '_start_tls_compatible', False):
raise TypeError( raise TypeError(
f'transport {self!r} is not supported by start_tls()') f'transport {transport!r} is not supported by start_tls()')
waiter = self.create_future() waiter = self.create_future()
ssl_protocol = sslproto.SSLProtocol( ssl_protocol = sslproto.SSLProtocol(
...@@ -1111,13 +1111,15 @@ class BaseEventLoop(events.AbstractEventLoop): ...@@ -1111,13 +1111,15 @@ class BaseEventLoop(events.AbstractEventLoop):
transport.pause_reading() transport.pause_reading()
transport.set_protocol(ssl_protocol) transport.set_protocol(ssl_protocol)
self.call_soon(ssl_protocol.connection_made, transport) conmade_cb = self.call_soon(ssl_protocol.connection_made, transport)
self.call_soon(transport.resume_reading) resume_cb = self.call_soon(transport.resume_reading)
try: try:
await waiter await waiter
except Exception: except Exception:
transport.close() transport.close()
conmade_cb.cancel()
resume_cb.cancel()
raise raise
return ssl_protocol._app_transport return ssl_protocol._app_transport
......
...@@ -399,6 +399,7 @@ class _SSLProtocolTransport(transports._FlowControlMixin, ...@@ -399,6 +399,7 @@ class _SSLProtocolTransport(transports._FlowControlMixin,
called with None as its argument. called with None as its argument.
""" """
self._ssl_protocol._abort() self._ssl_protocol._abort()
self._closed = True
class SSLProtocol(protocols.Protocol): class SSLProtocol(protocols.Protocol):
......
asyncio/start_tls: Fix error message; cancel callbacks in case of an
unhandled error; mark SSLTransport as closed if it is aborted.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment