aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMicael Karlberg <[email protected]>2018-10-12 16:59:28 +0200
committerMicael Karlberg <[email protected]>2018-10-12 16:59:28 +0200
commitac1e27ce82fde99519a9cf271144179e4a2ef373 (patch)
tree2769c6b6038c042babb86a4f91330428c4f1523a
parent09168a9d0a78319639d62254da717090e21c47ab (diff)
downloadotp-ac1e27ce82fde99519a9cf271144179e4a2ef373.tar.gz
otp-ac1e27ce82fde99519a9cf271144179e4a2ef373.tar.bz2
otp-ac1e27ce82fde99519a9cf271144179e4a2ef373.zip
[socket-nif|test] Add skeletons for controlling-process test cases
-rw-r--r--lib/kernel/test/socket_SUITE.erl560
1 files changed, 556 insertions, 4 deletions
diff --git a/lib/kernel/test/socket_SUITE.erl b/lib/kernel/test/socket_SUITE.erl
index 3f4347c52f..71e6dff174 100644
--- a/lib/kernel/test/socket_SUITE.erl
+++ b/lib/kernel/test/socket_SUITE.erl
@@ -64,7 +64,29 @@
api_to_recvmsg_udp4/1,
api_to_recvmsg_udp6/1,
api_to_recvmsg_tcp4/1,
- api_to_recvmsg_tcp6/1
+ api_to_recvmsg_tcp6/1,
+
+ %% Controlling Process
+ socket_cleanup_tcp4/1,
+ socket_cleanup_tcp6/1,
+ socket_cleanup_udp4/1,
+ socket_cleanup_udp6/1,
+ socket_close_tcp4/1,
+ socket_close_tcp6/1,
+ socket_close_udp4/1,
+ socket_close_udp6/1,
+ recv_response_local_close_tcp4/1,
+ recv_response_local_close_tcp6/1,
+ recv_response_remote_close_tcp4/1,
+ recv_response_remote_close_tcp6/1,
+ recvmsg_response_local_close_tcp4/1,
+ recvmsg_response_local_close_tcp6/1,
+ recvmsg_response_remote_close_tcp4/1,
+ recvmsg_response_remote_close_tcp6/1,
+ acceptor_response_local_close_tcp4/1,
+ acceptor_response_local_close_tcp6/1,
+ acceptor_response_remote_close_tcp4/1,
+ acceptor_response_remote_close_tcp6/1
%% Tickets
]).
@@ -102,15 +124,17 @@ suite() ->
all() ->
[
- {group, api}
+ {group, api},
+ {group, controlling_process}
%% {group, tickets}
].
groups() ->
[{api, [], api_cases()},
{api_basic, [], api_basic_cases()},
+ {api_options, [], api_options_cases()},
{api_op_with_timeout, [], api_op_with_timeout_cases()},
- {api_options, [], api_options_cases()}
+ {controlling_process, [], controlling_process_cases()}
%% {tickets, [], ticket_cases()}
].
@@ -161,6 +185,34 @@ api_op_with_timeout_cases() ->
api_to_recvmsg_tcp6
].
+%% These cases tests what happens when the controlling process dies
+controlling_process_cases() ->
+ [
+ socket_cleanup_tcp4,
+ socket_cleanup_tcp6,
+ socket_cleanup_udp4,
+ socket_cleanup_udp6,
+
+ socket_close_tcp4,
+ socket_close_tcp6,
+ socket_close_udp4,
+ socket_close_udp6,
+
+ recv_response_local_close_tcp4,
+ recv_response_local_close_tcp6,
+ recv_response_remote_close_tcp4,
+ recv_response_remote_close_tcp6,
+
+ recvmsg_response_local_close_tcp4,
+ recvmsg_response_local_close_tcp6,
+ recvmsg_response_remote_close_tcp4,
+ recvmsg_response_remote_close_tcp6,
+
+ acceptor_response_local_close_tcp4,
+ acceptor_response_local_close_tcp6,
+ acceptor_response_remote_close_tcp4,
+ acceptor_response_remote_close_tcp6
+ ].
%% ticket_cases() ->
%% [].
@@ -184,6 +236,14 @@ end_per_testcase(_TC, Config) ->
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% %%
+%% API BASIC %%
+%% %%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% Basically open (create) and close an IPv4 UDP (dgram) socket.
%% With some extra checks...
@@ -549,7 +609,7 @@ api_b_send_and_recv_tcp(InitState) ->
cmd => fun(#{lsock := LSock} = State) ->
case socket:accept(LSock) of
{ok, Sock} ->
- ei("accepted: ~p", [Sock]),
+ ei("accepted: ~n ~p", [Sock]),
{ok, State#{tsock => Sock}};
{error, _} = ERROR ->
ERROR
@@ -653,6 +713,14 @@ api_b_send_and_recv_tcp(InitState) ->
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% %%
+%% API OPTIONS %%
+%% %%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% Perform some simple getopt and setopt with the level = otp options
api_opt_simple_otp_options(suite) ->
@@ -1164,6 +1232,14 @@ api_opt_simple_otp_controlling_process() ->
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% %%
+%% API OPERATIONS WITH TIMEOUT %%
+%% %%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% This test case is intended to test the connect timeout option
%% on an IPv4 TCP (stream) socket.
@@ -2717,6 +2793,482 @@ api_to_recvmsg_tcp6(_Config) when is_list(_Config) ->
end).
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% %%
+%% CONTROLLING PROCESS %%
+%% %%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test that the sockets are cleaned up
+%% (removed) when the controlling process terminates (without explicitly
+%% calling the close function). For a IPv4 TCP (stream) socket.
+
+socket_cleanup_tcp4(suite) ->
+ [];
+socket_cleanup_tcp4(doc) ->
+ [];
+socket_cleanup_tcp4(_Config) when is_list(_Config) ->
+ tc_try(socket_cleanup_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp},
+ ok = socket_cleanup(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test that the sockets are cleaned up
+%% (removed) when the controlling process terminates (without explicitly
+%% calling the close function). For a IPv6 TCP (stream) socket.
+
+socket_cleanup_tcp6(suite) ->
+ [];
+socket_cleanup_tcp6(doc) ->
+ [];
+socket_cleanup_tcp6(_Config) when is_list(_Config) ->
+ tc_try(socket_cleanup_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet6,
+ type => stream,
+ protocol => tcp},
+ ok = socket_cleanup(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test that the sockets are cleaned up
+%% (removed) when the controlling process terminates (without explicitly
+%% calling the close function). For a IPv4 UDP (dgram) socket.
+
+socket_cleanup_udp4(suite) ->
+ [];
+socket_cleanup_udp4(doc) ->
+ [];
+socket_cleanup_udp4(_Config) when is_list(_Config) ->
+ tc_try(socket_cleanup_udp4,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => dgram,
+ protocol => udp},
+ ok = socket_cleanup(InitState)
+ end).
+
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test that the sockets are cleaned up
+%% (removed) when the controlling process terminates (without explicitly
+%% calling the close function). For a IPv6 UDP (dgram) socket.
+
+socket_cleanup_udp6(suite) ->
+ [];
+socket_cleanup_udp6(doc) ->
+ [];
+socket_cleanup_udp6(_Config) when is_list(_Config) ->
+ tc_try(socket_cleanup_udp6,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet6,
+ type => dgram,
+ protocol => udp},
+ ok = socket_cleanup(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+socket_cleanup(_InitState) ->
+ ok.
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a process other
+%% than the controlling process closes a socket.
+%% For a IPv4 TCP (stream) socket.
+
+socket_close_tcp4(suite) ->
+ [];
+socket_close_tcp4(doc) ->
+ [];
+socket_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(socket_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp},
+ ok = socket_close(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a process other
+%% than the controlling process closes a socket.
+%% For a IPv6 TCP (stream) socket.
+
+socket_close_tcp6(suite) ->
+ [];
+socket_close_tcp6(doc) ->
+ [];
+socket_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(socket_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet6,
+ type => stream,
+ protocol => tcp},
+ ok = socket_close(InitState)
+ end).
+
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a process other
+%% than the controlling process closes a socket.
+%% For a IPv4 UDP (dgram) socket.
+
+socket_close_udp4(suite) ->
+ [];
+socket_close_udp4(doc) ->
+ [];
+socket_close_udp4(_Config) when is_list(_Config) ->
+ tc_try(socket_close_udp4,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => dgram,
+ protocol => udp},
+ ok = socket_close(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a process other
+%% than the controlling process closes a socket.
+%% For a IPv6 UDP (dgram) socket.
+
+socket_close_udp6(suite) ->
+ [];
+socket_close_udp6(doc) ->
+ [];
+socket_close_udp6(_Config) when is_list(_Config) ->
+ tc_try(socket_close_udp6,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet6,
+ type => dgram,
+ protocol => udp},
+ ok = socket_close(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+socket_close(_InitState) ->
+ ok.
+
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% locally closed while the process is calling the recv function.
+%% Socket is IPv4.
+
+recv_response_local_close_tcp4(suite) ->
+ [];
+recv_response_local_close_tcp4(doc) ->
+ [];
+recv_response_local_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(recv_response_local_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recv(Sock) end,
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_local_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% locally closed while the process is calling the recv function.
+%% Socket is IPv6.
+
+recv_response_local_close_tcp6(suite) ->
+ [];
+recv_response_local_close_tcp6(doc) ->
+ [];
+recv_response_local_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(recv_response_local_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recv(Sock) end,
+ InitState = #{domain => inet6,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_local_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+receive_response_local_close_tcp(_InitState) ->
+ ok.
+
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% remotely closed while the process is calling the recv function.
+%% Socket is IPv4.
+
+recv_response_remote_close_tcp4(suite) ->
+ [];
+recv_response_remote_close_tcp4(doc) ->
+ [];
+recv_response_remote_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(recv_response_remote_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recv(Sock) end,
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_remote_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% remotely closed while the process is calling the recv function.
+%% Socket is IPv6.
+
+recv_response_remote_close_tcp6(suite) ->
+ [];
+recv_response_remote_close_tcp6(doc) ->
+ [];
+recv_response_remote_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(recv_response_remote_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recv(Sock) end,
+ InitState = #{domain => inet6,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_remote_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+receive_response_remote_close_tcp(_InitState) ->
+ ok.
+
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% locally closed while the process is calling the recvmsg function.
+%% Socket is IPv4.
+
+recvmsg_response_local_close_tcp4(suite) ->
+ [];
+recvmsg_response_local_close_tcp4(doc) ->
+ [];
+recvmsg_response_local_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(recvmsg_response_local_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recvmsg(Sock) end,
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_local_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% locally closed while the process is calling the recvmsg function.
+%% Socket is IPv6.
+
+recvmsg_response_local_close_tcp6(suite) ->
+ [];
+recvmsg_response_local_close_tcp6(doc) ->
+ [];
+recvmsg_response_local_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(recvmsg_response_local_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recvmsg(Sock) end,
+ InitState = #{domain => inet6,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_local_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% remotely closed while the process is calling the recvmsg function.
+%% Socket is IPv4.
+
+recvmsg_response_remote_close_tcp4(suite) ->
+ [];
+recvmsg_response_remote_close_tcp4(doc) ->
+ [];
+recvmsg_response_remote_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(recvmsg_response_remote_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recvmsg(Sock) end,
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_remote_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% remotely closed while the process is calling the recvmsg function.
+%% Socket is IPv6.
+
+recvmsg_response_remote_close_tcp6(suite) ->
+ [];
+recvmsg_response_remote_close_tcp6(doc) ->
+ [];
+recvmsg_response_remote_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(recvmsg_response_remote_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ Recv = fun(Sock) -> socket:recvmsg(Sock) end,
+ InitState = #{domain => inet6,
+ type => stream,
+ protocol => tcp,
+ recv => Recv},
+ ok = receive_response_remote_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% locally closed while the process is calling the accept function.
+%% We test what happens with a non-controlling_process also, since we
+%% git the setup anyway.
+%% Socket is IPv4.
+
+acceptor_response_local_close_tcp4(suite) ->
+ [];
+acceptor_response_local_close_tcp4(doc) ->
+ [];
+acceptor_response_local_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(acceptor_response_local_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp},
+ ok = acceptor_response_local_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% locally closed while the process is calling the accept function.
+%% We test what happens with a non-controlling_process also, since we
+%% git the setup anyway.
+%% Socket is IPv6.
+
+acceptor_response_local_close_tcp6(suite) ->
+ [];
+acceptor_response_local_close_tcp6(doc) ->
+ [];
+acceptor_response_local_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(acceptor_response_local_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp},
+ ok = acceptor_response_local_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+acceptor_response_local_close_tcp(_InitState) ->
+ ok.
+
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% remotely closed while the process is calling the accept function.
+%% We test what happens with a non-controlling_process also, since we
+%% git the setup anyway.
+%% Socket is IPv4.
+
+acceptor_response_remote_close_tcp4(suite) ->
+ [];
+acceptor_response_remote_close_tcp4(doc) ->
+ [];
+acceptor_response_remote_close_tcp4(_Config) when is_list(_Config) ->
+ tc_try(acceptor_response_remote_close_tcp4,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp},
+ ok = acceptor_response_remote_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%% This test case is intended to test what happens when a socket is
+%% remotely closed while the process is calling the accept function.
+%% We test what happens with a non-controlling_process also, since we
+%% git the setup anyway.
+%% Socket is IPv6.
+
+acceptor_response_remote_close_tcp6(suite) ->
+ [];
+acceptor_response_remote_close_tcp6(doc) ->
+ [];
+acceptor_response_remote_close_tcp6(_Config) when is_list(_Config) ->
+ tc_try(acceptor_response_remote_close_tcp6,
+ fun() ->
+ not_yet_implemented(),
+ InitState = #{domain => inet,
+ type => stream,
+ protocol => tcp},
+ ok = acceptor_response_remote_close_tcp(InitState)
+ end).
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+acceptor_response_remote_close_tcp(_InitState) ->
+ ok.
+
+
+
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%