Issue #14574: Ignore socket errors raised when flushing a connection on close.

This commit is contained in:
Kristján Valur Jónsson 2012-12-25 22:46:32 +00:00
parent 303eb478f2
commit 36852b7844
2 changed files with 8 additions and 3 deletions

View File

@ -299,8 +299,8 @@ request.
.. method:: RequestHandler.finish() .. method:: RequestHandler.finish()
Called after the :meth:`handle` method to perform any clean-up actions Called after the :meth:`handle` method to perform any clean-up actions
required. The default implementation does nothing. If :meth:`setup` or required. The default implementation does nothing. If :meth:`setup`
:meth:`handle` raise an exception, this function will not be called. raises an exception, this function will not be called.
.. method:: RequestHandler.handle() .. method:: RequestHandler.handle()

View File

@ -700,7 +700,12 @@ class StreamRequestHandler(BaseRequestHandler):
def finish(self): def finish(self):
if not self.wfile.closed: if not self.wfile.closed:
self.wfile.flush() try:
self.wfile.flush()
except socket.error:
# An final socket error may have occurred here, such as
# the local error ECONNABORTED.
pass
self.wfile.close() self.wfile.close()
self.rfile.close() self.rfile.close()