diff options
author | Loïc Hoguin <[email protected]> | 2018-11-21 14:29:36 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2018-11-21 14:29:36 +0100 |
commit | 800a4890092ebd30551c49fdae606ed5182bfdb1 (patch) | |
tree | ff62fdfd00999bf9b774e290c0c13eb1a9a74f00 /test/plain_handler_SUITE.erl | |
parent | bbc152ba8333c923b4eb9a64f4a0bb02e6ab15f0 (diff) | |
download | cowboy-800a4890092ebd30551c49fdae606ed5182bfdb1.tar.gz cowboy-800a4890092ebd30551c49fdae606ed5182bfdb1.tar.bz2 cowboy-800a4890092ebd30551c49fdae606ed5182bfdb1.zip |
Move a old HTTP test cases to new plain_handler test suite
Diffstat (limited to 'test/plain_handler_SUITE.erl')
-rw-r--r-- | test/plain_handler_SUITE.erl | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/test/plain_handler_SUITE.erl b/test/plain_handler_SUITE.erl new file mode 100644 index 0000000..e980d5b --- /dev/null +++ b/test/plain_handler_SUITE.erl @@ -0,0 +1,73 @@ +%% Copyright (c) 2018, Loïc Hoguin <[email protected]> +%% +%% Permission to use, copy, modify, and/or distribute this software for any +%% purpose with or without fee is hereby granted, provided that the above +%% copyright notice and this permission notice appear in all copies. +%% +%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +-module(plain_handler_SUITE). +-compile(export_all). +-compile(nowarn_export_all). + +-import(ct_helper, [config/2]). +-import(ct_helper, [doc/1]). +-import(cowboy_test, [gun_open/1]). + +%% ct. + +all() -> + cowboy_test:common_all(). + +groups() -> + cowboy_test:common_groups(ct_helper:all(?MODULE)). + +init_per_suite(Config) -> + ct_helper:create_static_dir(config(priv_dir, Config) ++ "/static"), + Config. + +end_per_suite(Config) -> + ct_helper:delete_static_dir(config(priv_dir, Config) ++ "/static"). + +init_per_group(Name, Config) -> + cowboy_test:init_common_groups(Name, Config, ?MODULE). + +end_per_group(Name, _) -> + cowboy:stop_listener(Name). + +%% Routes. + +init_dispatch(_) -> + cowboy_router:compile([{"localhost", [ + {"/crash/no_reply", crash_h, no_reply}, + {"/crash/reply", crash_h, reply} + ]}]). + +%% Tests. + +crash_after_reply(Config) -> + doc("A plain handler crash after a response was sent " + "results in no 500 response."), + ConnPid = gun_open(Config), + Ref = gun:get(ConnPid, "/crash/reply", [ + {<<"accept-encoding">>, <<"gzip">>} + ]), + {response, fin, 200, _} = gun:await(ConnPid, Ref), + {error, timeout} = gun:await(ConnPid, Ref, 1000), + gun:close(ConnPid). + +crash_before_reply(Config) -> + doc("A plain handler crash before a response was sent " + "results in a 500 response."), + ConnPid = gun_open(Config), + Ref = gun:get(ConnPid, "/crash/no_reply", [ + {<<"accept-encoding">>, <<"gzip">>} + ]), + {response, fin, 500, _} = gun:await(ConnPid, Ref), + gun:close(ConnPid). |