aboutsummaryrefslogtreecommitdiffstats
path: root/test/ws_handler_SUITE.erl
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2018-11-16 13:48:15 +0100
committerLoïc Hoguin <[email protected]>2018-11-16 13:49:00 +0100
commitf5015cb14bbadef95285460f3d842fbbb05c33c3 (patch)
tree6b0b633c22c4a2fb49256da63ca4f91a31f5ad8e /test/ws_handler_SUITE.erl
parent75045637fc6026054900f2dbea75805ad7c8e682 (diff)
downloadcowboy-f5015cb14bbadef95285460f3d842fbbb05c33c3.tar.gz
cowboy-f5015cb14bbadef95285460f3d842fbbb05c33c3.tar.bz2
cowboy-f5015cb14bbadef95285460f3d842fbbb05c33c3.zip
Add the set_options Websocket command
It allows overriding the idle_timeout option only for now.
Diffstat (limited to 'test/ws_handler_SUITE.erl')
-rw-r--r--test/ws_handler_SUITE.erl31
1 files changed, 30 insertions, 1 deletions
diff --git a/test/ws_handler_SUITE.erl b/test/ws_handler_SUITE.erl
index 6e2bb41..8c45dc7 100644
--- a/test/ws_handler_SUITE.erl
+++ b/test/ws_handler_SUITE.erl
@@ -51,7 +51,8 @@ init_dispatch(Name) ->
{"/handle", ws_handle_commands_h, RunOrHibernate},
{"/info", ws_info_commands_h, RunOrHibernate},
{"/active", ws_active_commands_h, RunOrHibernate},
- {"/deflate", ws_deflate_commands_h, RunOrHibernate}
+ {"/deflate", ws_deflate_commands_h, RunOrHibernate},
+ {"/set_options", ws_set_options_commands_h, RunOrHibernate}
]}]).
%% Support functions for testing using Gun.
@@ -257,3 +258,31 @@ websocket_deflate_ignore_if_not_negotiated(Config) ->
{ok, {text, <<"Hello.">>}} = receive_ws(ConnPid, StreamRef)
end || _ <- lists:seq(1, 10)],
ok.
+
+websocket_set_options_idle_timeout(Config) ->
+ doc("The idle_timeout option can be modified using the "
+ "command {set_options, Opts} at runtime."),
+ ConnPid = gun_open(Config),
+ StreamRef = gun:ws_upgrade(ConnPid, "/set_options"),
+ receive
+ {gun_upgrade, ConnPid, StreamRef, [<<"websocket">>], _} ->
+ ok;
+ {gun_response, ConnPid, _, _, Status, Headers} ->
+ exit({ws_upgrade_failed, Status, Headers});
+ {gun_error, ConnPid, StreamRef, Reason} ->
+ exit({ws_upgrade_failed, Reason})
+ after 1000 ->
+ error(timeout)
+ end,
+ %% We don't send anything for a short while and confirm
+ %% that idle_timeout does not trigger.
+ {error, timeout} = gun:await(ConnPid, StreamRef, 2000),
+ %% Trigger the change in idle_timeout and confirm that
+ %% the connection gets closed soon after.
+ gun:ws_send(ConnPid, {text, <<"idle_timeout_short">>}),
+ receive
+ {gun_down, ConnPid, _, _, _, _} ->
+ ok
+ after 2000 ->
+ error(timeout)
+ end.