Commit 482eb715 authored by Jason Madden's avatar Jason Madden

Avoid logging the common IOError on close (common at least in the tests). [skip ci]

parent 00f6bba1
...@@ -5,6 +5,7 @@ from gevent._fileobjectcommon import FileObjectClosed ...@@ -5,6 +5,7 @@ from gevent._fileobjectcommon import FileObjectClosed
from gevent.hub import get_hub from gevent.hub import get_hub
from gevent.hub import integer_types from gevent.hub import integer_types
from gevent.hub import PY3 from gevent.hub import PY3
from gevent.hub import reraise
from gevent.lock import Semaphore, DummySemaphore from gevent.lock import Semaphore, DummySemaphore
...@@ -81,7 +82,16 @@ class FileObjectThread(object): ...@@ -81,7 +82,16 @@ class FileObjectThread(object):
# so acquiring the lock could potentially introduce deadlocks # so acquiring the lock could potentially introduce deadlocks
# that weren't present before. Avoiding the lock doesn't make # that weren't present before. Avoiding the lock doesn't make
# the existing race condition any worse. # the existing race condition any worse.
self.threadpool.apply(fobj.close) # We wrap the close in an exception handler and re-raise directly
# to avoid the (common, expected) IOError from being logged
def close():
try:
fobj.close()
except:
return sys.exc_info()
exc_info = self.threadpool.apply(close)
if exc_info:
reraise(*exc_info)
def flush(self, _fobj=None): def flush(self, _fobj=None):
if _fobj is not None: if _fobj is not None:
......
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