diff options
author | Loïc Hoguin <[email protected]> | 2012-12-22 18:32:35 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2012-12-22 18:32:35 +0100 |
commit | 31c7bf7234a7ec89f791fa8ec76ada6e89166d6d (patch) | |
tree | db1dc3d6baf9807ea88b289f9d07a06e4432ca00 /test/ws_timeout_cancel_handler.erl | |
parent | 7ff2a62585258e65830e80d5ac0abb75b9c1cf0b (diff) | |
parent | 5f122d9fa670f9c239f3f68b4053b35884704f9e (diff) | |
download | cowboy-31c7bf7234a7ec89f791fa8ec76ada6e89166d6d.tar.gz cowboy-31c7bf7234a7ec89f791fa8ec76ada6e89166d6d.tar.bz2 cowboy-31c7bf7234a7ec89f791fa8ec76ada6e89166d6d.zip |
Merge branch 'fix-websocket-timeout' of git://github.com/jeremyong/cowboy
Diffstat (limited to 'test/ws_timeout_cancel_handler.erl')
-rw-r--r-- | test/ws_timeout_cancel_handler.erl | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/test/ws_timeout_cancel_handler.erl b/test/ws_timeout_cancel_handler.erl new file mode 100644 index 0000000..ee75d9b --- /dev/null +++ b/test/ws_timeout_cancel_handler.erl @@ -0,0 +1,33 @@ +%% Feel free to use, reuse and abuse the code in this file. + +-module(ws_timeout_cancel_handler). +-behaviour(cowboy_http_handler). +-behaviour(cowboy_websocket_handler). +-export([init/3, handle/2, terminate/2]). +-export([websocket_init/3, websocket_handle/3, + websocket_info/3, websocket_terminate/3]). + +init(_Any, _Req, _Opts) -> + {upgrade, protocol, cowboy_websocket}. + +handle(_Req, _State) -> + exit(badarg). + +terminate(_Req, _State) -> + exit(badarg). + +websocket_init(_TransportName, Req, _Opts) -> + erlang:start_timer(500, self(), should_not_cancel_timer), + {ok, Req, undefined, 1000}. + +websocket_handle({text, Data}, Req, State) -> + {reply, {text, Data}, Req, State}; +websocket_handle({binary, Data}, Req, State) -> + {reply, {binary, Data}, Req, State}. + +websocket_info(_Info, Req, State) -> + erlang:start_timer(500, self(), should_not_cancel_timer), + {ok, Req, State}. + +websocket_terminate(_Reason, _Req, _State) -> + ok. |