%%
%% %CopyrightBegin%
%%
%% Copyright Ericsson AB 2003-2010. All Rights Reserved.
%%
%% The contents of this file are subject to the Erlang Public License,
%% Version 1.1, (the "License"); you may not use this file except in
%% compliance with the License. You should have received a copy of the
%% Erlang Public License along with this software. If not, it can be
%% retrieved online at http://www.erlang.org/.
%%
%% Software distributed under the License is distributed on an "AS IS"
%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
%% the License for the specific language governing rights and limitations
%% under the License.
%%
%% %CopyrightEnd%
%%
%%
%%----------------------------------------------------------------------
%% Purpose: Used when performing testing appup tests
%%
%% {ok, P} = megaco_appup_mgc:start().
%% megaco_appup_mgc:stop(P).
%% megaco_appup_mgc:verbosity(P,silence).
%% megaco_appup_mgc:verbosity(P,debug).
%%
%%----------------------------------------------------------------------
-module(megaco_appup_mgc).
-export([start/0, start/1, stop/1]).
-export([verbosity/2]).
-export([main/2]).
-define(START(Mid, ET, Verb),
megaco_test_mgc:start(node(), Mid, ET, Verb)).
-define(STOP(Pid), megaco_test_mgc:stop(Pid)).
-define(REQ_HANDS(Pid), megaco_test_mgc:request_handle_sloppy(Pid)).
-define(VERBOSITY(Pid,V), megaco_test_mgc:verbosity(Pid,V)).
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
start() ->
start(silence).
start(V) ->
proc_lib:start_link(?MODULE, main, [self(), V]).
stop(Pid) ->
Pid ! stop.
verbosity(Pid, V) ->
Pid ! {verbosity, V}.
%% ------------------------------------------------------------------------
main(Parent, V) ->
d("starting"),
Mgc = init(V),
proc_lib:init_ack(Parent, {ok, self()}),
d("started"),
loop(Mgc).
init(V) ->
Mid = {deviceName, "mgc"},
ET = [{text,tcp}, {text,udp}, {binary,tcp}, {binary,udp}],
d("start MGC"),
{ok, Mgc} = ?START(Mid, ET, debug),
?VERBOSITY(Mgc, V),
Mgc.
loop(Mgc) ->
d("awaiting request..."),
receive
stop ->
d("stopping"),
?STOP(Mgc),
exit(normal);
{verbosity, V} ->
d("verbosity: ~p", [V]),
?VERBOSITY(Mgc, V);
Any ->
error("received unknown request: ~n~p", [Any])
end,
loop(Mgc).
%% ------------------------------------------------------------------------
error(F, A) ->
io:format("AMGC-ERROR: " ++ F, A).
d(F) ->
d(F, []).
d(F, A) ->
io:format("AMGC: " ++ F ++ "~n", A).