0
Fork 0
mirror of https://github.com/ninenines/cowboy.git synced 2025-07-14 12:20:24 +00:00

Change send_timeout_close test to accomodate macOS

This commit is contained in:
Loïc Hoguin 2023-12-13 17:24:48 +01:00
parent efb681d749
commit 67bd791dcc
No known key found for this signature in database
GPG key ID: 8A9DF795F6FED764
3 changed files with 28 additions and 21 deletions

View file

@ -19,6 +19,7 @@ init(Req0, #{delay := Delay} = Opts) ->
{cowboy_loop, Req, Opts}.
info(timeout, Req, State) ->
cowboy_req:stream_body(<<0:1000/unit:8>>, nofin, Req),
erlang:send_after(10, self(), timeout),
cowboy_req:stream_body(<<0:10000/unit:8>>, nofin, Req),
%% Equivalent to a 0 timeout.
self() ! timeout,
{ok, Req, State}.

View file

@ -448,7 +448,13 @@ send_timeout_close(Config) ->
{<<":path">>, <<"/endless">>},
{<<"x-test-pid">>, pid_to_list(self())}
]),
ok = gen_tcp:send(ClientSocket, cow_http2:headers(1, fin, HeadersBlock)),
ok = gen_tcp:send(ClientSocket, [
cow_http2:headers(1, fin, HeadersBlock),
%% Greatly increase the window to make sure we don't run
%% out of space before we get send timeouts.
cow_http2:window_update(10000000),
cow_http2:window_update(1, 10000000)
]),
%% Wait for the handler to start then get its pid,
%% the remote connection's pid and socket.
StreamPid = receive
@ -462,19 +468,19 @@ send_timeout_close(Config) ->
[ServerSocket] = [PidOrPort || PidOrPort <- ServerLinks, is_port(PidOrPort)],
%% Poll the socket repeatedly until it is closed by the server.
WaitClosedFun =
fun F(T, Status) when T =< 0 ->
error({status, Status});
F(T, _) ->
case prim_inet:getstatus(ServerSocket) of
{error, _} ->
ok;
{ok, Status} ->
fun F(T) when T =< 0 ->
error({status, prim_inet:getstatus(ServerSocket)});
F(T) ->
Snooze = 100,
case inet:sockname(ServerSocket) of
{error, _} ->
timer:sleep(Snooze);
{ok, _} ->
timer:sleep(Snooze),
F(T - Snooze, Status)
F(T - Snooze)
end
end,
ok = WaitClosedFun(2000, undefined),
ok = WaitClosedFun(2000),
false = erlang:is_process_alive(StreamPid),
false = erlang:is_process_alive(ServerPid)
after

View file

@ -556,19 +556,19 @@ send_timeout_close(_Config) ->
[ServerSocket] = [PidOrPort || PidOrPort <- ServerLinks, is_port(PidOrPort)],
%% Poll the socket repeatedly until it is closed by the server.
WaitClosedFun =
fun F(T, Status) when T =< 0 ->
error({status, Status});
F(T, _) ->
case prim_inet:getstatus(ServerSocket) of
{error, _} ->
ok;
{ok, Status} ->
fun F(T) when T =< 0 ->
error({status, prim_inet:getstatus(ServerSocket)});
F(T) ->
Snooze = 100,
case inet:sockname(ServerSocket) of
{error, _} ->
timer:sleep(Snooze);
{ok, _} ->
timer:sleep(Snooze),
F(T - Snooze, Status)
F(T - Snooze)
end
end,
ok = WaitClosedFun(2000, undefined),
ok = WaitClosedFun(2000),
false = erlang:is_process_alive(StreamPid),
false = erlang:is_process_alive(ServerPid)
after