aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2020-07-03 11:02:59 +0200
committerLoïc Hoguin <[email protected]>2020-07-03 11:02:59 +0200
commit03d306e6d172eb272a564aa8626d4554d1046455 (patch)
tree35d3f8f9bd585e3e46aa55810019a8314a6a8b62 /test
parent5aac00d60c7f22d717375e45a69769f53ad9555c (diff)
downloadcowboy-03d306e6d172eb272a564aa8626d4554d1046455.tar.gz
cowboy-03d306e6d172eb272a564aa8626d4554d1046455.tar.bz2
cowboy-03d306e6d172eb272a564aa8626d4554d1046455.zip
Fix concurrent body streaming getting stuck with HTTP/2
Diffstat (limited to 'test')
-rw-r--r--test/req_SUITE.erl10
1 files changed, 10 insertions, 0 deletions
diff --git a/test/req_SUITE.erl b/test/req_SUITE.erl
index 8216a95..352b2a0 100644
--- a/test/req_SUITE.erl
+++ b/test/req_SUITE.erl
@@ -1012,6 +1012,16 @@ stream_body_content_length_nofin_error(Config) ->
ok
end.
+stream_body_concurrent(Config) ->
+ ConnPid = gun_open(Config),
+ Ref1 = gun:get(ConnPid, "/resp/stream_body/loop", [{<<"accept-encoding">>, <<"gzip">>}]),
+ Ref2 = gun:get(ConnPid, "/resp/stream_body/loop", [{<<"accept-encoding">>, <<"gzip">>}]),
+ {response, nofin, 200, _} = gun:await(ConnPid, Ref1, infinity),
+ {ok, _} = gun:await_body(ConnPid, Ref1, infinity),
+ {response, nofin, 200, _} = gun:await(ConnPid, Ref2, infinity),
+ {ok, _} = gun:await_body(ConnPid, Ref2, infinity),
+ gun:close(ConnPid).
+
%% @todo Crash when calling stream_body after the fin flag has been set.
%% @todo Crash when calling stream_body after calling reply.
%% @todo Crash when calling stream_body before calling stream_reply.