Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
daa6d5aa
Commit
daa6d5aa
authored
Jan 15, 2018
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
libev failure showing up on Travis+pypy, error handling not seen where we want it.
parent
69ed624c
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
24 deletions
+34
-24
src/greentest/test__pywsgi.py
src/greentest/test__pywsgi.py
+34
-24
No files found.
src/greentest/test__pywsgi.py
View file @
daa6d5aa
...
@@ -1204,39 +1204,49 @@ class ChunkedInputTests(TestCase):
...
@@ -1204,39 +1204,49 @@ class ChunkedInputTests(TestCase):
read_http
(
fd
,
body
=
'this is chunked
\
n
line 2
\
n
line3'
)
read_http
(
fd
,
body
=
'this is chunked
\
n
line 2
\
n
line3'
)
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
\
n
thi'
body
=
b'4
\
r
\
n
thi'
req
=
b"POST /short-read HTTP/1.1
\
r
\
n
transfer-encoding: Chunked
\
r
\
n
\
r
\
n
"
+
body
req
=
b"POST /short-read HTTP/1.1
\
r
\
n
transfer-encoding: Chunked
\
r
\
n
\
r
\
n
"
+
body
sock
=
self
.
connect
()
sock
=
self
.
connect
()
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
# makefile is gone; python 2 closed them both (because there were
# 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 avoid a ResourceWarning
sock
.
close
()
else
:
# Under Py2 it still needs to go away, which was implicit before
del
sock
# Python 3 keeps the socket open even though the only
# makefile is gone; python 2 closed them both (because there were
# 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 avoid a ResourceWarning
sock
.
close
()
# Under Py2 it still needs to go away, which was implicit before
del
fd
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
# and waking up its recv() loop...we are stuck with the three bytes of
# and waking up its recv() loop...we are stuck with the three bytes of
# '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
)
self
.
assert_error
(
IOError
,
'unexpected end of file while parsing chunked data'
)
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'
)
class
Expect100ContinueTests
(
TestCase
):
class
Expect100ContinueTests
(
TestCase
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment