From 5964273cc4354b7378b8bdf49fe455d2b46d7c3b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= Date: Mon, 26 Mar 2018 18:49:09 +0200 Subject: Fix the flushing of messages when switching to Websocket We now flush messages that are specific to cowboy_http only. Stream handlers should also flush their own specific messages if necessary, although timeouts will be flushed regardless of where they originate from. Also renames the http_SUITE to old_http_SUITE to distinguish new tests from old tests. Most old tests need to be removed or converted eventually as they're legacy tests from Cowboy 1.0. --- test/old_http_SUITE_data/http_echo_body.erl | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 test/old_http_SUITE_data/http_echo_body.erl (limited to 'test/old_http_SUITE_data/http_echo_body.erl') diff --git a/test/old_http_SUITE_data/http_echo_body.erl b/test/old_http_SUITE_data/http_echo_body.erl new file mode 100644 index 0000000..d803108 --- /dev/null +++ b/test/old_http_SUITE_data/http_echo_body.erl @@ -0,0 +1,21 @@ +%% Feel free to use, reuse and abuse the code in this file. + +-module(http_echo_body). + +-export([init/2]). + +init(Req, Opts) -> + true = cowboy_req:has_body(Req), + Req3 = case cowboy_req:read_body(Req, #{length => 1000000}) of + {ok, Body, Req2} -> handle_body(Req2, Body); + {more, _, Req2} -> handle_badlength(Req2) + end, + {ok, Req3, Opts}. + +handle_badlength(Req) -> + cowboy_req:reply(413, #{}, <<"Request entity too large">>, Req). + +handle_body(Req, Body) -> + Size = cowboy_req:body_length(Req), + Size = byte_size(Body), + cowboy_req:reply(200, #{}, Body, Req). -- cgit v1.2.3