0
Fork 0
mirror of https://github.com/ninenines/cowboy.git synced 2025-07-14 20:30:23 +00:00

Split up urlencoded tests to speed up req_SUITE

This commit is contained in:
Loïc Hoguin 2019-09-15 21:49:45 +02:00
parent da5487b5a3
commit 8452df0617
No known key found for this signature in database
GPG key ID: 8A9DF795F6FED764

View file

@ -522,20 +522,18 @@ read_urlencoded_body(Config) ->
<<"[{<<\"abc\">>,true}]">> = do_body("POST", "/read_urlencoded_body", [], "abc", Config), <<"[{<<\"abc\">>,true}]">> = do_body("POST", "/read_urlencoded_body", [], "abc", Config),
<<"[{<<\"a\">>,<<\"b\">>},{<<\"c\">>,<<\"d e\">>}]">> <<"[{<<\"a\">>,<<\"b\">>},{<<\"c\">>,<<\"d e\">>}]">>
= do_body("POST", "/read_urlencoded_body", [], "a=b&c=d+e", Config), = do_body("POST", "/read_urlencoded_body", [], "a=b&c=d+e", Config),
%% Send a 10MB body, larger than the default length, to ensure a crash occurs.
ok = do_read_urlencoded_body_too_large("/no-opts/read_urlencoded_body",
string:chars($a, 10000000), Config),
%% We read any length for at most 1 second.
%%
%% The body is sent twice, first with nofin, then wait 1.1 second, then again with fin.
%% We expect the handler to crash because read_urlencoded_body expects the full body.
ok = do_read_urlencoded_body_too_long("/crash/read_urlencoded_body/period", <<"abc">>, Config),
%% The timeout value is set too low on purpose to ensure a crash occurs. %% The timeout value is set too low on purpose to ensure a crash occurs.
ok = do_read_body_timeout("/opts/read_urlencoded_body/timeout", <<"abc">>, Config), ok = do_read_body_timeout("/opts/read_urlencoded_body/timeout", <<"abc">>, Config),
%% Ensure parse errors result in a 400 response. %% Ensure parse errors result in a 400 response.
{400, _} = do_body_error("POST", "/read_urlencoded_body", [], "%%%%%", Config), {400, _} = do_body_error("POST", "/read_urlencoded_body", [], "%%%%%", Config),
ok. ok.
read_urlencoded_body_too_large(Config) ->
doc("application/x-www-form-urlencoded request body too large. "
"Send a 10MB body, larger than the default length, to ensure a crash occurs."),
do_read_urlencoded_body_too_large("/no-opts/read_urlencoded_body",
string:chars($a, 10000000), Config).
%% We expect a crash. %% We expect a crash.
do_read_urlencoded_body_too_large(Path, Body, Config) -> do_read_urlencoded_body_too_large(Path, Body, Config) ->
ConnPid = gun_open(Config), ConnPid = gun_open(Config),
@ -546,6 +544,12 @@ do_read_urlencoded_body_too_large(Path, Body, Config) ->
{response, _, 413, _} = gun:await(ConnPid, Ref), {response, _, 413, _} = gun:await(ConnPid, Ref),
gun:close(ConnPid). gun:close(ConnPid).
read_urlencoded_body_too_long(Config) ->
doc("application/x-www-form-urlencoded request body sent too slow. "
"The body is sent twice with 2s wait in-between. It is read by the handler "
"for at most 1 second. A crash occurs because we don't have the full body."),
do_read_urlencoded_body_too_long("/crash/read_urlencoded_body/period", <<"abc">>, Config).
%% We expect a crash. %% We expect a crash.
do_read_urlencoded_body_too_long(Path, Body, Config) -> do_read_urlencoded_body_too_long(Path, Body, Config) ->
ConnPid = gun_open(Config), ConnPid = gun_open(Config),
@ -578,20 +582,24 @@ read_and_match_urlencoded_body(Config) ->
{400, _} = do_body_error("POST", "/match/body_qs/a/c", [], "a=b", Config), {400, _} = do_body_error("POST", "/match/body_qs/a/c", [], "a=b", Config),
%% Ensure parse errors result in a 400 response. %% Ensure parse errors result in a 400 response.
{400, _} = do_body_error("POST", "/match/body_qs", [], "%%%%%", Config), {400, _} = do_body_error("POST", "/match/body_qs", [], "%%%%%", Config),
%% Send a 10MB body, larger than the default length, to ensure a crash occurs.
ok = do_read_urlencoded_body_too_large(
"/no-opts/read_and_match_urlencoded_body",
string:chars($a, 10000000), Config),
%% We read any length for at most 1 second.
%%
%% The body is sent twice, first with nofin, then wait 1.1 second, then again with fin.
%% We expect the handler to crash because read_and_match_urlencoded_body expects the full body.
ok = do_read_urlencoded_body_too_long(
"/crash/read_and_match_urlencoded_body/period", <<"abc">>, Config),
%% The timeout value is set too low on purpose to ensure a crash occurs. %% The timeout value is set too low on purpose to ensure a crash occurs.
ok = do_read_body_timeout("/opts/read_and_match_urlencoded_body/timeout", <<"abc">>, Config), ok = do_read_body_timeout("/opts/read_and_match_urlencoded_body/timeout", <<"abc">>, Config),
ok. ok.
read_and_match_urlencoded_body_too_large(Config) ->
doc("Read and match an application/x-www-form-urlencoded request body too large. "
"Send a 10MB body, larger than the default length, to ensure a crash occurs."),
do_read_urlencoded_body_too_large(
"/no-opts/read_and_match_urlencoded_body",
string:chars($a, 10000000), Config).
read_and_match_urlencoded_body_too_long(Config) ->
doc("Read and match an application/x-www-form-urlencoded request body sent too slow. "
"The body is sent twice with 2s wait in-between. It is read by the handler "
"for at most 1 second. A crash occurs because we don't have the full body."),
do_read_urlencoded_body_too_long(
"/crash/read_and_match_urlencoded_body/period", <<"abc">>, Config).
multipart(Config) -> multipart(Config) ->
doc("Multipart request body."), doc("Multipart request body."),
do_multipart("/multipart", Config). do_multipart("/multipart", Config).