Commit daa6d5aa authored by Jason Madden's avatar Jason Madden

libev failure showing up on Travis+pypy, error handling not seen where we want it.

parent 69ed624c
...@@ -1204,7 +1204,6 @@ class ChunkedInputTests(TestCase): ...@@ -1204,7 +1204,6 @@ class ChunkedInputTests(TestCase):
read_http(fd, body='this is chunked\nline 2\nline3') read_http(fd, body='this is chunked\nline 2\nline3')
def test_close_before_finished(self): def test_close_before_finished(self):
if server_implements_chunked:
self.expect_one_error() self.expect_one_error()
body = b'4\r\nthi' body = b'4\r\nthi'
req = b"POST /short-read HTTP/1.1\r\ntransfer-encoding: Chunked\r\n\r\n" + body req = b"POST /short-read HTTP/1.1\r\ntransfer-encoding: Chunked\r\n\r\n" + body
...@@ -1212,20 +1211,20 @@ class ChunkedInputTests(TestCase): ...@@ -1212,20 +1211,20 @@ class ChunkedInputTests(TestCase):
fd = sock.makefile(bufsize=1, mode='wb') fd = sock.makefile(bufsize=1, mode='wb')
fd.write(req) fd.write(req)
fd.close() fd.close()
if PY3:
# Python 3 keeps the socket open even though the only # Python 3 keeps the socket open even though the only
# makefile is gone; python 2 closed them both (because there were # makefile is gone; python 2 closed them both (because there were
# no outstanding references to the socket). Closing is essential for the server # no outstanding references to the socket). Closing is essential for the server
# to get the message that the read will fail. It's better to be explicit # to get the message that the read will fail. It's better to be explicit
# to avoid a ResourceWarning # to avoid a ResourceWarning
sock.close() sock.close()
else:
# Under Py2 it still needs to go away, which was implicit before # Under Py2 it still needs to go away, which was implicit before
del fd
del sock del sock
gevent.get_hub().loop.update_now()
gevent.sleep(0.01) # timing needed for cpython gevent.sleep(0.01) # timing needed for cpython
if server_implements_chunked:
if greentest.PYPY: if greentest.PYPY:
# XXX: Something is keeping the socket alive, # XXX: Something is keeping the socket alive,
# by which I mean, the close event is not propagating to the server # by which I mean, the close event is not propagating to the server
...@@ -1233,9 +1232,20 @@ class ChunkedInputTests(TestCase): ...@@ -1233,9 +1232,20 @@ class ChunkedInputTests(TestCase):
# 'thi' in the buffer and trying to read the forth. No amount of tinkering # 'thi' in the buffer and trying to read the forth. No amount of tinkering
# with the timing changes this...the only thing that does is running a # with the timing changes this...the only thing that does is running a
# GC and letting some object get collected. Might this be a problem in real life? # GC and letting some object get collected. Might this be a problem in real life?
import gc import gc
gc.collect() gc.collect()
gevent.sleep(0.01) gevent.sleep(0.01)
gevent.get_hub().loop.update_now()
gc.collect()
gevent.sleep(0.01)
# XXX2: Sometimes windows and PyPy/Travis fail to get this error, leading to a test failure.
# This would have to be due to the socket being kept around and open,
# not closed at the low levels. I haven't seen this locally.
# In the PyPy case, I've seen the IOError reported on the console, but not
# captured in the variables.
# https://travis-ci.org/gevent/gevent/jobs/329232976#L1374
self.assert_error(IOError, 'unexpected end of file while parsing chunked data') self.assert_error(IOError, 'unexpected end of file while parsing chunked data')
......
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