aboutsummaryrefslogtreecommitdiffstats
path: root/test/loop_handler_SUITE.erl
blob: 3a91e084ff7feb5a3b76ac26841d13359f4ba1f1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
%% Copyright (c) 2011-2017, 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(loop_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_group(Name, Config) ->
	cowboy_test:init_common_groups(Name, Config, ?MODULE).

end_per_group(Name, _) ->
	cowboy:stop_listener(Name).

%% Dispatch configuration.

init_dispatch(_) ->
	cowboy_router:compile([{'_', [
		{"/long_polling", long_polling_h, []},
		{"/loop_body", loop_handler_body_h, []},
		{"/loop_request_timeout", loop_handler_timeout_h, []},
		{"/loop_timeout_init", loop_handler_timeout_init_h, []},
		{"/loop_timeout_info", loop_handler_timeout_info_h, []},
		{"/loop_timeout_hibernate", loop_handler_timeout_hibernate_h, []}
	]}]).

%% Tests.

info_read_body(Config) ->
	doc("Check that a loop handler can read the request body in info/3."),
	ConnPid = gun_open(Config),
	Ref = gun:post(ConnPid, "/loop_body", [{<<"accept-encoding">>, <<"gzip">>}],
		<< 0:100000/unit:8 >>),
	{response, fin, 200, _} = gun:await(ConnPid, Ref),
	ok.

long_polling(Config) ->
	doc("Simple long-polling."),
	ConnPid = gun_open(Config),
	Ref = gun:get(ConnPid, "/long_polling", [{<<"accept-encoding">>, <<"gzip">>}]),
	{response, fin, 299, _} = gun:await(ConnPid, Ref),
	ok.

long_polling_unread_body(Config) ->
	doc("Long-polling with a body that is not read by the handler."),
	ConnPid = gun_open(Config),
	Ref = gun:post(ConnPid, "/long_polling", [{<<"accept-encoding">>, <<"gzip">>}],
		<< 0:100000/unit:8 >>),
	{response, fin, 299, _} = gun:await(ConnPid, Ref),
	ok.

long_polling_pipeline(Config) ->
	doc("Pipeline of long-polling calls."),
	ConnPid = gun_open(Config),
	Refs = [gun:get(ConnPid, "/long_polling", [{<<"accept-encoding">>, <<"gzip">>}])
		|| _ <- lists:seq(1, 2)],
	_ = [{response, fin, 299, _} = gun:await(ConnPid, Ref) || Ref <- Refs],
	ok.

request_timeout(Config) ->
	doc("Ensure that the request_timeout isn't applied when a request is ongoing."),
	ConnPid = gun_open(Config),
	Ref = gun:get(ConnPid, "/loop_request_timeout", [{<<"accept-encoding">>, <<"gzip">>}]),
	{response, nofin, 200, _} = gun:await(ConnPid, Ref, 10000),
	ok.

timeout_hibernate(Config) ->
	doc("Ensure that loop handler idle timeouts don't trigger after hibernate is returned."),
	ConnPid = gun_open(Config),
	Ref = gun:get(ConnPid, "/loop_timeout_hibernate", [{<<"accept-encoding">>, <<"gzip">>}]),
	{response, fin, 200, _} = gun:await(ConnPid, Ref),
	ok.

timeout_info(Config) ->
	doc("Ensure that loop handler idle timeouts trigger on time when set in info/3."),
	ConnPid = gun_open(Config),
	Ref = gun:get(ConnPid, "/loop_timeout_info", [{<<"accept-encoding">>, <<"gzip">>}]),
	{response, fin, 299, _} = gun:await(ConnPid, Ref),
	ok.

timeout_init(Config) ->
	doc("Ensure that loop handler idle timeouts trigger on time when set in init/2."),
	ConnPid = gun_open(Config),
	Ref = gun:get(ConnPid, "/loop_timeout_init?timeout=1000",
		[{<<"accept-encoding">>, <<"gzip">>}]),
	{response, fin, 200, _} = gun:await(ConnPid, Ref),
	Ref2 = gun:get(ConnPid, "/loop_timeout_init?timeout=100",
		[{<<"accept-encoding">>, <<"gzip">>}]),
	{response, fin, 299, _} = gun:await(ConnPid, Ref2),
	ok.