%% ========================================================================================================== %% Syn - A global Process Registry and Process Group manager. %% %% The MIT License (MIT) %% %% Copyright (c) 2015 Roberto Ostinelli and Neato Robotics, Inc. %% %% Permission is hereby granted, free of charge, to any person obtaining a copy %% of this software and associated documentation files (the "Software"), to deal %% in the Software without restriction, including without limitation the rights %% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell %% copies of the Software, and to permit persons to whom the Software is %% furnished to do so, subject to the following conditions: %% %% The above copyright notice and this permission notice shall be included in %% all copies or substantial portions of the Software. %% %% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR %% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, %% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE %% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER %% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, %% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN %% THE SOFTWARE. %% ========================================================================================================== -module(syn_test_suite_helper). %% API -export([start_slave/1, stop_slave/1]). -export([connect_node/1, disconnect_node/1]). -export([clean_after_test/0]). -export([start_process/0, start_process/1, start_process/2]). -export([kill_process/1]). -export([use_custom_handler/0]). -export([start_collecting_debug_data/0, send_debug_data/1, print_debug_data/0]). %% internal -export([process_main/0]). %% =================================================================== %% API %% =================================================================== start_slave(NodeShortName) -> CodePath = code:get_path(), {ok, Node} = ct_slave:start(NodeShortName, [ {boot_timeout, 10} %% {erl_flags, ErlangFlags} ]), true = rpc:call(Node, code, set_path, [CodePath]), {ok, Node}. stop_slave(NodeShortName) -> {ok, _} = ct_slave:stop(NodeShortName). connect_node(Node) -> net_kernel:connect_node(Node). disconnect_node(Node) -> erlang:disconnect_node(Node). clean_after_test() -> Nodes = [node() | nodes()], %% shutdown lists:foreach(fun(Node) -> ok = rpc:call(Node, syn, stop, []), ok = rpc:call(Node, application, stop, [mnesia]) end, Nodes), %% clean mnesia mnesia:delete_schema(Nodes). start_process() -> Pid = spawn(fun process_main/0), Pid. start_process(Node) when is_atom(Node) -> Pid = spawn(Node, fun process_main/0), Pid; start_process(Loop) when is_function(Loop) -> Pid = spawn(Loop), Pid. start_process(Node, Loop) -> Pid = spawn(Node, Loop), Pid. kill_process(Pid) -> exit(Pid, kill). use_custom_handler() -> application:set_env(syn, event_handler, syn_test_event_handler). start_collecting_debug_data() -> global:register_name(syn_debug_process, self()). send_debug_data(Message) -> global:send(syn_debug_process, Message). print_debug_data() -> receive Any -> ct:pal("~p", [Any]), print_debug_data() after 1000 -> ok end. %% =================================================================== %% Internal %% =================================================================== process_main() -> receive _ -> process_main() end.