%% %% %CopyrightBegin% %% %% Copyright Ericsson AB 2003-2012. 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: Test encoding/decoding (codec) module of Megaco/H.248 %%---------------------------------------------------------------------- -module(megaco_codec_v2_test). %% ---- -include_lib("megaco/include/megaco.hrl"). -include_lib("megaco/include/megaco_message_v2.hrl"). -include("megaco_test_lib.hrl"). %% ---- -export([msgs/0]). -export([rfc3525_msgs_display/0, rfc3525_msgs_test/0]). -export([t/0, t/1]). -export([all/0,groups/0,init_per_group/2,end_per_group/2, pretty_test_msgs/1, compact_test_msgs/1, flex_pretty_init/1, flex_pretty_finish/1, flex_pretty_test_msgs/1, flex_compact_init/1, flex_compact_finish/1, flex_compact_test_msgs/1, flex_compact_dm_timers1/1, flex_compact_dm_timers2/1, flex_compact_dm_timers3/1, flex_compact_dm_timers4/1, flex_compact_dm_timers5/1, flex_compact_dm_timers6/1, flex_compact_dm_timers7/1, flex_compact_dm_timers8/1, bin_test_msgs/1, ber_test_msgs/1, per_test_msgs/1, erl_dist_m_test_msgs/1, tickets/0, compact_otp4011_msg1/1, compact_otp4011_msg2/1, compact_otp4011_msg3/1, compact_otp4013_msg1/1, compact_otp4085_msg1/1, compact_otp4085_msg2/1, compact_otp4280_msg1/1, compact_otp4299_msg1/1, compact_otp4299_msg2/1, compact_otp4359_msg1/1, compact_otp4920_msg0/1, compact_otp4920_msg1/1, compact_otp4920_msg2/1, compact_otp4920_msg3/1, compact_otp4920_msg4/1, compact_otp4920_msg5/1, compact_otp4920_msg6/1, compact_otp4920_msg7/1, compact_otp4920_msg8/1, compact_otp4920_msg9/1, compact_otp4920_msg10/1, compact_otp4920_msg11/1, compact_otp4920_msg12/1, compact_otp4920_msg20/1, compact_otp4920_msg21/1, compact_otp4920_msg22/1, compact_otp4920_msg23/1, compact_otp4920_msg24/1, compact_otp4920_msg25/1, compact_otp5186_msg01/1, compact_otp5186_msg02/1, compact_otp5186_msg03/1, compact_otp5186_msg04/1, compact_otp5186_msg05/1, compact_otp5186_msg06/1, compact_otp5290_msg01/1, compact_otp5290_msg02/1, compact_otp5793_msg01/1, compact_otp5993_msg01/1, compact_otp5993_msg02/1, compact_otp5993_msg03/1, compact_otp6017_msg01/1, compact_otp6017_msg02/1, compact_otp6017_msg03/1, compact_otp7138_msg01/1, compact_otp7138_msg02/1, compact_otp7457_msg01/1, compact_otp7457_msg02/1, compact_otp7457_msg03/1, compact_otp7534_msg01/1, compact_otp7576_msg01/1, compact_otp7671_msg01/1, flex_compact_otp7138_msg01/1, flex_compact_otp7138_msg02/1, flex_compact_otp7431_msg01/1, flex_compact_otp7431_msg02/1, flex_compact_otp7431_msg03/1, flex_compact_otp7431_msg04/1, flex_compact_otp7431_msg05/1, flex_compact_otp7431_msg06/1, flex_compact_otp7431_msg07/1, flex_compact_otp7457_msg01/1, flex_compact_otp7457_msg02/1, flex_compact_otp7457_msg03/1, flex_compact_otp7534_msg01/1, flex_compact_otp7573_msg01/1, flex_compact_otp7576_msg01/1, pretty_otp4632_msg1/1, pretty_otp4632_msg2/1, pretty_otp4632_msg3/1, pretty_otp4632_msg4/1, pretty_otp4710_msg1/1, pretty_otp4710_msg2/1, pretty_otp4945_msg1/1, pretty_otp4945_msg2/1, pretty_otp4945_msg3/1, pretty_otp4945_msg4/1, pretty_otp4945_msg5/1, pretty_otp4945_msg6/1, pretty_otp4949_msg1/1, pretty_otp4949_msg2/1, pretty_otp4949_msg3/1, pretty_otp5042_msg1/1, pretty_otp5068_msg1/1, pretty_otp5085_msg1/1, pretty_otp5085_msg2/1, pretty_otp5085_msg3/1, pretty_otp5085_msg4/1, pretty_otp5085_msg5/1, pretty_otp5085_msg6/1, pretty_otp5085_msg7/1, pretty_otp5600_msg1/1, pretty_otp5600_msg2/1, pretty_otp5601_msg1/1, pretty_otp5793_msg01/1, pretty_otp5882_msg01/1, pretty_otp6490_msg01/1, pretty_otp6490_msg02/1, pretty_otp6490_msg03/1, pretty_otp6490_msg04/1, pretty_otp6490_msg05/1, pretty_otp6490_msg06/1, pretty_otp7249_msg01/1, pretty_otp7671_msg01/1, pretty_otp7671_msg02/1, pretty_otp7671_msg03/1, pretty_otp7671_msg04/1, pretty_otp7671_msg05/1, flex_pretty_otp5042_msg1/1, flex_pretty_otp5085_msg1/1, flex_pretty_otp5085_msg2/1, flex_pretty_otp5085_msg3/1, flex_pretty_otp5085_msg4/1, flex_pretty_otp5085_msg5/1, flex_pretty_otp5085_msg6/1, flex_pretty_otp5085_msg7/1, flex_pretty_otp5600_msg1/1, flex_pretty_otp5600_msg2/1, flex_pretty_otp5601_msg1/1, flex_pretty_otp5793_msg01/1, flex_pretty_otp7431_msg01/1, flex_pretty_otp7431_msg02/1, flex_pretty_otp7431_msg03/1, flex_pretty_otp7431_msg04/1, flex_pretty_otp7431_msg05/1, flex_pretty_otp7431_msg06/1, flex_pretty_otp7431_msg07/1, init_per_testcase/2, end_per_testcase/2]). -export([display_text_messages/0, generate_text_messages/0]). -export([ %% Decode profile_decode_compact_text_message/1, profile_decode_compact_text_messages/0, profile_decode_compact_flex_text_messages/0, profile_decode_pretty_text_message/1, profile_decode_pretty_text_messages/0, profile_decode_pretty_flex_text_messages/0, %% Encode profile_encode_compact_text_messages/0, profile_encode_pretty_text_messages/0 ]). %% ---- -define(V2, v2). -define(EC, []). -define(VERSION, 2). -define(VERSION_STR, "2"). -define(MSG_LIB, megaco_test_msg_v2_lib). -define(DEFAULT_PORT, 55555). -define(MG1_MID_NO_PORT, {ip4Address, #'IP4Address'{address = [124, 124, 124, 222]}}). -define(MG1_MID, {ip4Address, #'IP4Address'{address = [124, 124, 124, 222], portNumber = ?DEFAULT_PORT}}). -define(MG2_MID, {ip4Address, #'IP4Address'{address = [125, 125, 125, 111], portNumber = ?DEFAULT_PORT}}). -define(MGC_MID, {ip4Address, #'IP4Address'{address = [123, 123, 123, 4], portNumber = ?DEFAULT_PORT}}). -define(A4444, ["11111111", "00000000", "00000000"]). -define(A4445, ["11111111", "00000000", "11111111"]). -define(A5555, ["11111111", "11111111", "00000000"]). -define(A5556, ["11111111", "11111111", "11111111"]). %% ---- display_text_messages() -> Msgs = msgs4() ++ msgs5(), megaco_codec_test_lib:display_text_messages(?VERSION, Msgs). generate_text_messages() -> Msgs = msgs4() ++ msgs5(), megaco_codec_test_lib:generate_text_messages(?V2, ?VERSION, ?EC, Msgs). %% ---- %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg51a)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg51b)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg52)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg53)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg54a)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg58a)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg58b)). %% (catch megaco_codec_v2_test:profile_decode_compact_text_message(msg61a)). profile_decode_compact_text_message(MsgTag) -> Codec = megaco_compact_text_encoder, Config = [], profile_decode_text_message(Codec, Config, MsgTag). %% (catch megaco_codec_v2_test:profile_decode_pretty_text_message(msg51a)). %% (catch megaco_codec_v2_test:profile_decode_pretty_text_message(msg51b)). %% (catch megaco_codec_v2_test:profile_decode_pretty_text_message(msg52)). profile_decode_pretty_text_message(MsgTag) -> Codec = megaco_pretty_text_encoder, Config = [], profile_decode_text_message(Codec, Config, MsgTag). profile_decode_text_message(Codec, Config, MsgTag) -> Msgs = msgs4() ++ msgs5(), case lists:keysearch(MsgTag, 1, Msgs) of {value, Msg} -> profile_decode_text_messages(Codec, Config, [Msg]); false -> {error, {no_such_message, MsgTag}} end. %% (catch megaco_codec_v2_test:profile_decode_compact_text_messages()). profile_decode_compact_text_messages() -> Config = [], Slogan = decode_compact_v2, profile_decode_compact_text_messages(Slogan, Config). %% (catch megaco_codec_v2_test:profile_decode_compact_flex_text_messages()). profile_decode_compact_flex_text_messages() -> Conf = flex_init([]), Config = flex_scanner_conf(Conf), Slogan = decode_compact_flex_v2, Res = profile_decode_compact_text_messages(Slogan, [Config]), flex_finish(Conf), Res. profile_decode_compact_text_messages(Slogan, Config) -> Codec = megaco_compact_text_encoder, profile_decode_text_messages(Slogan, Codec, Config). %% (catch megaco_codec_v2_test:profile_decode_pretty_text_messages()). profile_decode_pretty_text_messages() -> Config = [], Slogan = decode_pretty_v2, profile_decode_pretty_text_messages(Slogan, Config). %% (catch megaco_codec_v2_test:profile_decode_pretty_flex_text_messages()). profile_decode_pretty_flex_text_messages() -> Conf = flex_init([]), Config = flex_scanner_conf(Conf), Slogan = decode_pretty_flex_v2, Res = profile_decode_pretty_text_messages(Slogan, [Config]), flex_finish(Conf), Res. profile_decode_pretty_text_messages(Slogan, Config) -> Codec = megaco_pretty_text_encoder, profile_decode_text_messages(Slogan, Codec, Config). profile_decode_text_messages(Slogan, Codec, Config) -> Msgs = msgs4() ++ msgs5(), profile_decode_text_messages(Slogan, Codec, Config, Msgs). profile_decode_text_messages(Slogan, Codec, Config, Msgs0) -> Msgs = [Msg || {_, Msg, _, _} <- Msgs0], EncodeRes = encode_text_messages(Codec, Config, Msgs, []), Bins = [Bin || {ok, Bin} <- EncodeRes], Fun = fun() -> decode_text_messages(Codec, Config, Bins, []) end, %% Make a dry run, just to make sure all modules are loaded: io:format("make a dry run...~n", []), (catch Fun()), io:format("make the run...~n", []), megaco_profile:profile(Slogan, Fun). %% (catch megaco_codec_v2_test:profile_encode_compact_text_messages()). profile_encode_compact_text_messages() -> Codec = megaco_compact_text_encoder, Config = [], Slogan = encode_compact_v2, profile_encode_text_messages(Slogan, Codec, Config). %% (catch megaco_codec_v2_test:profile_encode_pretty_text_messages()). profile_encode_pretty_text_messages() -> Codec = megaco_pretty_text_encoder, Config = [], Slogan = encode_pretty_v2, profile_encode_text_messages(Slogan, Codec, Config). profile_encode_text_messages(Slogan, Codec, Config) -> Msgs = msgs4() ++ msgs5(), profile_encode_text_messages(Slogan, Codec, Config, Msgs). profile_encode_text_messages(Slogan, Codec, Config, Msgs0) -> Msgs = [Msg || {_, Msg, _, _} <- Msgs0], Fun = fun() -> encode_text_messages(Codec, Config, Msgs, []) end, %% Make a dry run, just to make sure all modules are loaded: io:format("make a dry run...~n", []), (catch Fun()), io:format("make the run...~n", []), megaco_profile:profile(Slogan, Fun). encode_text_messages(_Codec, _Config, [], Acc) -> Acc; encode_text_messages(Codec, Config, [Msg|Msgs], Acc) -> Res = Codec:encode_message(Config, ?VERSION, Msg), encode_text_messages(Codec, Config, Msgs, [Res | Acc]). decode_text_messages(_Codec, _Config, [], Acc) -> Acc; decode_text_messages(Codec, Config, [Msg|Msgs], Acc) -> Res = Codec:decode_message(Config, dynamic, Msg), decode_text_messages(Codec, Config, Msgs, [Res | Acc]). %% ---- expand(RootCase) -> expand([RootCase], []). expand([], Acc) -> lists:flatten(lists:reverse(Acc)); expand([Case|Cases], Acc) -> case (catch apply(?MODULE,Case,[suite])) of [] -> expand(Cases, [Case|Acc]); C when is_list(C) -> expand(Cases, [expand(C, [])|Acc]); _ -> expand(Cases, [Case|Acc]) end. %% ---- t() -> megaco_test_lib:t(?MODULE). t(Case) -> megaco_test_lib:t({?MODULE, Case}). init_per_testcase(Case, Config) -> %% CaseString = io_lib:format("~p", [Case]), C = case lists:suffix("time_test", atom_to_list(Case)) of true -> [{tc_timeout, timer:minutes(10)}|Config]; false -> put(verbosity,trc), Config end, megaco_test_lib:init_per_testcase(Case, C). end_per_testcase(Case, Config) -> erase(verbosity), megaco_test_lib:end_per_testcase(Case, Config). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %% Top test case all() -> [{group, text}, {group, binary}, {group, erl_dist}, {group, tickets}]. groups() -> [{text, [], [{group, pretty}, {group, flex_pretty}, {group, compact}, {group, flex_compact}]}, {binary, [], [{group, bin}, {group, ber}, {group, per}]}, {erl_dist, [], [{group, erl_dist_m}]}, {pretty, [], [pretty_test_msgs]}, {compact, [], [compact_test_msgs]}, {flex_pretty, [], flex_pretty_cases()}, {flex_compact, [], flex_compact_cases()}, {bin, [], [bin_test_msgs]}, {ber, [], [ber_test_msgs]}, {per, [], [per_test_msgs]}, {erl_dist_m, [], [erl_dist_m_test_msgs]}, {tickets, [], [{group, compact_tickets}, {group, pretty_tickets}, {group, flex_compact_tickets}, {group, flex_pretty_tickets}]}, {compact_tickets, [], [compact_otp4011_msg1, compact_otp4011_msg2, compact_otp4011_msg3, compact_otp4013_msg1, compact_otp4085_msg1, compact_otp4085_msg2, compact_otp4280_msg1, compact_otp4299_msg1, compact_otp4299_msg2, compact_otp4359_msg1, compact_otp4920_msg0, compact_otp4920_msg1, compact_otp4920_msg2, compact_otp4920_msg3, compact_otp4920_msg4, compact_otp4920_msg5, compact_otp4920_msg6, compact_otp4920_msg7, compact_otp4920_msg8, compact_otp4920_msg9, compact_otp4920_msg10, compact_otp4920_msg11, compact_otp4920_msg12, compact_otp4920_msg20, compact_otp4920_msg21, compact_otp4920_msg22, compact_otp4920_msg23, compact_otp4920_msg24, compact_otp4920_msg25, compact_otp5186_msg01, compact_otp5186_msg02, compact_otp5186_msg03, compact_otp5186_msg04, compact_otp5186_msg05, compact_otp5186_msg06, compact_otp5290_msg01, compact_otp5290_msg02, compact_otp5793_msg01, compact_otp5993_msg01, compact_otp5993_msg02, compact_otp5993_msg03, compact_otp6017_msg01, compact_otp6017_msg02, compact_otp6017_msg03, compact_otp7138_msg01, compact_otp7138_msg02, compact_otp7457_msg01, compact_otp7457_msg02, compact_otp7457_msg03, compact_otp7534_msg01, compact_otp7576_msg01, compact_otp7671_msg01]}, {flex_compact_tickets, [], flex_compact_tickets_cases()}, {pretty_tickets, [], [pretty_otp4632_msg1, pretty_otp4632_msg2, pretty_otp4632_msg3, pretty_otp4632_msg4, pretty_otp4710_msg1, pretty_otp4710_msg2, pretty_otp4945_msg1, pretty_otp4945_msg2, pretty_otp4945_msg3, pretty_otp4945_msg4, pretty_otp4945_msg5, pretty_otp4945_msg6, pretty_otp4949_msg1, pretty_otp4949_msg2, pretty_otp4949_msg3, pretty_otp5042_msg1, pretty_otp5068_msg1, pretty_otp5085_msg1, pretty_otp5085_msg2, pretty_otp5085_msg3, pretty_otp5085_msg4, pretty_otp5085_msg5, pretty_otp5085_msg6, pretty_otp5085_msg7, pretty_otp5600_msg1, pretty_otp5600_msg2, pretty_otp5601_msg1, pretty_otp5793_msg01, pretty_otp5882_msg01, pretty_otp6490_msg01, pretty_otp6490_msg02, pretty_otp6490_msg03, pretty_otp6490_msg04, pretty_otp6490_msg05, pretty_otp6490_msg06, pretty_otp7249_msg01, pretty_otp7671_msg01, pretty_otp7671_msg02, pretty_otp7671_msg03, pretty_otp7671_msg04, pretty_otp7671_msg05]}, {flex_pretty_tickets, [], flex_pretty_tickets_cases()}]. init_per_group(flex_pretty_tickets, Config) -> flex_pretty_init(Config); init_per_group(flex_compact_tickets, Config) -> flex_compact_init(Config); init_per_group(flex_compact, Config) -> flex_compact_init(Config); init_per_group(flex_pretty, Config) -> flex_pretty_init(Config); init_per_group(_GroupName, Config) -> Config. end_per_group(flex_pretty_tickets, Config) -> flex_pretty_finish(Config); end_per_group(flex_compact_tickets, Config) -> flex_compact_finish(Config); end_per_group(flex_compact, Config) -> flex_compact_finish(Config); end_per_group(flex_pretty, Config) -> flex_pretty_finish(Config); end_per_group(_GroupName, Config) -> Config. flex_pretty_cases() -> [flex_pretty_test_msgs]. flex_compact_cases() -> [flex_compact_test_msgs, flex_compact_dm_timers1, flex_compact_dm_timers2, flex_compact_dm_timers3, flex_compact_dm_timers4, flex_compact_dm_timers5, flex_compact_dm_timers6, flex_compact_dm_timers7, flex_compact_dm_timers8]. %% Support for per_bin was added to ASN.1 as of version %% 1.3.2 (R8). And later merged into 1.3.1.3 (R7). These %% releases are identical (as far as I know). %% flex_compact_tickets_cases() -> [flex_compact_otp7138_msg01, flex_compact_otp7138_msg02, flex_compact_otp7431_msg01, flex_compact_otp7431_msg02, flex_compact_otp7431_msg03, flex_compact_otp7431_msg04, flex_compact_otp7431_msg05, flex_compact_otp7431_msg06, flex_compact_otp7431_msg07, flex_compact_otp7138_msg02, flex_compact_otp7457_msg01, flex_compact_otp7457_msg02, flex_compact_otp7457_msg03, flex_compact_otp7534_msg01, flex_compact_otp7573_msg01, flex_compact_otp7576_msg01]. flex_pretty_tickets_cases() -> [flex_pretty_otp5042_msg1, flex_pretty_otp5085_msg1, flex_pretty_otp5085_msg2, flex_pretty_otp5085_msg3, flex_pretty_otp5085_msg4, flex_pretty_otp5085_msg5, flex_pretty_otp5085_msg6, flex_pretty_otp5085_msg7, flex_pretty_otp5600_msg1, flex_pretty_otp5600_msg2, flex_pretty_otp5601_msg1, flex_pretty_otp5793_msg01, flex_pretty_otp7431_msg01, flex_pretty_otp7431_msg02, flex_pretty_otp7431_msg03, flex_pretty_otp7431_msg04, flex_pretty_otp7431_msg05, flex_pretty_otp7431_msg06, flex_pretty_otp7431_msg07]. %% ---- tickets() -> Flag = process_flag(trap_exit, true), Cases = expand(tickets), Fun = fun(Case) -> C = init_per_testcase(Case, [{tc_timeout, timer:minutes(10)}]), io:format("Eval ~w~n", [Case]), Result = case (catch apply(?MODULE, Case, [C])) of {'EXIT', Reason} -> io:format("~n~p exited:~n ~p~n", [Case, Reason]), {error, {Case, Reason}}; Res -> Res end, end_per_testcase(Case, C), Result end, process_flag(trap_exit, Flag), lists:map(Fun, Cases). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% pretty_test_msgs(suite) -> []; pretty_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs2() ++ msgs3() ++ msgs4() ++ msgs5(), %% Msgs = msgs5(), DynamicDecode = false, test_msgs(megaco_pretty_text_encoder, DynamicDecode, [], Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% flex_pretty_init(Config) -> flex_init(Config). flex_pretty_finish(Config) -> flex_finish(Config). flex_pretty_test_msgs(suite) -> []; flex_pretty_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs2() ++ msgs3() ++ msgs4(), Conf = flex_scanner_conf(Config), DynamicDecode = false, test_msgs(megaco_pretty_text_encoder, DynamicDecode, [Conf], Msgs). flex_pretty_otp5042_msg1(suite) -> []; flex_pretty_otp5042_msg1(Config) when is_list(Config) -> d("flex_pretty_otp5042_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp5042_msg1(), Bin0 = list_to_binary(Msg0), Conf = flex_scanner_conf(Config), case decode_message(megaco_pretty_text_encoder, false, [Conf], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {_, _Mod, {bad_timeStamp, TimeStamp}} -> exit({bad_timeStamp, TimeStamp}); _ -> io:format("flex_pretty_otp5042_msg1 -> " "~n Reason: ~w" "~n", [Reason]), exit({unexpected_decode_result, Reason}) end; {ok, M} -> t("flex_pretty_otp5042_msg1 -> successfull decode:" "~n~p", [M]), ok end. flex_pretty_otp5085_msg1(suite) -> []; flex_pretty_otp5085_msg1(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(ok, pretty_otp5085_msg1(), [Conf]). flex_pretty_otp5085_msg2(suite) -> []; flex_pretty_otp5085_msg2(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(error, pretty_otp5085_msg2(), [Conf]). flex_pretty_otp5085_msg3(suite) -> []; flex_pretty_otp5085_msg3(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(ok, pretty_otp5085_msg3(), [Conf]). flex_pretty_otp5085_msg4(suite) -> []; flex_pretty_otp5085_msg4(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg4 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(ok, pretty_otp5085_msg4(), [Conf]). flex_pretty_otp5085_msg5(suite) -> []; flex_pretty_otp5085_msg5(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg5 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(ok, pretty_otp5085_msg5(), [Conf]). flex_pretty_otp5085_msg6(suite) -> []; flex_pretty_otp5085_msg6(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg6 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(ok, pretty_otp5085_msg6(), [Conf]). flex_pretty_otp5085_msg7(suite) -> []; flex_pretty_otp5085_msg7(Config) when is_list(Config) -> d("flex_pretty_otp5085_msg7 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5085(ok, pretty_otp5085_msg7(), [Conf]). flex_pretty_otp5600_msg1(suite) -> []; flex_pretty_otp5600_msg1(Config) when is_list(Config) -> d("flex_pretty_otp5600_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5600(ok, pretty_otp5600_msg1(), [Conf]). flex_pretty_otp5600_msg2(suite) -> []; flex_pretty_otp5600_msg2(Config) when is_list(Config) -> d("flex_pretty_otp5600_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5600(ok, pretty_otp5600_msg2(), [Conf]). flex_pretty_otp5601_msg1(suite) -> []; flex_pretty_otp5601_msg1(Config) when is_list(Config) -> d("flex_pretty_otp5601_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5601(ok, pretty_otp5601_msg1(), [Conf]). flex_pretty_otp5793_msg01(suite) -> []; flex_pretty_otp5793_msg01(Config) when is_list(Config) -> d("flex_pretty_otp5793_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), pretty_otp5793(ok, pretty_otp5793_msg1(), [Conf]). flex_pretty_otp7431_msg01(suite) -> []; flex_pretty_otp7431_msg01(Config) when is_list(Config) -> d("flex_pretty_otp7431_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(ok, flex_pretty_otp7431_msg1(), [Conf]). flex_pretty_otp7431_msg02(suite) -> []; flex_pretty_otp7431_msg02(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_pretty_otp7431_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(error, flex_pretty_otp7431_msg2(), [Conf]). flex_pretty_otp7431_msg03(suite) -> []; flex_pretty_otp7431_msg03(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_pretty_otp7431_msg03 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(error, flex_pretty_otp7431_msg3(), [Conf]). flex_pretty_otp7431_msg04(suite) -> []; flex_pretty_otp7431_msg04(Config) when is_list(Config) -> d("flex_pretty_otp7431_msg04 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(error, flex_pretty_otp7431_msg4(), [Conf]). flex_pretty_otp7431_msg05(suite) -> []; flex_pretty_otp7431_msg05(Config) when is_list(Config) -> d("flex_pretty_otp7431_msg05 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(error, flex_pretty_otp7431_msg5(), [Conf]). flex_pretty_otp7431_msg06(suite) -> []; flex_pretty_otp7431_msg06(Config) when is_list(Config) -> d("flex_pretty_otp7431_msg06 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(error, flex_pretty_otp7431_msg6(), [Conf]). flex_pretty_otp7431_msg07(suite) -> []; flex_pretty_otp7431_msg07(Config) when is_list(Config) -> d("flex_pretty_otp7431_msg07 -> entry", []), ?ACQUIRE_NODES(1, Config), Conf = flex_scanner_conf(Config), flex_pretty_otp7431(error, flex_pretty_otp7431_msg7(), [Conf]). flex_pretty_otp7431(Expected, Msg, Conf) -> otp7431(Expected, megaco_pretty_text_encoder, Msg, Conf). otp7431(Expected, Codec, Msg0, Conf) -> Bin0 = list_to_binary(Msg0), case decode_message(Codec, false, Conf, Bin0) of {ok, _Msg1} when Expected =:= ok -> io:format(" decoded", []); {error, {bad_property_parm, Reason}} when (Expected =:= error) andalso is_list(Reason) -> io:format("expected result: ~s", [Reason]), ok; Else -> io:format("unexpected result", []), exit({unexpected_decode_result, Else}) end. flex_pretty_otp7431_msg1() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a=recvonly } ; RTP profile for G.723.1 is 4 } } } } }". flex_pretty_otp7431_msg2() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a= } } } } } }". flex_pretty_otp7431_msg3() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a } } } } } }". flex_pretty_otp7431_msg4() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a} } } } } }". flex_pretty_otp7431_msg5() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v= } } } } } }". flex_pretty_otp7431_msg6() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v } } } } } }". flex_pretty_otp7431_msg7() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v} } } } } }". %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% compact_test_msgs(suite) -> []; compact_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs2() ++ msgs3() ++ msgs4(), DynamicDecode = false, test_msgs(megaco_compact_text_encoder, DynamicDecode, [], Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% flex_compact_init(Config) -> flex_init(Config). flex_compact_finish(Config) -> flex_finish(Config). flex_compact_test_msgs(suite) -> []; flex_compact_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs2() ++ msgs3() ++ msgs4(), Conf = flex_scanner_conf(Config), DynamicDecode = true, test_msgs(megaco_compact_text_encoder, DynamicDecode, [Conf], Msgs). flex_compact_dm_timers1(suite) -> []; flex_compact_dm_timers1(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("1", "2", "3"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers1 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({1,2,3}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers2(suite) -> []; flex_compact_dm_timers2(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("02", "03", "04"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers2 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({2,3,4}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers3(suite) -> []; flex_compact_dm_timers3(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("1", "02", "31"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers3 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({1,2,31}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers4(suite) -> []; flex_compact_dm_timers4(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("10", "21", "99"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers4 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({10,21,99}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers5(suite) -> []; flex_compact_dm_timers5(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("99", "23", "11"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers5 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({99,23,11}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers6(suite) -> []; flex_compact_dm_timers6(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("77", "09", "1"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers6 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({77,9,1}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers7(suite) -> []; flex_compact_dm_timers7(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("77", "09", "1", "99"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers7 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({77,9,1,99}, M1); Else -> exit({decode_failed, M, Else}) end. flex_compact_dm_timers8(suite) -> []; flex_compact_dm_timers8(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), M = build_dm_timers_message("01", "09", "01", "02"), B = list_to_binary(M), Conf = flex_scanner_conf(Config), case decode_message(megaco_compact_text_encoder, false, [Conf], B) of {ok, M1} when is_record(M1,'MegacoMessage') -> t("flex_compact_dm_timers8 -> " "~n M: ~s" "~n M1: ~p", [M, M1]), verify_dm_timers({1,9,1,2}, M1); Else -> exit({decode_failed, M, Else}) end. build_dm_timers_message(T, S, L) -> TMRs = lists:flatten(io_lib:format("T:~s,S:~s,L:~s", [T, S, L])), build_dm_timers_message(TMRs). build_dm_timers_message(T, S, L, Z) -> TMRs = lists:flatten(io_lib:format("T:~s,S:~s,L:~s,Z:~s", [T, S, L,Z])), build_dm_timers_message(TMRs). build_dm_timers_message(TMRs) -> M = io_lib:format("!/" ?VERSION_STR " [123.123.123.4]:55555\nT=10001{C=-{MF=11111111/00000000/00000000{E=2223{al/on,dd/ce{DM=dialplan00}},SG{cg/rt},DM=dialplan00{~s,(0s| 00s|[1-7]xlxx|8lxxxxxxx|#xxxxxxx|*xx|9l1xxxxxxxxxx|9l011x.s)}}}}", [TMRs]), lists:flatten(M). verify_dm_timers(TMRs, #'MegacoMessage'{mess = Mess}) -> #'Message'{messageBody = Body} = Mess, case get_dm_timers(Body) of {error, Reason} -> exit({invalid_timer, {TMRs, Reason}}); TMRs -> ok; TMRs1 -> exit({invalid_timer_values, {TMRs, TMRs1}}) end. get_dm_timers({transactions, T}) when is_list(T) -> get_dm_timers1(T); get_dm_timers(Other) -> {error, {invalid_transactions, Other}}. get_dm_timers1([{transactionRequest,T}|Ts]) when is_record(T,'TransactionRequest') -> case get_dm_timers2(T) of {ok, Timers} -> Timers; _ -> get_dm_timers1(Ts) end; get_dm_timers1([_|Ts]) -> get_dm_timers1(Ts); get_dm_timers1([]) -> {error, {no_timers, 'TransactionRequest'}}. get_dm_timers2(#'TransactionRequest'{actions = Actions}) when is_list(Actions) -> get_dm_timers3(Actions). get_dm_timers3([#'ActionRequest'{commandRequests = Cmds}|Ars]) when is_list(Cmds) -> case get_dm_timers4(Cmds) of {ok, Timers} -> {ok, Timers}; _ -> get_dm_timers3(Ars) end; get_dm_timers3([_|Ars]) -> get_dm_timers3(Ars); get_dm_timers3([]) -> {error, {no_timers, 'ActionRequest'}}. get_dm_timers4([#'CommandRequest'{command = Cmd}|Cmds]) -> case get_dm_timers5(Cmd) of {ok, Timers} -> {ok, Timers}; _ -> get_dm_timers4(Cmds) end; get_dm_timers4([_|Cmds]) -> get_dm_timers4(Cmds); get_dm_timers4([]) -> {error, {no_timers, 'CommandRequest'}}. get_dm_timers5({modReq, #'AmmRequest'{descriptors = Descriptors}}) -> get_dm_timers6(Descriptors); get_dm_timers5(R) -> {error, {no_modReq, R}}. get_dm_timers6([{digitMapDescriptor, #'DigitMapDescriptor'{digitMapValue = Val}}|_]) -> case Val of #'DigitMapValue'{startTimer = T, shortTimer = S, longTimer = L, durationTimer = asn1_NOVALUE} -> {ok, {T, S, L}}; #'DigitMapValue'{startTimer = T, shortTimer = S, longTimer = L, durationTimer = Z} -> {ok, {T, S, L, Z}}; _ -> {error, no_value_in_dm} end; get_dm_timers6([_|Descs]) -> get_dm_timers6(Descs); get_dm_timers6([]) -> {error, {no_timers, descriptors}}. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% bin_test_msgs(suite) -> []; bin_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs4(), DynamicDecode = false, test_msgs(megaco_binary_encoder, DynamicDecode, [], Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% ber_test_msgs(suite) -> []; ber_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs4(), DynamicDecode = false, test_msgs(megaco_ber_encoder, DynamicDecode, [], Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% per_test_msgs(suite) -> []; per_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs4(), DynamicDecode = false, test_msgs(megaco_per_encoder, DynamicDecode, [], Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% erl_dist_m_test_msgs(suite) -> []; erl_dist_m_test_msgs(Config) when is_list(Config) -> ?ACQUIRE_NODES(1, Config), Msgs = msgs1() ++ msgs2() ++ msgs3() ++ msgs4(), DynamicDecode = false, Conf = [megaco_compressed], test_msgs(megaco_erl_dist_encoder, DynamicDecode, Conf, Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %% # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # %% Ticket test cases: %% -------------------------------------------------------------- %% Observe that this decode SHALL fail compact_otp4011_msg1(suite) -> []; compact_otp4011_msg1(Config) when is_list(Config) -> % put(severity,trc), % put(dbg,true), d("compact_otp4011_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), M = "!/" ?VERSION_STR " ML T=233350{C=${A=stedevice/01{M{O{MO=SR,RV=OFF,RG=OFF,tdmc/ec=OFF,MO=SR}}}}}", ok = compact_otp4011(M), % erase(severity), % erase(dbg), ok. %% -------------------------------------------------------------- %% Observe that this decode SHALL fail compact_otp4011_msg2(suite) -> []; compact_otp4011_msg2(Config) when is_list(Config) -> d("compact_otp4011_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), M = "!/" ?VERSION_STR " ML T=233350{C=${A=stedevice/01{M{O{MO=SO,RV=OFF,RG=OFF,tdmc/ec=OFF,MO=SR}}}}}", % put(severity,trc), % put(dbg,true), ok = compact_otp4011(M). %% -------------------------------------------------------------- %% Observe that this decode SHALL fail compact_otp4011_msg3(suite) -> []; compact_otp4011_msg3(Config) when is_list(Config) -> d("compact_otp4011_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), M = "!/" ?VERSION_STR " ML T=233350{C=${A=stedevice/01{M{O{MO=SR,RV=OFF,RG=OFF,tdmc/ec=OFF,MO=SO}}}}}", % put(severity,trc), % put(dbg,true), ok = compact_otp4011(M). compact_otp4011(M) -> d("compact_otp4011 -> entry with" "~n M: '~s'", [M]), Bin = list_to_binary(M), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, _} -> exit({decoded_erroneous_message,M}); {error, Error} when is_list(Error) -> % Expected result d("compact_otp4011 -> expected error result (so far)", []), case lists:keysearch(reason,1,Error) of {value, {reason,Reason}} -> d("compact_otp4011 -> expected error: " "~n Reason: ~p", [Reason]), case Reason of {0, megaco_text_parser_v2, {do_merge_control_streamParms, [A,B]}} when is_list(A) andalso is_record(B, 'LocalControlDescriptor') -> case lists:keysearch(mode,1,A) of {value, {mode, Mode}} when B#'LocalControlDescriptor'.streamMode /= asn1_NOVALUE -> d("compact_otp4011 -> " "expected error [~w]",[Mode]), ok; Other -> exit({unexpected_mode_reason, {A,B,Other}}) end; Other -> exit({unexpected_reason, Other}) end; false -> d("compact_otp4011 -> OUPS, wrong kind of error", []), exit({unexpected_result, Error}) end; Else -> d("compact_otp4011 -> unexpected decode result: ~p", [Else]), exit({unexpected_decode_result, Else}) end. %% -------------------------------------------------------------- %% Note that this decode SHALL fail, because of the misspelled %% MEGCAO instead of the correct MEGACO. compact_otp4013_msg1(suite) -> []; compact_otp4013_msg1(Config) when is_list(Config) -> d("compact_otp4013_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), M = "MEGCAO/2 MG1 T=12345678{C=-{SC=root{SV{MT=RS,RE=901}}}}", Bin = list_to_binary(M), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, _} -> exit({decoded_erroneous_message,M}); {error, Reason} when is_list(Reason) -> {value, {reason, no_version_found, _}} = lists:keysearch(reason, 1, Reason), {value, {token, [{'SafeChars',_,"megcao/2"}|_]}} = lists:keysearch(token, 1, Reason), ok; Else -> exit({unexpected_decode_result,Else}) end. %% -------------------------------------------------------------- %% %% compact_otp4085_msg1(suite) -> []; compact_otp4085_msg1(Config) when is_list(Config) -> d("compact_otp4085_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), M = compact_otp4085_erroneous_msg(), Bin = list_to_binary(M), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, M} -> exit({decoded_erroneous_message,M}); {error, Error} when is_list(Error) -> % Expected result t("compact_otp4085_msg1 -> decode failed", []), case lists:keysearch(reason, 1, Error) of {value, {reason,{999999, Module, Crap}}} -> t("compact_otp4085_msg1 -> THE ACTUAL ERROR: " "~n LINE NUMBER: 999999" "~n Module: ~p" "~n Crap: ~p", [Module, Crap]), %% ok; exit({decode_failed_999999, Module, Crap}); {value, {reason,{Line, Module, Crap}}} -> t("compact_otp4085_msg1 -> Expected: " "~n Line: ~p" "~n Module: ~p" "~n Crap: ~p", [Line, Module, Crap]), ok; false -> exit({unexpected_result, Error}) end; Else -> exit({unexpected_decode_result, Else}) end. %% -------------------------------------------------------------- %% This test case is just to show that the message used in %% compact_otp4085_msg1 is actually ok when you add '}' at the end. compact_otp4085_msg2(suite) -> []; compact_otp4085_msg2(Config) when is_list(Config) -> d("compact_otp4085_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), M1 = compact_otp4085_erroneous_msg() ++ "}", Bin = list_to_binary(M1), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, M2} -> l("compact_otp4085_msg1 -> successfull decode" "~n M2: ~p", [M2]), ok; Else -> e("compact_otp4085_msg1 -> decode error" "~n Else: ~p", [Else]), exit({unexpected_decode_result,Else}) end. %% This message lack the ending parentesis (}). compact_otp4085_erroneous_msg() -> M = "!/" ?VERSION_STR " ML T=11223342{C=${A=${M{O{MO=SR,RV=OFF,RG=OFF},L{v=0," "c=ATM NSAP $ ," "a=eecid:$ ," "m=audio - AAL1/ATMF -," "}}},A=stee1181/01{M{O{MO=SR,RV=OFF,RG=OFF,tdmc/ec=off}}}}", M. %% -------------------------------------------------------------- %% %% compact_otp4280_msg1(suite) -> []; compact_otp4280_msg1(Config) when is_list(Config) -> d("compact_otp4280_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Bin = list_to_binary(compact_otp4280_msg()), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, _Msg} -> ok; {error, Error} when is_list(Error) -> t("compact_otp4280_msg1 -> decode failed", []), case lists:keysearch(reason, 1, Error) of {value, {reason,{Line, Module, Reason} = R}} -> t("compact_otp4280_msg1 -> " "~n Line: ~w" "~n Module: ~w" "~n Reason: ~w", [Line, Module, Reason]), exit({decode_failed, R}); false -> exit({unexpected_result, Error}) end; Else -> exit({unexpected_decode_result, Else}) end. compact_otp4280_msg() -> M = "!/" ?VERSION_STR " mgw1 P=71853646{C=-{AV=root{M{TS{root/maxnumberofcontexts=49500," "root/maxterminationspercontext=2,root/normalmgexecutiontime=200," "root/normalmgcexecutiontime=150," "root/provisionalresponsetimervalue=2000,BF=OFF,SI=IV}}}}}", M. %% -------------------------------------------------------------- %% This ticket is about comments in a message compact_otp4299_msg1(suite) -> []; compact_otp4299_msg1(Config) when is_list(Config) -> d("compact_otp4299_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Bin = list_to_binary(compact_otp4299_msg()), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, _Msg} -> ok; {error, Reason} -> exit({decode_error, Reason}); Else -> exit({unexpected_decode_result, Else}) end. %% Same message, but this time decoded using the flex scanner compact_otp4299_msg2(suite) -> []; compact_otp4299_msg2(Config) when is_list(Config) -> d("compact_otp4299_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), {Pid, Conf} = compact_otp4299_msg2_init(), Bin = list_to_binary(compact_otp4299_msg()), Res = decode_message(megaco_compact_text_encoder, false, [Conf], Bin), compact_otp4299_msg2_finish(Pid), case Res of {ok, _Msg} -> ok; {error, Reason} -> exit({decode_error, Reason}); Else -> exit({unexpected_decode_result, Else}) end. compact_otp4299_msg2_init() -> Flag = process_flag(trap_exit, true), Res = (catch start_flex_scanner()), process_flag(trap_exit, Flag), case Res of {error, Reason} -> skip(Reason); {ok, FlexConfig} -> FlexConfig end. compact_otp4299_msg2_finish(Pid) -> stop_flex_scanner(Pid). compact_otp4299_msg() -> M = ";KALLE\n" "!/" ?VERSION_STR " mg58_1 P=005197711{; YET ANOTHER COMMENT\n" "C=035146207{A=mg58_1_1_4_1_23/19; BEFORE COMMA\n" ",; AFTER COMMA\n" "A=eph58_1/0xA4023371{M{L{\n" "v=0\n" "c=ATM NSAP 39.0102.0304.0506.0708.090a.0b58.0100.0000.0000.00\n" "m=audio - AAL1/ATMF -\n" "a=eecid:A4023371\n" "}}; HOBBE\n}; KALLE \"HOBBE \n}}" ";KALLE\n\n", M. %% -------------------------------------------------------------- %% %% compact_otp4359_msg1(suite) -> []; compact_otp4359_msg1(Config) when is_list(Config) -> d("compact_otp4359_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Bin = list_to_binary(compact_otp4359_msg()), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, #'MegacoMessage'{mess = Mess}} -> {transactions, Trans} = Mess#'Message'.messageBody, case Trans of [{transactionRequest,#'TransactionRequest'{transactionId = asn1_NOVALUE}}] -> ok; _ -> exit({unexpected_transactions, Trans}) end; Else -> t("compact_otp4359_msg1 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. compact_otp4359_msg() -> M = "!/" ?VERSION_STR " ml2 T={C=${A=${M{O {MO=SR,RG=OFF,RV=OFF}}}}}", M. %% -------------------------------------------------------------- %% %% compact_otp4920_msg0(suite) -> []; compact_otp4920_msg0(Config) when is_list(Config) -> d("compact_otp4920_msg0 -> entry", []), ?ACQUIRE_NODES(1, Config), % put(dbg,true), compact_otp4920_msg_1(compact_otp4920_msg0(), true). compact_otp4920_msg1(suite) -> []; compact_otp4920_msg1(Config) when is_list(Config) -> d("compact_otp4920_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), % put(dbg,true), compact_otp4920_msg_1(compact_otp4920_msg1(), false). compact_otp4920_msg2(suite) -> []; compact_otp4920_msg2(Config) when is_list(Config) -> d("compact_otp4920_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg2(), false). compact_otp4920_msg3(suite) -> []; compact_otp4920_msg3(Config) when is_list(Config) -> d("compact_otp4920_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg3(), true). compact_otp4920_msg4(suite) -> []; compact_otp4920_msg4(Config) when is_list(Config) -> d("compact_otp4920_msg4 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg4(), true). compact_otp4920_msg5(suite) -> []; compact_otp4920_msg5(Config) when is_list(Config) -> d("compact_otp4920_msg5 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg5(), true). compact_otp4920_msg6(suite) -> []; compact_otp4920_msg6(Config) when is_list(Config) -> d("compact_otp4920_msg6 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg6(), true). compact_otp4920_msg7(suite) -> []; compact_otp4920_msg7(Config) when is_list(Config) -> d("compact_otp4920_msg7 -> entry", []), ?ACQUIRE_NODES(1, Config), % put(dbg,true), compact_otp4920_msg_1(compact_otp4920_msg7(), true). compact_otp4920_msg8(suite) -> []; compact_otp4920_msg8(Config) when is_list(Config) -> d("compact_otp4920_msg8 -> entry", []), ?ACQUIRE_NODES(1, Config), % put(dbg,true), compact_otp4920_msg_1(compact_otp4920_msg8(), false). compact_otp4920_msg9(suite) -> []; compact_otp4920_msg9(Config) when is_list(Config) -> d("compact_otp4920_msg9 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg9(), false). compact_otp4920_msg10(suite) -> []; compact_otp4920_msg10(Config) when is_list(Config) -> d("compact_otp4920_msg10 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg10(), false). compact_otp4920_msg11(suite) -> []; compact_otp4920_msg11(Config) when is_list(Config) -> d("compact_otp4920_msg11 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg11(), false). compact_otp4920_msg12(suite) -> []; compact_otp4920_msg12(Config) when is_list(Config) -> d("compact_otp4920_msg12 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_1(compact_otp4920_msg12(), true). %% Duplicate padding compact_otp4920_msg20(suite) -> []; compact_otp4920_msg20(Config) when is_list(Config) -> d("compact_otp4920_msg20 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_2(compact_otp4920_msg20(), bad_mid_duplicate_padding). %% Length compact_otp4920_msg21(suite) -> []; compact_otp4920_msg21(Config) when is_list(Config) -> d("compact_otp4920_msg21 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_2(compact_otp4920_msg21(), bad_mid_ip6addr_length). %% Length compact_otp4920_msg22(suite) -> []; compact_otp4920_msg22(Config) when is_list(Config) -> d("compact_otp4920_msg22 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_2(compact_otp4920_msg22(), bad_mid_ip6addr_length). %% Length compact_otp4920_msg23(suite) -> []; compact_otp4920_msg23(Config) when is_list(Config) -> d("compact_otp4920_msg23 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_2(compact_otp4920_msg23(), bad_mid_ip6addr_length). %% Length compact_otp4920_msg24(suite) -> []; compact_otp4920_msg24(Config) when is_list(Config) -> d("compact_otp4920_msg24 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_2(compact_otp4920_msg24(), bad_mid_ip6addr_length). %% Length compact_otp4920_msg25(suite) -> []; compact_otp4920_msg25(Config) when is_list(Config) -> d("compact_otp4920_msg25 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp4920_msg_2(compact_otp4920_msg25(), bad_mid_ip6addr_length). compact_otp4920_msg_1(M1, CheckEqual) -> Bin1 = list_to_binary(M1), case decode_message(megaco_compact_text_encoder, false, [], Bin1) of {ok, Msg} -> io:format(" decoded", []), case encode_message(megaco_compact_text_encoder, [], Msg) of {ok, Bin1} -> io:format(", encoded - equal:", []), ok; {ok, Bin2} when is_binary(Bin2) andalso (CheckEqual =:= true) -> M2 = binary_to_list(Bin2), io:format(", encoded - not equal:", []), exit({messages_not_equal, M1, M2}); {ok, _} -> io:format(", encoded:", []), ok; Else -> io:format(", encode failed:", []), exit({unexpected_encode_result, Else}) end; Else -> io:format("decode failed:", []), exit({unexpected_decode_result, Else}) end. compact_otp4920_msg_2(M1, ExpectedReason) -> Bin = list_to_binary(M1), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, Msg} -> io:format("unexpected successfull decode", []), exit({unexpected_encode_ok, Msg}); {error, [{reason, {__Line, _Mod, Reason}}|_]} -> case element(1, Reason) of ExpectedReason -> ok; _ -> exit({unexpected_decode_error_reason, ExpectedReason, Reason}) end; {error, [{reason, {_Mod, Reason}}|_]} -> case element(1, Reason) of ExpectedReason -> ok; _ -> exit({unexpected_decode_error_reason, ExpectedReason, Reason}) end; Else -> io:format("unexpected decode result", []), exit({unexpected_decode_result, Else}) end. compact_otp4920_msg0() -> M = "!/" ?VERSION_STR " [192.168.30.1]\nT=100{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg1() -> M = "!/" ?VERSION_STR " [2031:0000:130F:0000:0000:09C0:876A:130B]\nT=101{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg2() -> M = "!/" ?VERSION_STR " [2031:0:130F:0:0:9C0:876A:130B]\nT=102{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg3() -> M = "!/" ?VERSION_STR " [2031:0:130F::9C0:876A:130B]\nT=103{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg4() -> M = "!/" ?VERSION_STR " [::1]\nT=104{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg5() -> M = "!/" ?VERSION_STR " [::]\nT=105{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg6() -> M = "!/" ?VERSION_STR " [1::]\nT=106{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg7() -> M = "!/" ?VERSION_STR " [FEDC:1::]\nT=107{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg8() -> M = "!/" ?VERSION_STR " [2031:0:130F:0:0:9C0:135.106.19.11]\nT=108{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg9() -> M = "!/" ?VERSION_STR " [2031:0:130F::9C0:135.106.19.11]\nT=109{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg10() -> M = "!/" ?VERSION_STR " [::FFFF:192.168.30.1]\nT=110{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg11() -> M = "!/" ?VERSION_STR " [::192.168.30.1]\nT=111{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp4920_msg12() -> M = "!/" ?VERSION_STR " [::C0A8:1E01]\nT=112{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. %% Illegal: only one :: allowed compact_otp4920_msg20() -> M = "!/" ?VERSION_STR " [2031::130F::9C0]\nT=120{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. %% Illegal: length compact_otp4920_msg21() -> M = "!/" ?VERSION_STR " [2031:FFEE:0000:130F:0000:0000:09C0:876A:130B]\nT=121{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. %% Illegal: length compact_otp4920_msg22() -> M = "!/" ?VERSION_STR " [2031:FFEE:0:130F:0:0:9C0:135.106.19.11]\nT=122{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. %% Illegal: length compact_otp4920_msg23() -> M = "!/" ?VERSION_STR " [2031:FFEE:0000:130F:2132:4354::09C0:876A:130B]\nT=123{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. %% Illegal: length compact_otp4920_msg24() -> M = "!/" ?VERSION_STR " [::2031:FFEE:0000:130F:2132:4354:09C0:876A:130B]\nT=124{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. %% Illegal: length compact_otp4920_msg25() -> M = "!/" ?VERSION_STR " [2031:FFEE:0000:130F:2132:4354:09C0:876A:130B::]\nT=125{C=${A=${M{O{MO=SR,RG=OFF,RV=OFF}}}}}", M. compact_otp5186_msg01(suite) -> []; compact_otp5186_msg01(Config) when is_list(Config) -> d("compact_otp5186_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5186_msg_1(compact_otp5186_msg01(), error, ignore). compact_otp5186_msg02(suite) -> []; compact_otp5186_msg02(Config) when is_list(Config) -> d("compact_otp5186_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5186_msg_1(compact_otp5186_msg02(), ok, ok). compact_otp5186_msg03(suite) -> []; compact_otp5186_msg03(Config) when is_list(Config) -> d("compact_otp5186_msg03 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5186_msg_2(compact_otp5186_msg03(), ok, ok). compact_otp5186_msg04(suite) -> []; compact_otp5186_msg04(Config) when is_list(Config) -> d("compact_otp5186_msg04 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5186_msg_2(compact_otp5186_msg04(), ok, ok). compact_otp5186_msg05(suite) -> []; compact_otp5186_msg05(Config) when is_list(Config) -> d("compact_otp5186_msg05 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5186_msg_2(compact_otp5186_msg05(), ok, ok). compact_otp5186_msg06(suite) -> []; compact_otp5186_msg06(Config) when is_list(Config) -> d("compact_otp5186_msg06 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5186_msg_2(compact_otp5186_msg06(), ok, ok). compact_otp5186_msg_1(M1, DecodeExpect, EncodeExpect) -> Bin1 = list_to_binary(M1), case decode_message(megaco_compact_text_encoder, false, [], Bin1) of {ok, Msg} when DecodeExpect == ok -> io:format(" decoded", []), case encode_message(megaco_compact_text_encoder, [], Msg) of {ok, Bin1} when EncodeExpect == ok -> io:format(", encoded - equal:", []), ok; {ok, Bin2} when EncodeExpect == ok -> M2 = binary_to_list(Bin2), io:format(", encoded - not equal:", []), exit({messages_not_equal, Msg, M1, M2}); {ok, Bin3} when EncodeExpect == error -> M3 = binary_to_list(Bin3), io:format(", unexpected encode:", []), exit({unexpected_encode_success, Msg, M1, M3}); _Else when EncodeExpect == error -> io:format(", encode failed ", []), ok end; {ok, Msg} when DecodeExpect == error -> io:format(" decoded", []), exit({unexpected_decode_success, Msg}); _Else when DecodeExpect == error -> io:format(" decode failed ", []), ok; Else when DecodeExpect == ok -> io:format(" decode failed ", []), exit({unexpected_decode_result, Else}) end. compact_otp5186_msg_2(Msg1, EncodeExpect, DecodeExpect) -> case encode_message(megaco_compact_text_encoder, [], Msg1) of {ok, Bin} when EncodeExpect == ok -> io:format(" encoded", []), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, Msg1} when DecodeExpect == ok -> io:format(", decoded - equal:", []), ok; {ok, Msg2} when DecodeExpect == ok -> M = binary_to_list(Bin), case (catch compact_otp5186_check_megamsg(Msg1, Msg2)) of ok -> io:format(", decoded - not equal - ok:", []), ok; {'EXIT', Reason} -> io:format(", decoded - not equal:", []), exit({messages_not_equal, M, Reason, Msg1, Msg2}) end; {ok, Msg3} when DecodeExpect == error -> M = binary_to_list(Bin), io:format(", decoded:", []), exit({unexpected_decode_success, M, Msg1, Msg3}); Else when DecodeExpect == ok -> M = binary_to_list(Bin), io:format(", decode failed ", []), exit({unexpected_decode_success, Msg1, M, Else}); _Else when DecodeExpect == error -> io:format(", decode failed ", []), ok end; {ok, Bin} when EncodeExpect == error -> M = binary_to_list(Bin), io:format(" encoded", []), exit({unexpected_encode_success, Msg1, M}); _Else when EncodeExpect == error -> io:format(" encode failed ", []), ok; Else when EncodeExpect == ok -> io:format(" encode failed ", []), exit({unexpected_encode_result, Else}) end. %% -- compact_otp5186_msg01() -> "!/2 \nP=67111298{C=2699{AV=mg5_ipeph/0x0f0001{}}}". compact_otp5186_msg02() -> "!/2 \nP=67111298{C=2699{AV=mg5_ipeph/0x0f0001}}". compact_otp5186_msg03() -> {'MegacoMessage', asn1_NOVALUE, {'Message', 2, {domainName,{'DomainName',"mg5",asn1_NOVALUE}}, {transactions, [{transactionReply, {'TransactionReply',67111298,asn1_NOVALUE, {actionReplies,[ {'ActionReply',2699,asn1_NOVALUE,asn1_NOVALUE, [ {auditValueReply, {auditResult, {'AuditResult', {megaco_term_id,false,["mg5_ipeph","0x0f0001"]}, [ ] } } } ] } ] } } } ] } } }. compact_otp5186_msg04() -> {'MegacoMessage',asn1_NOVALUE, {'Message',2,{domainName,{'DomainName',"mg5",asn1_NOVALUE}}, {transactions, [{transactionReply, {'TransactionReply',67111298,asn1_NOVALUE, {actionReplies,[ {'ActionReply',2699,asn1_NOVALUE,asn1_NOVALUE, [ {auditValueReply, {auditResult, {'AuditResult', {megaco_term_id,false,["mg5_ipeph","0x0f0001"]}, [ {emptyDescriptors, {'AuditDescriptor',asn1_NOVALUE,asn1_NOVALUE} } ] } } } ] } ] } } } ] } } }. compact_otp5186_msg05() -> {'MegacoMessage', asn1_NOVALUE, {'Message', 2, {domainName,{'DomainName',"mg5",asn1_NOVALUE}}, {transactions, [{transactionReply, {'TransactionReply',67111298,asn1_NOVALUE, {actionReplies,[ {'ActionReply',2699,asn1_NOVALUE,asn1_NOVALUE, [ {addReply, {'AmmsReply', [ {megaco_term_id,false,["mg5_ipeph","0x0f0001"]} ], [ ] } } ] } ] } } } ] } } }. compact_otp5186_msg06() -> {'MegacoMessage',asn1_NOVALUE, {'Message',2,{domainName,{'DomainName',"mg5",asn1_NOVALUE}}, {transactions, [{transactionReply, {'TransactionReply',67111298,asn1_NOVALUE, {actionReplies,[ {'ActionReply',2699,asn1_NOVALUE,asn1_NOVALUE, [ {addReply, {'AmmsReply', [ {megaco_term_id,false,["mg5_ipeph","0x0f0001"]} ], [ {emptyDescriptors, {'AuditDescriptor',asn1_NOVALUE,asn1_NOVALUE} } ] } } ] } ] } } } ] } } }. %% -- compact_otp5186_check_megamsg(M1, M1) -> ok; compact_otp5186_check_megamsg(#'MegacoMessage'{authHeader = AH, mess = M1}, #'MegacoMessage'{authHeader = AH, mess = M2}) -> compact_otp5186_check_mess(M1, M2); compact_otp5186_check_megamsg(#'MegacoMessage'{authHeader = AH1}, #'MegacoMessage'{authHeader = AH2}) -> exit({not_equal, authHeader, AH1, AH2}). compact_otp5186_check_mess(M, M) -> ok; compact_otp5186_check_mess(#'Message'{version = V, mId = MId, messageBody = B1}, #'Message'{version = V, mId = MId, messageBody = B2}) -> compact_otp5186_check_body(B1, B2); compact_otp5186_check_mess(#'Message'{version = V, mId = MId1}, #'Message'{version = V, mId = MId2}) -> exit({not_equal, mId, MId1, MId2}); compact_otp5186_check_mess(#'Message'{version = V1, mId = MId}, #'Message'{version = V2, mId = MId}) -> exit({not_equal, version, V1, V2}). compact_otp5186_check_body(B, B) -> ok; compact_otp5186_check_body({transactions, T1}, {transactions, T2}) -> compact_otp5186_check_trans(T1, T2); compact_otp5186_check_body({messageError, E1}, {messageError, E2}) -> compact_otp5186_check_merr(E1, E2); compact_otp5186_check_body(B1, B2) -> exit({not_equal, messageBody, B1, B2}). compact_otp5186_check_trans([], []) -> ok; compact_otp5186_check_trans([], T2) -> exit({not_equal, transactions, [], T2}); compact_otp5186_check_trans(T1, []) -> exit({not_equal, transactions, T1, []}); compact_otp5186_check_trans([Tran1|Trans1], [Tran2|Trans2]) -> compact_otp5186_check_trans(Trans1, Trans2), compact_otp5186_check_transaction(Tran1, Tran2). compact_otp5186_check_merr(ME, ME) -> ok; compact_otp5186_check_merr(#'ErrorDescriptor'{errorCode = EC, errorText = ET1}, #'ErrorDescriptor'{errorCode = EC, errorText = ET2}) -> exit({not_equal, errorText, ET1, ET2}); compact_otp5186_check_merr(#'ErrorDescriptor'{errorCode = EC1, errorText = ET}, #'ErrorDescriptor'{errorCode = EC2, errorText = ET}) -> exit({not_equal, errorCode, EC1, EC2}). compact_otp5186_check_transaction(T, T) -> ok; compact_otp5186_check_transaction({transactionReply, TR1}, {transactionReply, TR2}) -> compact_otp5186_check_transRep(TR1, TR2); compact_otp5186_check_transaction(T1, T2) -> exit({unexpected_transactions, T1, T2}). compact_otp5186_check_transRep(T, T) -> ok; compact_otp5186_check_transRep(#'TransactionReply'{transactionId = TId, immAckRequired = IAR, transactionResult = TR1}, #'TransactionReply'{transactionId = TId, immAckRequired = IAR, transactionResult = TR2}) -> compact_otp5186_check_transRes(TR1, TR2); compact_otp5186_check_transRep(T1, T2) -> exit({unexpected_transaction_reply, T1, T2}). compact_otp5186_check_transRes(TR, TR) -> ok; compact_otp5186_check_transRes({actionReplies, AR1}, {actionReplies, AR2}) -> compact_otp5186_check_actReps(AR1, AR2); compact_otp5186_check_transRes(TR1, TR2) -> exit({unexpected_transaction_result, TR1, TR2}). compact_otp5186_check_actReps([], []) -> ok; compact_otp5186_check_actReps(AR1, []) -> exit({not_equal, actionReplies, AR1, []}); compact_otp5186_check_actReps([], AR2) -> exit({not_equal, actionReplies, [], AR2}); compact_otp5186_check_actReps([AR1|ARs1], [AR2|ARs2]) -> compact_otp5186_check_actRep(AR1, AR2), compact_otp5186_check_actReps(ARs1, ARs2). compact_otp5186_check_actRep(AR, AR) -> ok; compact_otp5186_check_actRep(#'ActionReply'{contextId = ID, errorDescriptor = ED, contextReply = CtxRep, commandReply = CmdRep1}, #'ActionReply'{contextId = ID, errorDescriptor = ED, contextReply = CtxRep, commandReply = CmdRep2}) -> compact_otp5186_check_cmdReps(CmdRep1, CmdRep2); compact_otp5186_check_actRep(AR1, AR2) -> exit({unexpected_actionReply, AR1, AR2}). compact_otp5186_check_cmdReps([], []) -> ok; compact_otp5186_check_cmdReps(CR1, []) -> exit({not_equal, commandReplies, CR1, []}); compact_otp5186_check_cmdReps([], CR2) -> exit({not_equal, commandReplies, [], CR2}); compact_otp5186_check_cmdReps([CR1|CRs1], [CR2|CRs2]) -> compact_otp5186_check_cmdRep(CR1, CR2), compact_otp5186_check_cmdReps(CRs1, CRs2). compact_otp5186_check_cmdRep(CR, CR) -> ok; compact_otp5186_check_cmdRep({auditValueReply, AVR1}, {auditValueReply, AVR2}) -> compact_otp5186_check_auditReply(AVR1, AVR2); compact_otp5186_check_cmdRep({addReply, AVR1}, {addReply, AVR2}) -> compact_otp5186_check_ammsReply(AVR1, AVR2); compact_otp5186_check_cmdRep(CR1, CR2) -> exit({unexpected_commandReply, CR1, CR2}). compact_otp5186_check_auditReply(AR, AR) -> ok; compact_otp5186_check_auditReply({auditResult, AR1}, {auditResult, AR2}) -> compact_otp5186_check_auditRes(AR1, AR2); compact_otp5186_check_auditReply(AR1, AR2) -> exit({unexpected_auditReply, AR1, AR2}). compact_otp5186_check_ammsReply(AR, AR) -> ok; compact_otp5186_check_ammsReply(#'AmmsReply'{terminationID = ID, terminationAudit = TA1}, #'AmmsReply'{terminationID = ID, terminationAudit = TA2}) -> %% This is just to simplify the test F = fun(asn1_NOVALUE) -> []; (E) -> E end, compact_otp5186_check_termAudit(F(TA1), F(TA2)); compact_otp5186_check_ammsReply(AR1, AR2) -> exit({unexpected_ammsReply, AR1, AR2}). compact_otp5186_check_auditRes(AR, AR) -> ok; compact_otp5186_check_auditRes(#'AuditResult'{terminationID = ID, terminationAuditResult = TAR1}, #'AuditResult'{terminationID = ID, terminationAuditResult = TAR2}) -> compact_otp5186_check_termAuditRes(TAR1, TAR2); compact_otp5186_check_auditRes(AR1, AR2) -> exit({unexpected_auditResult, AR1, AR2}). compact_otp5186_check_termAuditRes([], []) -> ok; %% An empty empty descriptor is removed compact_otp5186_check_termAuditRes([{emptyDescriptors, #'AuditDescriptor'{auditToken = asn1_NOVALUE, auditPropertyToken = asn1_NOVALUE}}|TAR1], []) -> compact_otp5186_check_termAuditRes(TAR1, []); compact_otp5186_check_termAuditRes(TAR1, []) -> exit({not_equal, termAuditRes, TAR1, []}); %% An empty empty descriptor is removed compact_otp5186_check_termAuditRes([], [{emptyDescriptors, #'AuditDescriptor'{auditToken = asn1_NOVALUE, auditPropertyToken = asn1_NOVALUE}}|TAR2]) -> compact_otp5186_check_termAuditRes([], TAR2); compact_otp5186_check_termAuditRes([], TAR2) -> exit({not_equal, termAuditRes, [], TAR2}); compact_otp5186_check_termAuditRes([ARP1|TAR1], [ARP2|TAR2]) -> compact_otp5186_check_auditRetParm(ARP1, ARP2), compact_otp5186_check_termAuditRes(TAR1, TAR2). compact_otp5186_check_termAudit([], []) -> ok; %% An empty empty descriptor is removed compact_otp5186_check_termAudit([{emptyDescriptors, #'AuditDescriptor'{auditToken = asn1_NOVALUE, auditPropertyToken = asn1_NOVALUE}}|TAR1], []) -> compact_otp5186_check_termAudit(TAR1, []); compact_otp5186_check_termAudit(TAR1, []) -> exit({not_equal, termAudit, TAR1, []}); %% An empty empty descriptor is removed compact_otp5186_check_termAudit([], [{emptyDescriptors, #'AuditDescriptor'{auditToken = asn1_NOVALUE, auditPropertyToken = asn1_NOVALUE}}|TAR2]) -> compact_otp5186_check_termAudit([], TAR2); compact_otp5186_check_termAudit([], TAR2) -> exit({not_equal, termAudit, [], TAR2}); compact_otp5186_check_termAudit([ARP1|TAR1], [ARP2|TAR2]) -> compact_otp5186_check_auditRetParm(ARP1, ARP2), compact_otp5186_check_termAudit(TAR1, TAR2). compact_otp5186_check_auditRetParm(ARP, ARP) -> ok; compact_otp5186_check_auditRetParm({emptyDescriptors, AD1}, {emptyDescriptors, AD2}) -> compact_otp5186_check_auditDesc(AD1, AD2); compact_otp5186_check_auditRetParm(ARP1, ARP2) -> exit({unexpected_auditRetParm, ARP1, ARP2}). compact_otp5186_check_auditDesc(AD, AD) -> ok; compact_otp5186_check_auditDesc(#'AuditDescriptor'{auditToken = L1, auditPropertyToken = asn1_NOVALUE}, #'AuditDescriptor'{auditToken = L2, auditPropertyToken = asn1_NOVALUE}) -> compact_otp5186_check_auditDesc_auditItems(L1, L2); compact_otp5186_check_auditDesc(#'AuditDescriptor'{auditToken = asn1_NOVALUE, auditPropertyToken = APT1}, #'AuditDescriptor'{auditToken = asn1_NOVALUE, auditPropertyToken = APT2}) -> compact_otp5186_check_auditDesc_apt(APT1, APT2); compact_otp5186_check_auditDesc(AD1, AD2) -> exit({unexpected_auditDesc, AD1, AD2}). compact_otp5186_check_auditDesc_auditItems([], []) -> ok; compact_otp5186_check_auditDesc_auditItems(AI1, []) -> exit({not_equal, auditItems, AI1, []}); compact_otp5186_check_auditDesc_auditItems([], AI2) -> exit({not_equal, auditItems, [], AI2}); compact_otp5186_check_auditDesc_auditItems([AI1|AIs1], [AI2|AIs2]) -> compact_otp5186_check_auditDesc_auditItem(AI1, AI2), compact_otp5186_check_auditDesc_auditItems(AIs1, AIs2). compact_otp5186_check_auditDesc_auditItem(AI, AI) -> ok; compact_otp5186_check_auditDesc_auditItem(AI1, AI2) -> exit({not_equal, auditItem, AI1, AI2}). compact_otp5186_check_auditDesc_apt(APT, APT) -> ok; compact_otp5186_check_auditDesc_apt(APT1, APT2) -> exit({not_equal, auditPropertyToken, APT1, APT2}). %% -------------------------------------------------------------- compact_otp5290_msg01(suite) -> []; compact_otp5290_msg01(Config) when is_list(Config) -> d("compact_otp5290_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5290_msg_1(compact_otp5290_msg01(), ok, ok). compact_otp5290_msg02(suite) -> []; compact_otp5290_msg02(Config) when is_list(Config) -> d("compact_otp5290_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5290_msg_1(compact_otp5290_msg02(), error, ignore). compact_otp5290_msg_1(M1, DecodeExpect, EncodeExpect) -> Bin1 = list_to_binary(M1), case decode_message(megaco_compact_text_encoder, false, [], Bin1) of {ok, Msg} when DecodeExpect == ok -> io:format(" decoded", []), case encode_message(megaco_compact_text_encoder, [], Msg) of {ok, Bin1} when EncodeExpect == ok -> io:format(", encoded - equal:", []), ok; {ok, Bin2} when EncodeExpect == ok -> M2 = binary_to_list(Bin2), io:format(", encoded - not equal:", []), exit({messages_not_equal, Msg, M1, M2}); {ok, Bin3} when EncodeExpect == error -> M3 = binary_to_list(Bin3), io:format(", unexpected encode:", []), exit({unexpected_encode_success, Msg, M3}); _ when EncodeExpect == error -> io:format(", encode failed ", []), ok end; {ok, Msg} when DecodeExpect == error -> io:format(" decoded", []), exit({unexpected_decode_success, Msg}); _Else when DecodeExpect == error -> io:format(" decode failed ", []), ok; Else when DecodeExpect == ok -> io:format(" decode failed ", []), exit({unexpected_decode_result, Else}) end. compact_otp5290_msg01() -> "!/" ?VERSION_STR " \nT=12345678{C=*{CA{TP,PR}}}". compact_otp5290_msg02() -> "!/" ?VERSION_STR " \nT=12345678{C=*{CA{TP,PR,TP}}}". compact_otp5793_msg01(suite) -> []; compact_otp5793_msg01(Config) when is_list(Config) -> d("compact_otp5793_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5793(ok, pretty_otp5793_msg1()). compact_otp5793(Expected, Msg) -> expect_codec(Expected, megaco_compact_text_encoder, Msg, []). %% -------------------------------------------------------------- compact_otp5993_msg01(suite) -> []; compact_otp5993_msg01(Config) when is_list(Config) -> d("compact_otp5993_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5993(ok, compact_otp5993_msg01()). compact_otp5993_msg02(suite) -> []; compact_otp5993_msg02(Config) when is_list(Config) -> d("compact_otp5993_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5993(ok, compact_otp5993_msg02()). compact_otp5993_msg03(suite) -> []; compact_otp5993_msg03(Config) when is_list(Config) -> d("compact_otp5993_msg03 -> entry", []), ?ACQUIRE_NODES(1, Config), compact_otp5993(ok, compact_otp5993_msg03()). compact_otp5993(Expected, Msg) -> expect_codec(Expected, megaco_compact_text_encoder, Msg, []). compact_otp5993_msg01() -> MT = h221, T = #megaco_term_id{id = ?A4444}, TL = [T], MD = #'MuxDescriptor'{muxType = MT, termList = TL}, compact_otp5993_msg(MD). compact_otp5993_msg02() -> MT = h223, T1 = #megaco_term_id{id = ?A4445}, T2 = #megaco_term_id{id = ?A5556}, TL = [T1, T2], MD = #'MuxDescriptor'{muxType = MT, termList = TL}, compact_otp5993_msg(MD). compact_otp5993_msg(MD) when is_record(MD, 'MuxDescriptor') -> AmmDesc = {muxDescriptor, MD}, AmmReq = #'AmmRequest'{terminationID = [hd(MD#'MuxDescriptor'.termList)], descriptors = [AmmDesc]}, Cmd = {addReq, AmmReq}, CmdReq = #'CommandRequest'{command = Cmd}, ActReq = #'ActionRequest'{contextId = 5993, commandRequests = [CmdReq]}, TransReq = #'TransactionRequest'{transactionId = 3995, actions = [ActReq]}, Trans = {transactionRequest, TransReq}, Body = {transactions, [Trans]}, Msg = #'Message'{version = ?VERSION, mId = ?MG1_MID, messageBody = Body}, #'MegacoMessage'{mess = Msg}. compact_otp5993_msg03() -> T1 = #megaco_term_id{id = ?A4445}, T2 = #megaco_term_id{id = ?A5556}, TIDs = [T1, T2], AudRep = {contextAuditResult, TIDs}, CmdRep = {auditValueReply, AudRep}, ActRep = #'ActionReply'{contextId = 5993, commandReply = [CmdRep]}, TransRes = {actionReplies, [ActRep]}, TransRep = #'TransactionReply'{transactionId = 3995, transactionResult = TransRes}, Trans = {transactionReply, TransRep}, Body = {transactions, [Trans]}, Msg = #'Message'{version = ?VERSION, mId = ?MG1_MID, messageBody = Body}, #'MegacoMessage'{mess = Msg}. %% -------------------------------------------------------------- compact_otp6017_msg01(suite) -> []; compact_otp6017_msg01(Config) when is_list(Config) -> d("compact_otp6017_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), ok = compact_otp6017(0), ok. compact_otp6017_msg02(suite) -> []; compact_otp6017_msg02(Config) when is_list(Config) -> d("compact_otp6017_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), ok = compact_otp6017(16#FFFFFFFE), ok. compact_otp6017_msg03(suite) -> []; compact_otp6017_msg03(Config) when is_list(Config) -> d("compact_otp6017_msg03 -> entry", []), ?ACQUIRE_NODES(1, Config), ok = compact_otp6017(16#FFFFFFFF), ok. compact_otp6017(BadCID) -> M = compact_otp6017_msg(BadCID), Bin = list_to_binary(M), case decode_message(megaco_compact_text_encoder, false, [], Bin) of {ok, Msg} -> exit({unexpected_decode_success, {Msg, M}}); {error, Reason} when is_list(Reason) -> % Expected result case lists:keysearch(reason, 1, Reason) of {value, {reason, {_Line, _Mod, {bad_ContextID, BadCID}}}} -> io:format(" ~w", [BadCID]), ok; {value, {reason, ActualReason}} -> exit({unexpected_reason, ActualReason}); false -> exit({reason_not_found, Reason}) end; Crap -> exit({unexpected_decode_result, Crap}) end. compact_otp6017_msg(CID) when is_integer(CID) -> "MEGACO/" ?VERSION_STR " MG1 T=12345678{C=" ++ integer_to_list(CID) ++ "{SC=root{SV{MT=RS,RE=901}}}}". %% -------------------------------------------------------------- compact_otp7138_msg01(suite) -> []; compact_otp7138_msg01(Config) when is_list(Config) -> %% put(dbg, true), %% put(severity, trc), d("compact_otp7138_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = compact_otp7138_msg01(), EC = [], ok = compact_otp7138(EC, Msg), ok. compact_otp7138_msg02(suite) -> []; compact_otp7138_msg02(Config) when is_list(Config) -> %% put(dbg, true), %% put(severity, trc), d("compact_otp7138_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = compact_otp7138_msg02(), EC = [], ok = compact_otp7138(EC, Msg), ok. compact_otp7138_msg01() -> <<"!/2 \nT=1111{C=1{N=mgw2dev1/1{OE=16777985{ctyp/dtone{dtt=CT}}}}}">>. compact_otp7138_msg02() -> <<"!/2 \nT=1111{C=1{N=mgw2dev1/1{OE=16777985{ctyp/dtone{dtt=\"CT\"}}}}}">>. compact_otp7138(EC, BinMsg) -> d("compact_otp7138 -> " "~n ~p", [binary_to_list(BinMsg)]), Codec = megaco_compact_text_encoder, case decode_message(Codec, false, EC, BinMsg) of {ok, Msg} -> case encode_message(Codec, EC, Msg) of {ok, BinMsg} -> d("compact_otp7138 -> encode successfull: " "~n ~p", [binary_to_list(BinMsg)]), ok; {ok, BinMsg2} -> d("compact_otp7138 -> encode successfull but result differ: " "~n ~p", [binary_to_list(BinMsg2)]), ok; {error, Reason} -> e("encode failed: ~p", [Reason]), {error, Reason} end; {error, Reason} -> e("decode failed: ~p", [Reason]), {error, Reason} end. compact_otp7457_msg01(suite) -> []; compact_otp7457_msg01(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("compact_otp7457_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = compact_otp7457_msg01(), EC = [], ok = compact_otp7457(EC, Msg), ok. compact_otp7457_msg02(suite) -> []; compact_otp7457_msg02(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("compact_otp7457_msg02 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = compact_otp7457_msg02(), EC = [], ok = compact_otp7457(EC, Msg), ok. compact_otp7457_msg03(suite) -> []; compact_otp7457_msg03(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("compact_otp7457_msg03 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = compact_otp7457_msg03(), EC = [], ok = compact_otp7457(EC, Msg), ok. compact_otp7457_msg01() -> <<"!/2 \nT=15{C=-{SC=tdm12/1/1/*{SV{MT=RS,RE=900}}}}\n">>. compact_otp7457_msg02() -> <<"!/2 \nT=15{C=-{O-SC=tdm12/1/1/*{SV{MT=RS,RE=900}}}}\n">>. compact_otp7457_msg03() -> <<"!/2 \nT=15{C=-{W-SC=tdm12/1/1/*{SV{MT=RS,RE=900}}}}\n">>. compact_otp7457(EC, BinMsg) -> d("compact_otp7457 -> " "~n ~p", [binary_to_list(BinMsg)]), Codec = megaco_compact_text_encoder, case decode_message(Codec, false, EC, BinMsg) of {ok, Msg} -> case encode_message(Codec, EC, Msg) of {ok, BinMsg} -> d("compact_otp7457 -> encode successfull: " "~n ~p", [binary_to_list(BinMsg)]), ok; {ok, BinMsg2} -> d("compact_otp7457 -> " "encode successfull but result differ: " "~n ~p", [binary_to_list(BinMsg2)]), ok; {error, Reason} -> e("encode failed: ~p", [Reason]), {error, Reason} end; {error, Reason} -> e("decode failed: ~p", [Reason]), {error, Reason} end. compact_otp7534_msg01(suite) -> []; compact_otp7534_msg01(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("compact_otp7534_msg01 -> entry", []), Msg = otp7534_msg01(), compact_otp7534([], Msg). compact_otp7576_msg01(suite) -> []; compact_otp7576_msg01(Config) when is_list(Config) -> %% put(dbg, true), %% put(severity, trc), d("compact_otp7576_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = compact_otp7576_msg01(), EC = [], ok = compact_otp7576(EC, Msg), ok. compact_otp7576_msg01() -> M = "!/" ?VERSION_STR "[130.100.144.37]:2944\nT=10032{C=${tp{*,*,is,st=1},pr=6,a=rtp/2/${m{st=1{o{mo=so,rv=ON},l{ v=0 c=IN IP4 $ m=audio $ RTP/AVP 0 b=AS:64 a=rtpmap:0 PCMU/8000 }}},e=1{G/CAUSE}},a=rtp/2/${m{st=1{o{mo=rc,rv=ON},l{ v=0 c=IN IP4 $ m=audio $ RTP/AVP 0 b=AS:64 a=rtpmap:0 PCMU/8000 },r{ v=0 c=IN IP4 130.100.126.77 m=audio 8014 RTP/AVP 0 b=AS:64 a=rtpmap:0 PCMU/8000 }}},e=1{G/CAUSE}}}}", list_to_binary(M). compact_otp7576(EC, BinMsg) -> d("compact_otp7576 -> " "~n ~p", [binary_to_list(BinMsg)]), Codec = megaco_compact_text_encoder, case decode_message(Codec, false, EC, BinMsg) of {ok, Msg} -> case encode_message(Codec, EC, Msg) of {ok, BinMsg} -> d("compact_otp7138 -> encode successfull: " "~n ~p", [binary_to_list(BinMsg)]), ok; {ok, BinMsg2} -> d("compact_otp7138 -> encode successfull but result differ: " "~n ~p", [binary_to_list(BinMsg2)]), case decode_message(Codec, false, EC, BinMsg2) of {ok, Msg} -> d("compact_otp7138 -> " "extra verification decode ok", []), ok; {ok, Msg2} -> e("verification decode generated other message: " "~n Msg: ~p" "~n Msg2: ~p", [Msg, Msg2]), {error, {verification_decode, Msg, Msg2}} end; {error, Reason} -> e("encode failed: ~p", [Reason]), {error, Reason} end; {error, Reason} -> e("decode failed: ~p", [Reason]), {error, Reason} end. %% -------------------------------------------------------------- %% compact_otp7671_msg01(suite) -> []; compact_otp7671_msg01(Config) when is_list(Config) -> put(severity, trc), put(dbg, true), d("compact_otp7671_msg01 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = compact_otp7671( compact_otp7671_msg01(), [] ), erase(dbg), erase(severity), ok. compact_otp7671(Msg, Conf) -> compact_otp7671(Msg, Conf, ok). compact_otp7671(Msg, Conf, ExpectedEncode) -> compact_otp7671(Msg, Conf, ExpectedEncode, ok). compact_otp7671(Msg, Conf, ExpectedEncode, ExpectedDecode) -> otp7671(Msg, megaco_compact_text_encoder, Conf, ExpectedEncode, ExpectedDecode). %% "!/" ?VERSION_STR " \nT=172047781{C=-{MF=root{DM=DmName}}}", compact_otp7671_msg01() -> pretty_otp7671_msg01(). %% ============================================================== %% %% F l e x C o m p a c t T e s t c a s e s %% flex_compact_otp7138_msg01(suite) -> []; flex_compact_otp7138_msg01(Config) when is_list(Config) -> %% put(dbg, true), %% put(severity, trc), d("flex_compact_otp7138_msg01 -> entry", []), Msg = compact_otp7138_msg01(), Conf = flex_scanner_conf(Config), compact_otp7138([Conf], Msg). flex_compact_otp7138_msg02(suite) -> []; flex_compact_otp7138_msg02(Config) when is_list(Config) -> %% put(dbg, true), %% put(severity, trc), d("flex_compact_otp7138_msg02 -> entry", []), Msg = compact_otp7138_msg02(), Conf = flex_scanner_conf(Config), compact_otp7138([Conf], Msg). flex_compact_otp7431_msg01(suite) -> []; flex_compact_otp7431_msg01(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg01 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(ok, flex_compact_otp7431_msg1(), [Conf]). flex_compact_otp7431_msg02(suite) -> []; flex_compact_otp7431_msg02(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg02 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(error, flex_compact_otp7431_msg2(), [Conf]). flex_compact_otp7431_msg03(suite) -> []; flex_compact_otp7431_msg03(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg03 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(error, flex_compact_otp7431_msg3(), [Conf]). flex_compact_otp7431_msg04(suite) -> []; flex_compact_otp7431_msg04(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg04 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(error, flex_compact_otp7431_msg4(), [Conf]). flex_compact_otp7431_msg05(suite) -> []; flex_compact_otp7431_msg05(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg05 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(error, flex_compact_otp7431_msg5(), [Conf]). flex_compact_otp7431_msg06(suite) -> []; flex_compact_otp7431_msg06(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg06 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(error, flex_compact_otp7431_msg6(), [Conf]). flex_compact_otp7431_msg07(suite) -> []; flex_compact_otp7431_msg07(Config) when is_list(Config) -> %% put(severity,trc), %% put(dbg,true), d("flex_comppact_otp7431_msg07 -> entry", []), Conf = flex_scanner_conf(Config), flex_compact_otp7431(error, flex_compact_otp7431_msg7(), [Conf]). flex_compact_otp7431(Expected, Msg, Conf) -> otp7431(Expected, megaco_compact_text_encoder, Msg, Conf). flex_compact_otp7431_msg1() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a=recvonly }}}}}}". flex_compact_otp7431_msg2() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a= } }}}}}". flex_compact_otp7431_msg3() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a } }}}}}". flex_compact_otp7431_msg4() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a} }}}}}". flex_compact_otp7431_msg5() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v= } }}}}}". flex_compact_otp7431_msg6() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v } }}}}}". flex_compact_otp7431_msg7() -> "!/1 [124.124.124.222]:55555 P=10003{C=2000{A=a4444,A=a4445{M{ST=1{L{ v} }}}}}". flex_compact_otp7457_msg01(suite) -> []; flex_compact_otp7457_msg01(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("flex_compact_otp7457_msg01 -> entry", []), Msg = compact_otp7457_msg01(), Conf = flex_scanner_conf(Config), compact_otp7457([Conf], Msg). flex_compact_otp7457_msg02(suite) -> []; flex_compact_otp7457_msg02(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("flex_compact_otp7457_msg02 -> entry", []), Msg = compact_otp7457_msg02(), Conf = flex_scanner_conf(Config), compact_otp7457([Conf], Msg). flex_compact_otp7457_msg03(suite) -> []; flex_compact_otp7457_msg03(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("flex_compact_otp7457_msg03 -> entry", []), Msg = compact_otp7457_msg03(), Conf = flex_scanner_conf(Config), compact_otp7457([Conf], Msg). flex_compact_otp7534_msg01(suite) -> []; flex_compact_otp7534_msg01(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("flex_compact_otp7534_msg01 -> entry", []), Msg = otp7534_msg01(), Conf = flex_scanner_conf(Config), compact_otp7534([Conf], Msg). otp7534_msg01() -> <<"!/2 bgwch3_1\nP=62916991{C=-{AV=root{M{TS{ipra/ar=[interconnect,interconnect1,internal],SI=IV}},PG{root-2,ocp-1,it-1,nt-1,rtp-1,gm-1,ds-1,tman-1,xnq-1}}}}">>. compact_otp7534(EC, BinMsg) -> Codec = megaco_compact_text_encoder, otp7534(Codec, EC, BinMsg). otp7534(Codec, EC, BinMsg) -> d("otp7534 -> " "~n Codec: ~p" "~n ~p", [Codec, binary_to_list(BinMsg)]), case decode_message(Codec, false, EC, BinMsg) of {ok, Msg} -> case encode_message(Codec, EC, Msg) of {ok, BinMsg} -> d("otp7457 -> encode successfull: " "~n ~p", [binary_to_list(BinMsg)]), ok; {ok, BinMsg2} -> d("otp7457 -> " "encode successfull but result differ: " "~n ~p", [binary_to_list(BinMsg2)]), ok; {error, Reason} -> e("encode failed: ~p", [Reason]), {error, Reason} end; {error, Reason} -> e("decode failed: ~p", [Reason]), {error, Reason} end. flex_compact_otp7573_msg01(suite) -> []; flex_compact_otp7573_msg01(Config) when is_list(Config) -> put(dbg, true), put(severity, trc), d("flex_compact_otp7573_msg01 -> entry", []), Msg = otp7573_msg01(), Conf = flex_scanner_conf(Config), compact_otp7573([Conf], Msg). otp7573_msg01() -> <<"!/2 \nP=37775561{C=-{AV=root{M{TS{root/maxnumberofcontexts=16000,root/maxterminationspercontext=2,root/normalmgexecutiontime=3000,root/normalmgcexecutiontime=3000,root/mgprovisionalresponsetimervalue=2000,root/mgcprovisionalresponsetimervalue=2000,root/mgcoriginatedpendinglimit=5,root/mgoriginatedpendinglimit=5,ipra/ar=[\"\"],SI=IV}},PG{root-2,ocp-1,it-1,nt-1,rtp-1,gm-1,ds-1,tman-1,xnq-1,ipra-1}}}}">>. compact_otp7573(EC, BinMsg) -> Codec = megaco_compact_text_encoder, otp7573(Codec, EC, BinMsg). otp7573(Codec, EC, BinMsg) -> d("otp7573 -> " "~n Codec: ~p" "~n ~p", [Codec, binary_to_list(BinMsg)]), case decode_message(Codec, false, EC, BinMsg) of {ok, Msg} -> case encode_message(Codec, EC, Msg) of {ok, BinMsg} -> d("otp7573 -> encode successfull: " "~n ~p", [binary_to_list(BinMsg)]), ok; {ok, BinMsg2} -> d("otp7573 -> " "encode successfull but result differ: " "~n ~p", [binary_to_list(BinMsg2)]), ok; {error, Reason} -> e("encode failed: ~p", [Reason]), {error, Reason} end; {error, Reason} -> e("decode failed: ~p", [Reason]), {error, Reason} end. flex_compact_otp7576_msg01(suite) -> []; flex_compact_otp7576_msg01(Config) when is_list(Config) -> %% put(dbg, true), %% put(severity, trc), d("flex_compact_otp7576_msg01 -> entry", []), Msg = compact_otp7576_msg01(), Conf = flex_scanner_conf(Config), compact_otp7576([Conf], Msg). %% ============================================================== %% %% P r e t t y T e s t c a s e s %% pretty_otp4632_msg1(suite) -> []; pretty_otp4632_msg1(Config) when is_list(Config) -> d("pretty_otp4632_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4632_msg1(), case encode_message(megaco_pretty_text_encoder, [], Msg0) of {ok, BinMsg} when is_binary(BinMsg) -> {ok, Msg1} = decode_message(megaco_pretty_text_encoder, false, [], BinMsg), ok = chk_MegacoMessage(Msg0, Msg1); Else -> t("pretty_otp4632_msg1 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4632_msg1() -> msg4(?MG1_MID_NO_PORT, "901 mg col boot"). pretty_otp4632_msg2(suite) -> []; pretty_otp4632_msg2(Config) when is_list(Config) -> d("pretty_otp4632_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4632_msg2(), case encode_message(megaco_pretty_text_encoder, [], Msg0) of {ok, BinMsg} when is_binary(BinMsg) -> {ok, Msg1} = decode_message(megaco_pretty_text_encoder, false, [], BinMsg), ok = chk_MegacoMessage(Msg0,Msg1); Else -> t("pretty_otp4632_msg2 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4632_msg2() -> msg4(?MG1_MID_NO_PORT, "901"). pretty_otp4632_msg3(suite) -> []; pretty_otp4632_msg3(Config) when is_list(Config) -> d("pretty_otp4632_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4632_msg3(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {ok, Msg} when is_record(Msg, 'MegacoMessage') -> {ok, Bin1} = encode_message(megaco_pretty_text_encoder, [], Msg), Msg1 = binary_to_list(Bin1), %% io:format("Msg1:~n~s~n", [Msg1]), Msg0 = Msg1, ok; Else -> t("pretty_otp4632_msg3 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4632_msg3() -> M = "MEGACO/" ?VERSION_STR " [124.124.124.222]\nTransaction = 9998 {\n\tContext = - {\n\t\tServiceChange = root {\n\t\t\tServices {\n\t\t\t\tMethod = Restart,\n\t\t\t\tServiceChangeAddress = 55555,\n\t\t\t\tProfile = resgw/1,\n\t\t\t\tReason = \"901\"\n\t\t\t}\n\t\t}\n\t}\n}", M. pretty_otp4632_msg4(suite) -> []; pretty_otp4632_msg4(Config) when is_list(Config) -> d("pretty_otp4632_msg4 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4632_msg4(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {ok, Msg} when is_record(Msg, 'MegacoMessage') -> {ok, Bin1} = encode_message(megaco_pretty_text_encoder, [], Msg), Msg1 = binary_to_list(Bin1), %% io:format("Msg1:~n~s~n", [Msg1]), pretty_otp4632_msg4_chk(Msg0,Msg1); Else -> t("pretty_otp4632_msg4 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4632_msg4() -> M = "MEGACO/" ?VERSION_STR " [124.124.124.222]\nTransaction = 9998 {\n\tContext = - {\n\t\tServiceChange = root {\n\t\t\tServices {\n\t\t\t\tMethod = Restart,\n\t\t\t\tServiceChangeAddress = 55555,\n\t\t\t\tProfile = resgw/1,\n\t\t\t\tReason = 901\n\t\t\t}\n\t\t}\n\t}\n}", M. pretty_otp4632_msg4_chk([], []) -> exit(messages_not_eq); pretty_otp4632_msg4_chk([], Rest1) -> exit({messages_not_eq1, Rest1}); pretty_otp4632_msg4_chk(Rest0, []) -> exit({messages_not_eq0, Rest0}); pretty_otp4632_msg4_chk([$R,$e,$a,$s,$o,$n,$ ,$=,$ ,$9,$0,$1|_Rest0], [$R,$e,$a,$s,$o,$n,$ ,$=,$ ,$",$9,$0,$1,$"|_Rest1]) -> ok; pretty_otp4632_msg4_chk([_|Rest0], [_|Rest1]) -> pretty_otp4632_msg4_chk(Rest0,Rest1). pretty_otp4710_msg1(suite) -> []; pretty_otp4710_msg1(Config) when is_list(Config) -> d("pretty_otp4710_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4710_msg1(), case encode_message(megaco_pretty_text_encoder, [], Msg0) of {ok, Bin} when is_binary(Bin) -> {ok, Msg1} = decode_message(megaco_pretty_text_encoder, false, [], Bin), ok = chk_MegacoMessage(Msg0,Msg1); Else -> t("pretty_otp4710_msg1 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4710_msg1() -> msg40(). pretty_otp4710_msg2(suite) -> []; pretty_otp4710_msg2(Config) when is_list(Config) -> d("pretty_otp4710_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4710_msg2(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {ok, Msg} when is_record(Msg, 'MegacoMessage') -> {ok, Bin1} = encode_message(megaco_pretty_text_encoder, [], Msg), Msg1 = binary_to_list(Bin1), %% io:format("Msg1:~n~s~n", [Msg1]), pretty_otp4710_msg2_chk(Msg0,Msg1); Else -> t("pretty_otp4710_msg2 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4710_msg2() -> "Authentication = 0xEFCDAB89:0x12345678:0x1234567889ABCDEF76543210\nMEGACO/" ?VERSION_STR " [124.124.124.222]\nTransaction = 9998 {\n\tContext = - {\n\t\tServiceChange = root {\n\t\t\tServices {\n\t\t\t\tMethod = Restart,\n\t\t\t\tServiceChangeAddress = 55555,\n\t\t\t\tProfile = resgw/1,\n\t\t\t\tReason = \"901 mg col boot\"\n\t\t\t}\n\t\t}\n\t}\n}". pretty_otp4710_msg2_chk(Msg,Msg) -> ok; pretty_otp4710_msg2_chk( [$A,$u,$t,$h,$e,$n,$t,$i,$c,$a,$t,$i,$o,$n,$=,$ |Msg0], [$A,$u,$t,$h,$e,$n,$t,$i,$c,$a,$t,$i,$o,$n,$=,$ |Msg1]) -> {AH0, Rest0} = pretty_otp4710_msg2_chk_ah(Msg0, []), {AH1, Rest1} = pretty_otp4710_msg2_chk_ah(Msg1, []), case AH0 == AH1 of true -> exit({message_not_equal, Rest0, Rest1}); false -> exit({auth_header_not_equal, AH0, AH1}) end. pretty_otp4710_msg2_chk_ah([], _Acc) -> exit(no_auth_header_found); pretty_otp4710_msg2_chk_ah([$M,$E,$G,$A,$C,$O,$/,_|Rest], Acc) -> {lists:reverse(Acc), Rest}; pretty_otp4710_msg2_chk_ah([C|R], Acc) -> pretty_otp4710_msg2_chk_ah(R, [C|Acc]). pretty_otp4945_msg1(suite) -> []; pretty_otp4945_msg1(Config) when is_list(Config) -> d("pretty_otp4945_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4945_msg1(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {missing_required_serviceChangeParm, [serviceChangeReason]} -> ok; Else -> t("pretty_otp4945_msg1 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end; Else -> io:format("pretty_otp4945_msg1 -> " "~n Else: ~w" "~n", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4945_msg1() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { Method = Restart, ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". pretty_otp4945_msg2(suite) -> []; pretty_otp4945_msg2(Config) when is_list(Config) -> d("pretty_otp4945_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4945_msg2(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {missing_required_serviceChangeParm, [serviceChangeMethod]} -> ok; Else -> t("pretty_otp4945_msg2 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end; Else -> t("pretty_otp4945_msg2 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4945_msg2() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { Reason = 901, ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". pretty_otp4945_msg3(suite) -> []; pretty_otp4945_msg3(Config) when is_list(Config) -> d("pretty_otp4945_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4945_msg3(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {missing_required_serviceChangeParm, [serviceChangeReason, serviceChangeMethod]} -> ok; {missing_required_serviceChangeParm, [serviceChangeMethod, serviceChangeReason]} -> ok; Else -> t("pretty_otp4945_msg3 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end; Else -> t("pretty_otp4945_msg3 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4945_msg3() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". pretty_otp4945_msg4(suite) -> []; pretty_otp4945_msg4(Config) when is_list(Config) -> d("pretty_otp4945_msg4 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4945_msg4(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {ok, _} -> ok; Else -> t("pretty_otp4945_msg4 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4945_msg4() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { Method = Restart, Reason = 901, ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". pretty_otp4945_msg5(suite) -> []; pretty_otp4945_msg5(Config) when is_list(Config) -> d("pretty_otp4945_msg5 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4945_msg5(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {at_most_once_serviceChangeParm, {profile, _Val1, _Val2}} -> ok; Else -> io:format("pretty_otp4945_msg6 -> " "~n Else: ~w" "~n", [Else]), exit({unexpected_decode_result, Else}) end; Else -> t("pretty_otp4945_msg5 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4945_msg5() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { Method = Restart, Reason = 901, Profile = ResGW/1, ServiceChangeAddress = 55555, Profile = ResGW/2 } } } }". pretty_otp4945_msg6(suite) -> []; pretty_otp4945_msg6(Config) when is_list(Config) -> d("pretty_otp4945_msg6 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4945_msg6(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {not_both_address_mgcid_serviceChangeParm, _Val1, _Val2} -> ok; Else -> io:format("pretty_otp4945_msg6 -> " "~n Else: ~w" "~n", [Else]), exit({unexpected_decode_result, Else}) end; Else -> t("pretty_otp4945_msg6 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4945_msg6() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { Method = Restart, Reason = 901, ServiceChangeAddress = 55555, MgcIdToTry = kalle, Profile = ResGW/1 } } } }". pretty_otp4949_msg1(suite) -> []; pretty_otp4949_msg1(Config) when is_list(Config) -> d("pretty_otp4949_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4949_msg1(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {ok, _} -> ok; Else -> t("pretty_otp4949_msg1 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4949_msg1() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Reply = 9998 { Context = - { ServiceChange = ROOT { Services { ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". pretty_otp4949_msg2(suite) -> []; pretty_otp4949_msg2(Config) when is_list(Config) -> d("pretty_otp4949_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4949_msg2(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {at_most_once_servChgReplyParm, {profile, _Val1, _Val2}} -> ok; Else -> io:format("pretty_otp4949_msg2 -> " "~n Else: ~w" "~n", [Else]), exit({unexpected_decode_result, Else}) end; Else -> t("pretty_otp4949_msg2 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4949_msg2() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Reply = 9998 { Context = - { ServiceChange = ROOT { Services { Profile = ResGW/1, ServiceChangeAddress = 55555, Profile = ResGW/2 } } } }". pretty_otp4949_msg3(suite) -> []; pretty_otp4949_msg3(Config) when is_list(Config) -> d("pretty_otp4949_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp4949_msg3(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {not_both_address_mgcid_servChgReplyParm, _Val1, _Val2} -> ok; Else -> io:format("pretty_otp4949_msg3 -> " "~n Else: ~w" "~n", [Else]), exit({unexpected_decode_result, Else}) end; Else -> t("pretty_otp4949_msg3 -> " "~n Else: ~w", [Else]), exit({unexpected_decode_result, Else}) end. pretty_otp4949_msg3() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Reply = 9998 { Context = - { ServiceChange = ROOT { Services { ServiceChangeAddress = 55555, MgcIdToTry = kalle, Profile = ResGW/1 } } } }". pretty_otp5042_msg1(suite) -> []; pretty_otp5042_msg1(Config) when is_list(Config) -> d("pretty_otp5042_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg0 = pretty_otp5042_msg1(), Bin0 = list_to_binary(Msg0), case decode_message(megaco_pretty_text_encoder, false, [], Bin0) of {error, [{reason, Reason}|_]} -> case Reason of {_, _Mod, {bad_timeStamp, TimeStamp}} -> exit({bad_timeStamp, TimeStamp}); _ -> io:format("pretty_otp5042_msg1 -> " "~n Reason: ~w" "~n", [Reason]), exit({unexpected_decode_result, Reason}) end; {ok, M} -> t("pretty_otp5042_msg1 -> successfull decode:" "~n~p", [M]), ok end. pretty_otp5042_msg1() -> "MEGACO/" ?VERSION_STR " :2944 Transaction = 102 { Context = 5 { Notify = MUX/1 { ObservedEvents = 1 { h245bh/h245msgin { Stream = 1 , h245enc = 0270020600088175000653401004100403E802E00180018001780680000034301160000700088175010101007A0100020001800001320000C0000219D005027F0070500100040100021080000319D005027F00504001008000041C001250000700088175010000400280010003000880000518AA027F400006850130008011020100000001030002000300040005000006 } } } } }". pretty_otp5068_msg1(suite) -> []; pretty_otp5068_msg1(Config) when is_list(Config) -> d("pretty_otp5068_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), Msg = pretty_otp5068_msg1(), case encode_message(megaco_pretty_text_encoder, [], Msg) of {error, Reason} -> % io:format("pretty_otp5068_msg1 -> " % "~n Reason: ~w" % "~n", [Reason]), exit({unexpected_encode_result, Reason}); {ok, Bin} -> % io:format("pretty_otp5068_msg1 -> successfull encode:" % "~n~s~n", [binary_to_list(Bin)]), case decode_message(megaco_pretty_text_encoder, false, [], Bin) of {ok, _} -> % io:format("pretty_otp5068_msg1 -> ok~n", []), ok; Else -> % io:format("pretty_otp5068_msg1 -> ~n~p~n", [Else]), exit({unexpected_decode_result, Else}) end end. pretty_otp5068_msg1() -> {'MegacoMessage', asn1_NOVALUE, {'Message', 2, {deviceName,[109,103,51,51]}, {transactions, [{transactionReply, {'TransactionReply', 190, asn1_NOVALUE, {actionReplies, [{'ActionReply', %% Comments: This is repeated many times. 0, asn1_NOVALUE, asn1_NOVALUE, [{auditValueReply, {auditResult, {'AuditResult', {megaco_term_id,false, [[99,101,100,101,118,49,47,52,47,49,47,49],[51,49]]}, [{mediaDescriptor, {'MediaDescriptor', {'TerminationStateDescriptor', [], asn1_NOVALUE, inSvc}, asn1_NOVALUE}}]}}}]}]}}}]}}}. pretty_otp5085_msg1(suite) -> []; pretty_otp5085_msg1(Config) when is_list(Config) -> d("pretty_otp5085_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(ok, pretty_otp5085_msg1()). pretty_otp5085_msg2(suite) -> []; pretty_otp5085_msg2(Config) when is_list(Config) -> d("pretty_otp5085_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(error, pretty_otp5085_msg2()). pretty_otp5085_msg3(suite) -> []; pretty_otp5085_msg3(Config) when is_list(Config) -> d("pretty_otp5085_msg3 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(ok, pretty_otp5085_msg3()). pretty_otp5085_msg4(suite) -> []; pretty_otp5085_msg4(Config) when is_list(Config) -> d("pretty_otp5085_msg4 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(ok, pretty_otp5085_msg4()). pretty_otp5085_msg5(suite) -> []; pretty_otp5085_msg5(Config) when is_list(Config) -> d("pretty_otp5085_msg5 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(ok, pretty_otp5085_msg5()). pretty_otp5085_msg6(suite) -> []; pretty_otp5085_msg6(Config) when is_list(Config) -> d("pretty_otp5085_msg6 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(ok, pretty_otp5085_msg6()). pretty_otp5085_msg7(suite) -> []; pretty_otp5085_msg7(Config) when is_list(Config) -> d("pretty_otp5085_msg7 -> entry", []), ?ACQUIRE_NODES(1, Config), pretty_otp5085(ok, pretty_otp5085_msg7()). pretty_otp5085(Expected, Msg) -> pretty_otp5085(Expected, Msg, []). pretty_otp5085(Expected, Msg, Conf) -> t("pretty_otp5085 -> entry with" "~n Expected: ~p" "~n Msg: ~p", [Expected, Msg]), case (catch encode_message(megaco_pretty_text_encoder, Conf, Msg)) of {error, Reason} when Expected == error -> d("pretty_otp5085 -> encode failed as expected" "~n Reason: ~w", [Reason]), ok; {error, Reason} -> e("pretty_otp5085 -> encode failed unexpectedly: " "~n Reason: ~w", [Reason]), exit({unexpected_encode_result, Reason}); {ok, Bin} when Expected == error -> e("pretty_otp5085 -> encode succeded unexpectedly: " "~n ~w", [binary_to_list(Bin)]), exit({unexpected_encode_result, binary_to_list(Bin)}); {ok, Bin} -> d("pretty_otp5085 -> successfull encode as expected:" "~n~s", [binary_to_list(Bin)]), case decode_message(megaco_pretty_text_encoder, false, Conf, Bin) of {ok, Msg} -> d("pretty_otp5085 -> successfull decode~n", []), ok; {ok, Msg2} -> e("pretty_otp5085 -> successfull decode" " - but not equal", []), exit({unexpected_decode_result, Msg, Msg2}); Else -> e("pretty_otp5085 -> decode failed:~n~p", [Else]), exit({unexpected_decode_result, Else}) end end. pretty_otp5085_msg1() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"mg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, {'ErrorDescriptor',504,asn1_NOVALUE}, asn1_NOVALUE, [] } ] } } } ] } } }. pretty_otp5085_msg2() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"mg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, asn1_NOVALUE, asn1_NOVALUE, [] } ] } } } ] } } }. pretty_otp5085_msg3() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"mg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, asn1_NOVALUE, #'ContextRequest'{priority = 3}, [] } ] } } } ] } } }. pretty_otp5085_msg4() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"mg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, asn1_NOVALUE, asn1_NOVALUE, [{addReply, cre_AmmsReply([#megaco_term_id{id = ?A4444}])}, {notifyReply, cre_NotifyRep([#megaco_term_id{id = ?A5555}])}] } ] } } } ] } } }. pretty_otp5085_msg5() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"mg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, asn1_NOVALUE, #'ContextRequest'{priority = 5}, [{addReply, cre_AmmsReply([#megaco_term_id{id = ?A4444}])}, {notifyReply, cre_NotifyRep([#megaco_term_id{id = ?A5555}])}] } ] } } } ] } } }. pretty_otp5085_msg6() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"msg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, {'ErrorDescriptor',504,asn1_NOVALUE}, #'ContextRequest'{priority = 6}, [{addReply, cre_AmmsReply([#megaco_term_id{id = ?A4444}])}, {notifyReply, cre_NotifyRep([#megaco_term_id{id = ?A5555}])}] } ] } } } ] } } }. pretty_otp5085_msg7() -> {'MegacoMessage', asn1_NOVALUE, {'Message', ?VERSION, {deviceName,"msg36"}, {transactions, [{transactionReply, {'TransactionReply', 230, asn1_NOVALUE, {actionReplies, [{'ActionReply', 400, {'ErrorDescriptor',504,asn1_NOVALUE}, #'ContextRequest'{priority = 7}, [{notifyReply, cre_NotifyRep([#megaco_term_id{id = ?A5555}])}] } ] } } } ] } } }. pretty_otp5600_msg1(suite) -> []; pretty_otp5600_msg1(Config) when is_list(Config) -> d("pretty_otp5600_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), %% put(severity,trc), %% put(dbg,true), pretty_otp5600(ok, pretty_otp5600_msg1()). pretty_otp5600_msg2(suite) -> []; pretty_otp5600_msg2(Config) when is_list(Config) -> d("pretty_otp5600_msg2 -> entry", []), ?ACQUIRE_NODES(1, Config), %% put(severity,trc), %% put(dbg,true), pretty_otp5600(ok, pretty_otp5600_msg2()). pretty_otp5600(Expected, Msg) -> pretty_otp5600(Expected, Msg, []). pretty_otp5600(Expected, Msg, Conf) -> t("pretty_otp5600 -> entry with" "~n Expected: ~p" "~n Msg: ~p", [Expected, Msg]), case (catch encode_message(megaco_pretty_text_encoder, Conf, Msg)) of {error, Reason} when Expected == error -> d("pretty_otp5600 -> encode failed as expected" "~n Reason: ~w", [Reason]), ok; {error, Reason} -> e("pretty_otp5600 -> encode failed unexpectedly: " "~n Reason: ~w", [Reason]), exit({unexpected_encode_result, Reason}); {ok, Bin} when Expected == error -> e("pretty_otp5600 -> encode succeded unexpectedly: " "~n ~w", [binary_to_list(Bin)]), exit({unexpected_encode_result, binary_to_list(Bin)}); {ok, Bin} -> d("pretty_otp5600 -> successfull encode as expected:" "~n~s", [binary_to_list(Bin)]), case decode_message(megaco_pretty_text_encoder, false, Conf, Bin) of {ok, Msg} -> d("pretty_otp5600 -> successfull decode~n", []), ok; {ok, Msg2} -> e("pretty_otp5600 -> successfull decode" " - but not equal", []), exit({unexpected_decode_result, Msg, Msg2}); Else -> e("pretty_otp5600 -> decode failed:~n~p", [Else]), exit({unexpected_decode_result, Else}) end end. pretty_otp5600_msg1() -> SRE = #'SecondRequestedEvent'{ pkgdName = "al/on", evParList = [] }, SED = #'SecondEventsDescriptor'{ requestID = 2, eventList = [ SRE ] }, SIG = { signal, #'Signal'{ signalName = "cg/dt", sigParList = [] } }, RA = #'RequestedActions'{ secondEvent = SED, signalsDescriptor = [ SIG ] }, RE = #'RequestedEvent'{ pkgdName = "al/of", eventAction = RA, evParList = [] }, EV = #'EventsDescriptor'{ requestID = 1, eventList = [ RE ] }, TermID = {megaco_term_id, true, [[$*]] }, AMMR = #'AmmRequest'{ terminationID = [ TermID ], descriptors = [ { eventsDescriptor, EV } ] }, CR = #'CommandRequest'{command = {modReq, AMMR}}, AR = #'ActionRequest'{contextId = ?megaco_null_context_id, commandRequests = [CR]}, ARs = [AR], TR = #'TransactionRequest'{transactionId = 5600, actions = ARs}, TRs = [{transactionRequest, TR}], Mess = #'Message'{version = ?VERSION, mId = ?MGC_MID, messageBody = {transactions, TRs}}, #'MegacoMessage'{mess = Mess}. pretty_otp5600_msg2() -> SIG = { signal, #'Signal'{ signalName = "cg/dt", sigParList = [] } }, SRA = #'SecondRequestedActions'{ signalsDescriptor = [ SIG ] }, SRE = #'SecondRequestedEvent'{ pkgdName = "al/on", eventAction = SRA, evParList = [] }, SED = #'SecondEventsDescriptor'{ requestID = 2, eventList = [ SRE ] }, RA = #'RequestedActions'{ secondEvent = SED }, RE = #'RequestedEvent'{ pkgdName = "al/of", eventAction = RA, evParList = [] }, EV = #'EventsDescriptor'{ requestID = 1, eventList = [ RE ] }, TermID = {megaco_term_id, true, [[$*]] }, AMMR = #'AmmRequest'{ terminationID = [ TermID ], descriptors = [ { eventsDescriptor, EV } ] }, CR = #'CommandRequest'{command = {modReq, AMMR}}, AR = #'ActionRequest'{contextId = ?megaco_null_context_id, commandRequests = [CR]}, ARs = [AR], TR = #'TransactionRequest'{transactionId = 5600, actions = ARs}, TRs = [{transactionRequest, TR}], Mess = #'Message'{version = ?VERSION, mId = ?MGC_MID, messageBody = {transactions, TRs}}, #'MegacoMessage'{mess = Mess}. pretty_otp5601_msg1(suite) -> []; pretty_otp5601_msg1(Config) when is_list(Config) -> d("pretty_otp5601_msg1 -> entry", []), ?ACQUIRE_NODES(1, Config), %% put(severity,trc), %% put(dbg,true), pretty_otp5601(ok, pretty_otp5601_msg1()). pretty_otp5601(Expected, Msg) -> pretty_otp5601(Expected, Msg, []). pretty_otp5601(Expected, Msg, Conf) -> t("pretty_otp5601 -> entry with" "~n Expected: ~p" "~n Msg: ~p", [Expected, Msg]), case (catch encode_message(megaco_pretty_text_encoder, Conf, Msg)) of {error, Reason} when Expected == error -> d("pretty_otp5601 -> encode failed as expected" "~n Reason: ~w", [Reason]), ok; {error, Reason} -> e("pretty_otp5601 -> encode failed unexpectedly: " "~n Reason: ~w", [Reason]), exit({unexpected_encode_result, Reason}); {ok, Bin} when Expected == error -> e("pretty_otp5601 -> encode succeded unexpectedly: " "~n ~w", [binary_to_list(Bin)]), exit({unexpected_encode_result, binary_to_list(Bin)}); {ok, Bin} -> d("pretty_otp5601 -> successfull encode as expected:" "~n~s", [binary_to_list(Bin)]), case decode_message(megaco_pretty_text_encoder, false, Conf, Bin) of {ok, Msg} -> d("pretty_otp5601 -> successfull decode~n", []), ok; {ok, Msg2} -> e("pretty_otp5601 -> successfull decode" " - but not equal", []), exit({unexpected_decode_result, Msg, Msg2}); Else -> e("pretty_otp5601 -> decode failed:~n~p", [Else]), exit({unexpected_decode_result, Else}) end end. pretty_otp5601_msg1() -> SRE1 = #'SecondRequestedEvent'{ pkgdName = "al/on", evParList = [] }, SRA = #'SecondRequestedActions'{ eventDM = { digitMapName, "dialllan0" }}, SRE2 = #'SecondRequestedEvent'{ pkgdName = "dd/ce", eventAction = SRA, evParList = [] }, SED = #'SecondEventsDescriptor'{ requestID = 2, eventList = [ SRE1, SRE2 ] }, RA = #'RequestedActions'{ secondEvent = SED }, RE = #'RequestedEvent'{ pkgdName = "al/of", eventAction = RA, evParList = [] }, EV = #'EventsDescriptor'{ requestID = 1, eventList = [ RE ] }, TermID = {megaco_term_id, true, [[$*]] }, AMMR = #'AmmRequest'{ terminationID = [ TermID ], descriptors = [ { eventsDescriptor, EV } ] }, CR = #'CommandRequest'{command = {modReq, AMMR}}, AR = #'ActionRequest'{contextId = ?megaco_null_context_id, commandRequests = [CR]}, ARs = [AR], TR = #'TransactionRequest'{transactionId = 5600, actions = ARs}, TRs = [{transactionRequest, TR}], Mess = #'Message'{version = ?VERSION, mId = ?MGC_MID, messageBody = {transactions, TRs}}, #'MegacoMessage'{mess = Mess}. pretty_otp5793_msg01(suite) -> []; pretty_otp5793_msg01(Config) when is_list(Config) -> d("pretty_otp5793_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), %% put(severity,trc), %% put(dbg,true), pretty_otp5793(ok, pretty_otp5793_msg1()). pretty_otp5793(Expected, Msg) -> expect_codec(Expected, megaco_pretty_text_encoder, Msg, []). pretty_otp5793(Expected, Msg, Conf) -> expect_codec(Expected, megaco_pretty_text_encoder, Msg, Conf). pretty_otp5793_msg1() -> {'MegacoMessage',asn1_NOVALUE, {'Message',2, {deviceName,"bs_sbg_4/99"}, {transactions, [{transactionReply, {'TransactionReply', 370, asn1_NOVALUE, {actionReplies, [{'ActionReply', 3, asn1_NOVALUE, asn1_NOVALUE, [{auditValueReply, {contextAuditResult, [{megaco_term_id, false, ["ip", "104", "1", "18"]}]}}, {auditValueReply, {contextAuditResult, [{megaco_term_id, false, ["ip", "104", "2", "19"]}]}}]}]}}}]}}}. pretty_otp5882_msg01(suite) -> []; pretty_otp5882_msg01(Config) when is_list(Config) -> d("pretty_otp5882_msg01 -> entry", []), ?ACQUIRE_NODES(1, Config), %% put(severity,trc), %% put(dbg,true), pretty_otp5882(). pretty_otp5882() -> otp5882(megaco_pretty_text_encoder, []). otp5882(Codec, Conf) -> Msg = pretty_otp5882_msg01(), case (catch encode_message(Codec, Conf, Msg)) of {error, {message_encode_failed, {error, {ActualReason, _}}, _}} -> case ActualReason of {invalid_LocalControlDescriptor, empty} -> ok; _ -> exit({unexpected_error_actual_reason, ActualReason}) end; {error, Reason} -> exit({unexpected_error_reason, Reason}); {ok, Bin} -> exit({unexpected_encode_sucess, binary_to_list(Bin)}) end. pretty_otp5882_msg01() -> LCD = #'LocalControlDescriptor'{}, % Create illegal LCD Parms = ?MSG_LIB:cre_StreamParms(LCD), StreamDesc = ?MSG_LIB:cre_StreamDescriptor(1, Parms), MediaDesc = ?MSG_LIB:cre_MediaDescriptor([StreamDesc]), AmmReq = ?MSG_LIB:cre_AmmRequest([#megaco_term_id{id = ?A4445}], [{mediaDescriptor, MediaDesc}]), Cmd = ?MSG_LIB:cre_Command(modReq, AmmReq), CmdReq = ?MSG_LIB:cre_CommandRequest(Cmd), CID = ?MSG_LIB:cre_ContextID(5882), ActReq = ?MSG_LIB:cre_ActionRequest(CID, [CmdReq]), Actions = [ActReq], TransId = ?MSG_LIB:cre_TransactionId(7302), TransReq = ?MSG_LIB:cre_TransactionRequest(TransId, Actions), Trans = ?MSG_LIB:cre_Transaction(TransReq), Mid = ?MG1_MID, Mess = ?MSG_LIB:cre_Message(?VERSION, Mid, [Trans]), ?MSG_LIB:cre_MegacoMessage(Mess). %% -------------------------------------------------------------- %% pretty_otp6490_msg01(suite) -> []; pretty_otp6490_msg01(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp6490_msg01 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp6490( pretty_otp6490_msg01(), [] ), %% erase(dbg), %% erase(severity), ok. pretty_otp6490_msg02(suite) -> []; pretty_otp6490_msg02(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp6490_msg02 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp6490( pretty_otp6490_msg02(), [] ), %% erase(severity), %% erase(dbg), ok. pretty_otp6490_msg03(suite) -> []; pretty_otp6490_msg03(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp6490_msg03 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp6490( pretty_otp6490_msg03(), [] ), %% erase(severity), %% erase(dbg), ok. pretty_otp6490_msg04(suite) -> []; pretty_otp6490_msg04(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp6490_msg04 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp6490( pretty_otp6490_msg04(), [] ), %% erase(severity), %% erase(dbg), ok. pretty_otp6490_msg05(suite) -> []; pretty_otp6490_msg05(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp6490_msg05 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp6490( pretty_otp6490_msg05(), [] ), %% erase(severity), %% erase(dbg), ok. pretty_otp6490_msg06(suite) -> []; pretty_otp6490_msg06(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp6490_msg06 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp6490( pretty_otp6490_msg06(), [] ), %% erase(severity), %% erase(dbg), ok. pretty_otp6490(Msg, Conf) -> pretty_otp6490(Msg, Conf, ok). pretty_otp6490(Msg, Conf, ExpectedEncode) -> pretty_otp6490(Msg, Conf, ExpectedEncode, ok). pretty_otp6490(Msg, Conf, ExpectedEncode, ExpectedDecode) -> otp6490(Msg, megaco_pretty_text_encoder, Conf, ExpectedEncode, ExpectedDecode). otp6490(Msg, Codec, Conf, ExpectedEncode, ExpectedDecode) -> case (catch encode_message(Codec, Conf, Msg)) of {error, _Reason} when ExpectedEncode == error -> ok; {error, Reason} when ExpectedEncode == ok -> exit({unexpected_encode_failure, Reason}); {ok, Bin} when ExpectedEncode == error -> exit({unexpected_encode_success, Msg, binary_to_list(Bin)}); {ok, Bin} when ExpectedEncode == ok -> case decode_message(Codec, false, Conf, Bin) of {ok, Msg} when ExpectedDecode == ok -> ok; {ok, Msg} when ExpectedDecode == error -> exit({unexpected_decode_success, Msg}); {ok, Msg2} when ExpectedDecode == ok -> exit({unexpected_decode_result, Msg, Msg2}); {ok, Msg2} when ExpectedDecode == error -> exit({unexpected_decode_success, Msg, Msg2}); {error, _Reason} when ExpectedDecode == error -> ok; {error, Reason} when ExpectedDecode == ok -> exit({unexpected_decode_failure, Msg, Reason}) end end. pretty_otp6490_msg(EBD) -> AmmDesc = ?MSG_LIB:cre_AmmDescriptor(EBD), AmmReq = cre_AmmReq([#megaco_term_id{id = ?A4445}], [AmmDesc]), CmdReq = cre_CmdReq({modReq, AmmReq}), CID = cre_CtxID(64901), ActReq = cre_ActReq(CID, [CmdReq]), Actions = [ActReq], TransId = cre_TransId(64902), TransReq = cre_TransReq(TransId, Actions), Trans = cre_Trans(TransReq), Mid = ?MG1_MID, Mess = cre_Msg(Mid, [Trans]), cre_MegacoMessage(Mess). pretty_otp6490_msg01() -> EvSpecs = [], % This will result in an error EBD = EvSpecs, % This is because the lib checks that the size is valid pretty_otp6490_msg(EBD). pretty_otp6490_msg02() -> EvPar = ?MSG_LIB:cre_EventParameter("sune", ["mangs"]), PkgdName = ?MSG_LIB:cre_PkgdName("foo", "a"), EvName = ?MSG_LIB:cre_EventName(PkgdName), EvSpec = ?MSG_LIB:cre_EventSpec(EvName, [EvPar]), EvSpecs = [EvSpec], EBD = ?MSG_LIB:cre_EventBufferDescriptor(EvSpecs), pretty_otp6490_msg(EBD). pretty_otp6490_msg03() -> EvPar1 = ?MSG_LIB:cre_EventParameter("sune", ["mangs"]), EvPar2 = ?MSG_LIB:cre_EventParameter("kalle", ["anka"]), EvPar3 = ?MSG_LIB:cre_EventParameter("flippa", ["ur"]), PkgdName = ?MSG_LIB:cre_PkgdName("foo", "a"), EvName = ?MSG_LIB:cre_EventName(PkgdName), EvSpec = ?MSG_LIB:cre_EventSpec(EvName, [EvPar1,EvPar2,EvPar3]), EvSpecs = [EvSpec], EBD = ?MSG_LIB:cre_EventBufferDescriptor(EvSpecs), pretty_otp6490_msg(EBD). pretty_otp6490_msg04() -> EvPar1 = ?MSG_LIB:cre_EventParameter("sune", ["mangs"]), EvPar2 = ?MSG_LIB:cre_EventParameter("kalle", ["anka"]), EvPar3 = ?MSG_LIB:cre_EventParameter("flippa", ["ur"]), PkgdName1 = ?MSG_LIB:cre_PkgdName("foo", "a"), EvName1 = ?MSG_LIB:cre_EventName(PkgdName1), EvSpec1 = ?MSG_LIB:cre_EventSpec(EvName1, [EvPar1,EvPar2,EvPar3]), EvPar4 = ?MSG_LIB:cre_EventParameter("hej", ["hopp"]), PkgdName2 = ?MSG_LIB:cre_PkgdName("bar", "b"), EvName2 = ?MSG_LIB:cre_EventName(PkgdName2), EvSpec2 = ?MSG_LIB:cre_EventSpec(EvName2, [EvPar4]), EvSpecs = [EvSpec1,EvSpec2], EBD = ?MSG_LIB:cre_EventBufferDescriptor(EvSpecs), pretty_otp6490_msg(EBD). pretty_otp6490_msg05() -> EvPar = ?MSG_LIB:cre_EventParameter("sune", ["mangs"]), PkgdName = ?MSG_LIB:cre_PkgdName("foo", root), EvName = ?MSG_LIB:cre_EventName(PkgdName), EvSpec = ?MSG_LIB:cre_EventSpec(EvName, [EvPar]), EvSpecs = [EvSpec], EBD = ?MSG_LIB:cre_EventBufferDescriptor(EvSpecs), pretty_otp6490_msg(EBD). pretty_otp6490_msg06() -> EvPar = ?MSG_LIB:cre_EventParameter("sune", ["mangs"]), PkgdName = ?MSG_LIB:cre_PkgdName(root, root), EvName = ?MSG_LIB:cre_EventName(PkgdName), EvSpec = ?MSG_LIB:cre_EventSpec(EvName, [EvPar]), EvSpecs = [EvSpec], EBD = ?MSG_LIB:cre_EventBufferDescriptor(EvSpecs), pretty_otp6490_msg(EBD). %% -------------------------------------------------------------- %% pretty_otp7249_msg01(suite) -> []; pretty_otp7249_msg01(doc) -> "Ticket OTP-7249 has really nothing to to with just version 2 " "although the test message is version 2. Instead the decode " "is actually done by the mini decoder, which is where the bug " "manifests itself. The bug is in effect located in the (plain) " "text scanner. "; pretty_otp7249_msg01(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp7249_msg01 -> entry", []), ok = pretty_otp7249( pretty_otp7249_msg01() ), %% erase(dbg), %% erase(severity), ok. pretty_otp7249_msg01() -> "MEGACO/2 \r\nTransaction = 500017 { \r\nContext = - { ServiceChange = ROOT { Services { \r\nMethod = Disconnected, Reason = 900, 20070116T15233997 } \r\n } } } \r\n". pretty_otp7249(EncodedMsg) -> Codec = megaco_pretty_text_encoder, Conf = [], Bin = list_to_binary(EncodedMsg), case decode_mini_message(Codec, Conf, Bin) of {ok, Msg} when is_record(Msg, 'MegacoMessage') -> %% io:format("Msg: ~n~p" %% "~n", [Msg]), ok; {error, Reason} -> exit({unexpected_decode_failure, EncodedMsg, Reason}) end. %% -------------------------------------------------------------- %% pretty_otp7671_msg01(suite) -> []; pretty_otp7671_msg01(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp7671_msg01 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp7671( pretty_otp7671_msg01(), [] ), %% erase(dbg), %% erase(severity), ok. pretty_otp7671_msg02(suite) -> []; pretty_otp7671_msg02(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp7671_msg02 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp7671( pretty_otp7671_msg02(), [] ), %% erase(dbg), %% erase(severity), ok. pretty_otp7671_msg03(suite) -> []; pretty_otp7671_msg03(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp7671_msg03 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp7671( pretty_otp7671_msg03(), [] ), %% erase(dbg), %% erase(severity), ok. pretty_otp7671_msg04(suite) -> []; pretty_otp7671_msg04(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp7671_msg04 -> entry", []), %% ?ACQUIRE_NODES(1, Config), ok = pretty_otp7671( pretty_otp7671_msg04(), [] , error, ignore), %% erase(dbg), %% erase(severity), ok. pretty_otp7671_msg05(suite) -> []; pretty_otp7671_msg05(Config) when is_list(Config) -> %% put(severity, trc), %% put(dbg, true), d("pretty_otp7671_msg05 -> entry", []), Check = fun(M1, M2) -> cmp_otp7671_msg05(M1, M2) end, ok = pretty_otp7671( pretty_otp7671_msg05(), [] , ok, ok, Check), %% erase(dbg), %% erase(severity), ok. pretty_otp7671(Msg, Conf) -> pretty_otp7671(Msg, Conf, ok). pretty_otp7671(Msg, Conf, ExpectedEncode) -> pretty_otp7671(Msg, Conf, ExpectedEncode, ok). pretty_otp7671(Msg, Conf, ExpectedEncode, ExpectedDecode) -> otp7671(Msg, megaco_pretty_text_encoder, Conf, ExpectedEncode, ExpectedDecode). pretty_otp7671(Msg, Conf, ExpectedEncode, ExpectedDecode, Check) -> otp7671(Msg, megaco_pretty_text_encoder, Conf, ExpectedEncode, ExpectedDecode, Check). otp7671(Msg, Codec, Conf, ExpectedEncode, ExpectedDecode) -> Check = fun(M1, M2) -> exit({unexpected_decode_result, M1, M2}) end, otp7671(Msg, Codec, Conf, ExpectedEncode, ExpectedDecode, Check). otp7671(Msg, Codec, Conf, ExpectedEncode, ExpectedDecode, Check) when is_function(Check) -> case (catch encode_message(Codec, Conf, Msg)) of {error, _Reason} when ExpectedEncode =:= error -> ok; {error, Reason} when ExpectedEncode =:= ok -> exit({unexpected_encode_failure, Reason}); {ok, Bin} when ExpectedEncode =:= error -> exit({unexpected_encode_success, Msg, binary_to_list(Bin)}); {ok, Bin} when ExpectedEncode =:= ok -> case decode_message(Codec, false, Conf, Bin) of {ok, Msg} when ExpectedDecode =:= ok -> ok; {ok, Msg2} when ExpectedDecode =:= ok -> Check(Msg, Msg2); {ok, Msg} when ExpectedDecode =:= error -> exit({unexpected_decode_success, Msg}); {ok, Msg2} when ExpectedDecode =:= error -> exit({unexpected_decode_success, Msg, Msg2}); {error, _Reason} when ExpectedDecode =:= error -> ok; {error, Reason} when ExpectedDecode == ok -> exit({unexpected_decode_failure, Msg, Reason}) end end. pretty_otp7671_msg(DigitMapDesc) -> AmmReq = cre_AmmReq([#megaco_term_id{id = ["root"]}], [{digitMapDescriptor, DigitMapDesc}]), CmdReq = cre_CmdReq({modReq, AmmReq}), msg_request(?MGC_MID, 10001, ?megaco_null_context_id, [CmdReq]). pretty_otp7671_msg01() -> Name = "dialplan01", DigitMapDesc = cre_DigitMapDesc(Name), pretty_otp7671_msg(DigitMapDesc). pretty_otp7671_msg02() -> Name = "dialplan02", Body = "(0s| 00s|[1-7]xlxx|8lxxxxxxx|#xxxxxxx|*xx|9l1xxxxxxxxxx|9l011x.s)", Value = cre_DigitMapValue(Body), DigitMapDesc = cre_DigitMapDesc(Name, Value), pretty_otp7671_msg(DigitMapDesc). pretty_otp7671_msg03() -> Body = "(0s| 00s|[1-7]xlxx|8lxxxxxxx|#xxxxxxx|*xx|9l1xxxxxxxxxx|9l011x.s)", Value = cre_DigitMapValue(Body), DigitMapDesc = cre_DigitMapDesc(Value), pretty_otp7671_msg(DigitMapDesc). pretty_otp7671_msg04() -> DigitMapDesc = cre_DigitMapDesc(), pretty_otp7671_msg(DigitMapDesc). pretty_otp7671_msg05() -> {'MegacoMessage',asn1_NOVALUE, {'Message',?VERSION, {domainName,{'DomainName',"tgc",asn1_NOVALUE}}, {transactions, [{transactionRequest, {'TransactionRequest',12582952, [{'ActionRequest',0,asn1_NOVALUE,asn1_NOVALUE, [{'CommandRequest', {modReq, {'AmmRequest', [{megaco_term_id,false,["root"]}], [{digitMapDescriptor, {'DigitMapDescriptor',"dialplan1", {'DigitMapValue',asn1_NOVALUE,asn1_NOVALUE,asn1_NOVALUE,[], asn1_NOVALUE}}}]}}, asn1_NOVALUE,asn1_NOVALUE}]}]}}]}}}. cmp_otp7671_msg05(#'MegacoMessage'{authHeader = asn1_NOVALUE, mess = M1}, #'MegacoMessage'{authHeader = asn1_NOVALUE, mess = M2}) -> #'Message'{messageBody = Body1} = M1, #'Message'{messageBody = Body2} = M2, {transactions, Trans1} = Body1, {transactions, Trans2} = Body2, [{transactionRequest, TR1}] = Trans1, [{transactionRequest, TR2}] = Trans2, #'TransactionRequest'{actions = Acts1} = TR1, #'TransactionRequest'{actions = Acts2} = TR2, [#'ActionRequest'{commandRequests = CR1}] = Acts1, [#'ActionRequest'{commandRequests = CR2}] = Acts2, [#'CommandRequest'{command = Cmd1}] = CR1, [#'CommandRequest'{command = Cmd2}] = CR2, {modReq, #'AmmRequest'{descriptors = Descs1}} = Cmd1, {modReq, #'AmmRequest'{descriptors = Descs2}} = Cmd2, [{digitMapDescriptor, #'DigitMapDescriptor'{digitMapName = Name, digitMapValue = Value1}}] = Descs1, [{digitMapDescriptor, #'DigitMapDescriptor'{digitMapName = Name, digitMapValue = Value2}}] = Descs2, #'DigitMapValue'{startTimer = asn1_NOVALUE, shortTimer = asn1_NOVALUE, longTimer = asn1_NOVALUE, digitMapBody = [], durationTimer = asn1_NOVALUE} = Value1, asn1_NOVALUE = Value2, ok. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% expect_codec(Expect, Codec, Msg, Conf) -> t("expect_codec -> entry with" "~n Expect: ~p" "~n Msg: ~p", [Expect, Msg]), case (catch encode_message(Codec, Conf, Msg)) of {error, _Reason} when Expect == error -> d("expect_codec -> encode failed as expected" "~n _Reason: ~w", [_Reason]), ok; {error, Reason} -> e("expect_codec -> encode failed unexpectedly: " "~n Reason: ~w", [Reason]), exit({unexpected_encode_result, Reason}); {ok, Bin} when Expect == error -> e("expect_codec -> encode succeded unexpectedly: " "~n ~w", [binary_to_list(Bin)]), exit({unexpected_encode_result, binary_to_list(Bin)}); {ok, Bin} -> d("expect_codec -> successfull encode as expected:" "~n~s", [binary_to_list(Bin)]), case (catch decode_message(Codec, false, Conf, Bin)) of {ok, Msg} -> d("expect_codec -> successfull decode~n", []), ok; {ok, Msg2} -> e("expect_codec -> successfull decode" " - but not equal", []), chk_MegacoMessage(Msg, Msg2); %% exit({unexpected_decode_result, Msg, Msg2}); Else -> e("expect_codec -> decode failed:~n~p", [Else]), exit({unexpected_decode_result, Else}) end; Else -> e("expect_codec -> encode failed:~n~p", [Else]), exit({unexpected_encode_result, Else}) end. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% msgs() -> Msgs = msgs1() ++ msgs2() ++ msgs3() ++ msgs4(), [M || {_, M, _, _} <- Msgs]. msgs1() -> Plain = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:plain_encode_decode(Codec, DD, Ver, EC, M) end, [ {msg01a, msg1a(), Plain, [{dbg,false}]}, {msg01b, msg1b(), Plain, [{dbg,false}]}, {msg02, msg2(), Plain, [{dbg,false}]}, {msg03, msg3(), Plain, [{dbg,false}]}, {msg04, msg4(), Plain, [{dbg,false}]}, {msg05, msg5(), Plain, [{dbg,false}]}, {msg06a, msg6a(), Plain, [{dbg,false}]}, {msg06b, msg6b(), Plain, [{dbg,false}]}, {msg07, msg7(), Plain, [{dbg,false}]}, {msg08a, msg8a(), Plain, [{dbg,false}]}, {msg08b, msg8b(), Plain, [{dbg,false}]}, {msg09, msg9(), Plain, [{dbg,false}]}, {msg10, msg10(), Plain, [{dbg,false}]}, {msg11, msg11(), Plain, [{dbg,false}]}, {msg12, msg12(), Plain, [{dbg,false}]}, {msg13, msg13(), Plain, [{dbg,false}]}, {msg14, msg14(), Plain, [{dbg,false}]}, {msg15, msg15(), Plain, [{dbg,false}]}, {msg16, msg16(), Plain, [{dbg,false}]}, {msg17, msg17(), Plain, [{dbg,false}]}, {msg18, msg18(), Plain, [{dbg,false}]}, {msg19, msg19(), Plain, [{dbg,false}]}, {msg20, msg20(), Plain, [{dbg,false}]}, {msg21, msg21(), Plain, [{dbg,false}]}, {msg22a, msg22a(), Plain, [{dbg,false}]}, {msg22b, msg22b(), Plain, [{dbg,false}]}, {msg22c, msg22c(), Plain, [{dbg,false}]}, {msg22d, msg22d(), Plain, [{dbg,false}]}, {msg22e, msg22e(), Plain, [{dbg,false}]}, {msg22f, msg22f(), Plain, [{dbg,false}]}, {msg23a, msg23a(), Plain, [{dbg,false}]}, {msg23b, msg23b(), Plain, [{dbg,false}]}, {msg23c, msg23c(), Plain, [{dbg,false}]}, {msg23d, msg23d(), Plain, [{dbg,false}]}, {msg24, msg24(), Plain, [{dbg,false}]}, {msg25, msg25(), Plain, [{dbg,false}]}, {msg30a, msg30a(), Plain, [{dbg,false}]}, {msg30b, msg30b(), Plain, [{dbg,false}]}, {msg30c, msg30c(), Plain, [{dbg,false}]}, {msg30d, msg30d(), Plain, [{dbg,false}]} ]. msgs2() -> TransFirst = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:trans_first_encode_decode(Codec, DD, Ver, EC, M) end, ActionsFirst = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:actions_first_encode_decode(Codec, DD, Ver, EC, M) end, ActionFirst = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:action_first_encode_decode(Codec, DD, Ver, EC, M) end, [ {msg01a_tf, msg1a(), TransFirst, [{dbg,false}]}, {msg02_tf, msg2(), TransFirst, [{dbg,false}]}, {msg10_tf, msg10(), TransFirst, [{dbg,false}]}, {msg11_tf, msg11(), TransFirst, [{dbg,false}]}, {msg23d_tf, msg23d(), TransFirst, [{dbg,false}]}, {msg30b_tf, msg30b(), TransFirst, [{dbg,false}]}, {msg30c_tf, msg30c(), TransFirst, [{dbg,false}]}, {msg01a_asf, msg1a(), ActionsFirst, [{dbg,false}]}, {msg02_asf, msg2(), ActionsFirst, [{dbg,false}]}, {msg10_asf, msg10(), ActionsFirst, [{dbg,false}]}, {msg23d_asf, msg23d(), ActionsFirst, [{dbg,false}]}, {msg01a_af, msg1a(), ActionFirst, [{dbg,false}]}, {msg02_af, msg2(), ActionFirst, [{dbg,false}]}, {msg10_af, msg10(), ActionFirst, [{dbg,false}]}, {msg23d_af, msg23d(), ActionFirst, [{dbg,false}]} ]. msgs3() -> Plain = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:plain_encode_decode(Codec, DD, Ver, EC, M) end, [{msgs3_name(Name), rfc3525_decode(M), Plain, [{dbg, false}]} || {Name, M} <- rfc3525_msgs()]. msgs3_name(N) -> list_to_atom("rfc3525_" ++ atom_to_list(N)). rfc3525_decode(M) when is_list(M) -> rfc3525_decode(list_to_binary(M)); rfc3525_decode(M) when is_binary(M) -> case (catch decode_message(megaco_pretty_text_encoder, false, [], M)) of {ok, Msg} -> Msg; Error -> {error, {rfc3525_decode_error, Error}} end. msgs4() -> Plain = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:plain_encode_decode(Codec, DD, Ver, EC, M) end, [ {msg51a, msg51a(), Plain, [{dbg, false}]}, {msg51b, msg51b(), Plain, [{dbg, false}]}, {msg51c, msg51c(), Plain, [{dbg, false}]}, {msg51d, msg51d(), Plain, [{dbg, false}]}, {msg51e, msg51e(), Plain, [{dbg, false}]}, {msg51f, msg51f(), Plain, [{dbg, false}]}, {msg51g, msg51g(), Plain, [{dbg, false}]}, {msg51h, msg51h(), Plain, [{dbg, false}]}, {msg51i, msg51i(), Plain, [{dbg, false}]}, {msg52, msg52(), Plain, [{dbg, false}]}, {msg53, msg53(), Plain, [{dbg, false}]}, {msg54a, msg54a(), Plain, [{dbg, false}]}, {msg54b, msg54b(), Plain, [{dbg, false}]}, {msg54c, msg54c(), Plain, [{dbg, false}]}, {msg55, msg55(), Plain, [{dbg, false}]}, {msg56, msg56(), Plain, [{dbg, false}]}, {msg57, msg57(), Plain, [{dbg, false}]}, {msg58a, msg58a(), Plain, [{dbg, false}]}, {msg58b, msg58b(), Plain, [{dbg, false}]} ]. msgs5() -> Plain = fun(Codec, DD, Ver, EC, M) -> megaco_codec_test_lib:plain_encode_decode(Codec, DD, Ver, EC, M) end, PlainEDFail = fun(Codec, DD, Ver, EC, M) -> Res = megaco_codec_test_lib:plain_encode_decode(Codec, DD, Ver, EC, M), case Res of {error, {message_encode_failed, Reason, _M}} -> case Reason of {error, {{deprecated, _}, _}} -> ok; _ -> Res end; _ -> Res end end, PlainDE = fun(Codec, _DD, Ver, EC, B) -> Res = megaco_codec_test_lib:decode_message(Codec, false, Ver, EC, B), case Res of {ok, M} -> #'MegacoMessage'{mess = Mess} = M, #'Message'{messageBody = {transactions, TRs}} = Mess, [{transactionRequest, TR}] = TRs, #'TransactionRequest'{actions = Actions} = TR, [Action] = Actions, #'ActionRequest'{commandRequests = CmdReqs} = Action, [CmdReq] = CmdReqs, #'CommandRequest'{command = Cmd} = CmdReq, {addReq,AmmReq} = Cmd, #'AmmRequest'{descriptors = []} = AmmReq, ok; _ -> Res end end, [ {msg61a, msg61a(), Plain, [{dbg, false}]}, {msg61b, msg61b(), Plain, [{dbg, false}]}, {msg61c, msg61c(), Plain, [{dbg, false}]}, {msg62a, msg62a(), PlainEDFail, [{dbg, false}]}, {msg62b, msg62b(), PlainDE, [{dbg, false}]} ]. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% msg_actions([], Actions) -> lists:reverse(Actions); msg_actions([{CtxId, CmdReqs}|ActionInfo], Actions) -> Action = ?MSG_LIB:cre_ActionRequest(CtxId,CmdReqs), msg_actions(ActionInfo, [Action|Actions]). megaco_trans_req([], Transactions) -> {transactions, lists:reverse(Transactions)}; megaco_trans_req([{TransId, ActionInfo}|TransInfo], Transactions) -> Actions = msg_actions(ActionInfo, []), TR = ?MSG_LIB:cre_TransactionRequest(TransId, Actions), Trans = ?MSG_LIB:cre_Transaction(TR), megaco_trans_req(TransInfo, [Trans|Transactions]). megaco_message(Version, Mid, Body) -> Mess = ?MSG_LIB:cre_Message(Version, Mid, Body), ?MSG_LIB:cre_MegacoMessage(Mess). msg_request(Mid, TransInfo) -> TransReq = megaco_trans_req(TransInfo, []), megaco_message(?VERSION, Mid, TransReq). msg_request(Mid, TransId, ContextId, CmdReq) -> Action = ?MSG_LIB:cre_ActionRequest(ContextId, CmdReq), Actions = [Action], TR = ?MSG_LIB:cre_TransactionRequest(TransId, Actions), Trans = ?MSG_LIB:cre_Transaction(TR), Mess = ?MSG_LIB:cre_Message(?VERSION, Mid, [Trans]), ?MSG_LIB:cre_MegacoMessage(Mess). msg_request(Auth, Mid, TransId, ContextId, CmdReq) -> Action = ?MSG_LIB:cre_ActionRequest(ContextId, CmdReq), Actions = [Action], TR = ?MSG_LIB:cre_TransactionRequest(TransId, Actions), Trans = ?MSG_LIB:cre_Transaction(TR), Mess = ?MSG_LIB:cre_Message(?VERSION, Mid, [Trans]), ?MSG_LIB:cre_MegacoMessage(Auth, Mess). msg_reply(Mid, TransId, ContextId, CmdReply) -> Action = cre_ActRep(ContextId, CmdReply), Actions = [Action], TR = cre_TransRep(TransId, Actions), Trans = ?MSG_LIB:cre_Transaction(TR), Mess = ?MSG_LIB:cre_Message(?VERSION, Mid, [Trans]), ?MSG_LIB:cre_MegacoMessage(Mess). msg_ack(Mid, [Range|_] = Ranges) when is_tuple(Range) -> msg_ack(Mid, [Ranges]); msg_ack(Mid, Ranges) -> %% TRAs = make_tras(Ranges, []), TRAs = make_tras(Ranges), Req = {transactions, TRAs}, cre_MegacoMessage(?VERSION, Mid, Req). make_tras(TRARanges) -> F = fun(R) -> {transactionResponseAck, make_tra(R)} end, lists:map(F, TRARanges). make_tra(Ranges) -> F = fun({F,L}) -> cre_TransAck(F,L) end, lists:map(F, Ranges). %% ------------------------------------------------------------------------- msg1(Mid, Tid) -> Gain = cre_PropParm("tdmc/gain", "2"), Ec = cre_PropParm("tdmc/ec", "g165"), LCD = cre_LocalControlDesc(sendRecv,[Gain, Ec]), V = cre_PropParm("v", "0"), %% C = cre_PropParm("c", "IN IP4 $ "), C = cre_PropParm("c", [$I,$N,$ ,$I,$P,$4,$ ,$$,$ ]), M = cre_PropParm("m", "audio $ RTP/AVP 0"), A = cre_PropParm("a", "fmtp:PCMU VAD=X-NNVAD"), LD = cre_LocalRemoteDesc([[V, C, M, A]]), Parms = cre_StreamParms(LCD,LD), StreamDesc = cre_StreamDesc(1,Parms), MediaDesc = cre_MediaDesc(StreamDesc), ReqEvent = cre_ReqedEv("al/of"), EventsDesc = cre_EvsDesc(2222,[ReqEvent]), AmmReq = cre_AmmReq([#megaco_term_id{id = Tid}], [{mediaDescriptor, MediaDesc}, {eventsDescriptor, EventsDesc}]), CmdReq = cre_CmdReq({modReq, AmmReq}), msg_request(Mid, 9999, ?megaco_null_context_id, [CmdReq]). msg1a() -> msg1a(?MGC_MID). msg1a(Mid) -> msg1(Mid, ?A4444). msg1b() -> msg1b(?MGC_MID). msg1b(Mid) -> msg1(Mid, ?A4445). %% -------------------------- msg2() -> msg2(?MGC_MID). msg2(Mid) -> msg2(Mid, ?A4444). msg2(Mid, Tid) -> Gain = cre_PropParm("tdmc/gain", "2"), Ec = cre_PropParm("tdmc/ec", "g165"), LCD = cre_LocalControlDesc(sendRecv,[Gain, Ec]), V = cre_PropParm("v", "0"), %% C = cre_PropParm("c", "IN IP4 $ "), C = cre_PropParm("c", [$I,$N,$ ,$I,$P,$4,$ ,$$,$ ]), M = cre_PropParm("m", "audio $ RTP/AVP 0"), A = cre_PropParm("a", "fmtp:PCMU VAD=X-NNVAD"), LD = cre_LocalRemoteDesc([[V, C, M, A]]), Parms = cre_StreamParms(LCD,LD), StreamDesc = cre_StreamDesc(1,Parms), MediaDesc = cre_MediaDesc(StreamDesc), EventParm = cre_EvParm("strict",["exact"]), ReqEvent = cre_ReqedEv("al/of", [EventParm]), EventsDesc = cre_EvsDesc(2222,[ReqEvent]), AmmReq = cre_AmmReq([#megaco_term_id{id = Tid}], [{mediaDescriptor, MediaDesc}, {eventsDescriptor, EventsDesc}]), CmdReq = cre_CmdReq({modReq, AmmReq}), msg_request(Mid, 9999, ?megaco_null_context_id, [CmdReq]). %% -------------------------- msg3() -> msg3(?MG1_MID). msg3(Mid) -> TimeStamp = cre_TimeNot("19990729", "22000000"), Event = cre_ObsEv("al/of",TimeStamp), Desc = cre_ObsEvsDesc(2222,[Event]), NotifyReq = cre_NotifyReq([#megaco_term_id{id = ?A4444}],Desc), CmdReq = cre_CmdReq({notifyReq, NotifyReq}), msg_request(Mid, 10000, ?megaco_null_context_id, [CmdReq]). %% -------------------------- msg4() -> msg4(?MG1_MID_NO_PORT, "901 mg col boot"). msg4(Mid, Reason) when is_list(Reason) -> Address = {portNumber, ?DEFAULT_PORT}, Profile = cre_SvcChProf("resgw",1), Parm = cre_SvcChParm(restart,Address,[Reason],Profile), Req = cre_SvcChReq([?megaco_root_termination_id],Parm), CmdReq = cre_CmdReq({serviceChangeReq, Req}), msg_request(Mid, 9998, ?megaco_null_context_id, [CmdReq]). %% -------------------------- msg5() -> msg5(?MGC_MID). msg5(Mid) -> Address = {portNumber, ?DEFAULT_PORT}, Profile = cre_SvcChProf("resgw",1), Parm = cre_SvcChResParm(Address,Profile), Reply = cre_SvcChRep([?megaco_root_termination_id], {serviceChangeResParms,Parm}), msg_reply(Mid, 9998, ?megaco_null_context_id, [{serviceChangeReply, Reply}]). %% -------------------------- msg6(Mid, Tid) -> Reply = cre_AmmsReply([#megaco_term_id{id = Tid}]), msg_reply(Mid, 9999, ?megaco_null_context_id, [{modReply, Reply}]). msg6a() -> msg6a(?MG1_MID). msg6a(Mid) -> msg6(Mid, ?A4444). msg6b() -> msg6b(?MG2_MID). msg6b(Mid) -> msg6(Mid, ?A5555). %% -------------------------- msg7() -> msg7(?MGC_MID). msg7(Mid) -> Reply = cre_NotifyRep([#megaco_term_id{id = ?A4444}]), msg_reply(Mid, 10000, ?megaco_null_context_id, [{notifyReply, Reply}]). %% -------------------------- msg8(Mid, DigitMapValue) -> Strict = cre_EvParm("strict",["state"]), On = cre_ReqedEv("al/on", [Strict]), Name = "dialplan00", Action = cre_ReqedActs(Name), Ce = cre_ReqedEv("dd/ce", Action), EventsDesc = cre_EvsDesc(2223,[On, Ce]), Signal = cre_Sig("cg/rt"), DigMapDesc = cre_DigitMapDesc(Name, DigitMapValue), AmmReq = cre_AmmReq([#megaco_term_id{id = ?A4444}], [{eventsDescriptor, EventsDesc}, {signalsDescriptor, [{signal, Signal}]}, {digitMapDescriptor, DigMapDesc}]), CmdReq = cre_CmdReq({modReq, AmmReq}), msg_request(Mid, 10001, ?megaco_null_context_id, [CmdReq]). msg8a() -> msg8a(?MGC_MID). msg8a(Mid) -> Body = "(0s| 00s|[1-7]xlxx|8lxxxxxxx|#xxxxxxx|*xx|9l1xxxxxxxxxx|9l011x.s)", Value = cre_DigitMapValue(Body), msg8(Mid, Value). msg8b() -> msg8b(?MGC_MID). msg8b(Mid) -> Body = "(0s| 00s|[1-7]xlxx|8lxxxxxxx|#xxxxxxx|*xx|9l1xxxxxxxxxx|9l011x.s)", Value = cre_DigitMapValue(Body, 1, 23, 99), msg8(Mid, Value). %% -------------------------- msg9() -> msg9(?MG1_MID). msg9(Mid) -> TimeStamp = cre_TimeNot("19990729","22010001"), Parm = cre_EvParm("ds",["916135551212"]), Event = cre_ObsEv("dd/ce",TimeStamp,[Parm]), Desc = cre_ObsEvsDesc(2223,[Event]), NotifyReq = cre_NotifyReq([#megaco_term_id{id = ?A4444}], Desc), CmdReq = cre_CmdReq({notifyReq, NotifyReq}), msg_request(Mid, 10002, ?megaco_null_context_id, [CmdReq]). %% -------------------------- msg10() -> msg10(?MGC_MID). msg10(Mid) -> AmmReq = cre_AmmReq([#megaco_term_id{id = ?A4444}],[]), CmdReq = cre_CmdReq({addReq, AmmReq}), Jit = cre_PropParm("nt/jit", "40"), LCD = cre_LocalControlDesc(recvOnly,[Jit]), V = cre_PropParm("v", "0"), C = cre_PropParm("c", "IN IP4 $ "), M = cre_PropParm("m", "audio $ RTP/AVP 4"), A = cre_PropParm("a", "ptime:30"), V2 = cre_PropParm("v", "0"), C2 = cre_PropParm("c", "IN IP4 $ "), M2 = cre_PropParm("m", "audio $ RTP/AVP 0"), LD = cre_LocalRemoteDesc([[V, C, M, A], [V2, C2, M2]]), Parms = cre_StreamParms(LCD, LD), StreamDesc = cre_StreamDesc(1,Parms), MediaDesc = cre_MediaDesc(StreamDesc), ChooseTid = #megaco_term_id{contains_wildcards = true, id = [[?megaco_choose]]}, AmmReq2 = cre_AmmReq([ChooseTid],[{mediaDescriptor, MediaDesc}]), CmdReq2 = cre_CmdReq({addReq, AmmReq2}), msg_request(Mid, 10003, ?megaco_choose_context_id, [CmdReq, CmdReq2]). msg11() -> msg11(?MG1_MID). msg11(Mid) -> V = cre_PropParm("v", "0"), C = cre_PropParm("c", "IN IP4 124.124.124.222"), M = cre_PropParm("m", "audio 2222 RTP/AVP 4"), A = cre_PropParm("a", "ptime:30"), A2 = cre_PropParm("a", "recvonly"), LD = cre_LocalRemoteDesc([[V, C, M, A, A2]]), Parms = cre_StreamParmsL(LD), StreamDesc = cre_StreamDesc(1, Parms), MediaDesc = cre_MediaDesc(StreamDesc), Reply = cre_AmmsReply([#megaco_term_id{id = ?A4444}]), Reply2 = cre_AmmsReply([#megaco_term_id{id = ?A4445}], [{mediaDescriptor, MediaDesc}]), msg_reply(Mid, 10003, 2000, [{addReply, Reply}, {addReply, Reply2}]). %% -------------------------- msg12() -> msg12(?MGC_MID). msg12(Mid) -> LCD = cre_LocalControlDesc(sendRecv), Parms = cre_StreamParms(LCD), StreamDesc = cre_StreamDesc(1,Parms), MediaDesc = cre_MediaDesc(StreamDesc), Signal = cre_Sig("al/ri"), Descs = [{mediaDescriptor, MediaDesc}, {signalsDescriptor, [{signal, Signal}]}], AmmReq = cre_AmmReq([#megaco_term_id{id = ?A5555}], Descs), CmdReq = cre_CmdReq({addReq, AmmReq}), Jit = cre_PropParm("nt/jit", "40"), LCD2 = cre_LocalControlDesc(sendRecv, [Jit]), V = cre_PropParm("v", "0"), C = cre_PropParm("c", "IN IP4 $ "), M = cre_PropParm("m", "audio $ RTP/AVP 4"), A = cre_PropParm("a", "ptime:30"), LD2 = cre_LocalRemoteDesc([[V, C, M, A]]), V2 = cre_PropParm("v", "0"), C2 = cre_PropParm("c", "IN IP4 124.124.124.222"), M2 = cre_PropParm("m", "audio 2222 RTP/AVP 4"), RD2 = cre_LocalRemoteDesc([[V2, C2, M2]]), Parms2 = cre_StreamParms(LCD2,LD2,RD2), StreamDesc2 = cre_StreamDesc(1,Parms2), MediaDesc2 = cre_MediaDesc(StreamDesc2), ChooseTid = #megaco_term_id{contains_wildcards = true, id = [[?megaco_choose]]}, AmmReq2 = cre_AmmReq([ChooseTid],[{mediaDescriptor, MediaDesc2}]), CmdReq2 = cre_CmdReq({addReq, AmmReq2}), msg_request(Mid, 50003, ?megaco_choose_context_id, [CmdReq, CmdReq2]). %% -------------------------- msg13() -> msg13(?MG2_MID). msg13(Mid) -> V = cre_PropParm("v", "0"), C = cre_PropParm("c", "IN IP4 125.125.125.111"), M = cre_PropParm("m", "audio 1111 RTP/AVP 4"), LD = cre_LocalRemoteDesc([[V, C, M]]), Parms = cre_StreamParmsL(LD), StreamDesc = cre_StreamDesc(1,Parms), MediaDesc = cre_MediaDesc(StreamDesc), Reply = cre_AmmsReply([#megaco_term_id{id = ?A5556}], [{mediaDescriptor, MediaDesc}]), msg_reply(Mid, 50003, 5000, [{addReply, Reply}]). %% -------------------------- msg14() -> msg14(?MGC_MID). msg14(Mid) -> %% Cmd 1) Signal = cre_Sig("cg/rt"), AmmReq1 = cre_AmmReq([#megaco_term_id{id = ?A4444}], [{signalsDescriptor, [{signal, Signal}]}]), CmdReq1 = cre_CmdReq({modReq, AmmReq1}), %% Cmd 2) Gain = cre_PropParm("tdmc/gain", "2"), Ec = cre_PropParm("tdmc/ec", "g165"), LCD = cre_LocalControlDesc(sendRecv, [Gain, Ec]), Parms2 = cre_StreamParms(LCD), StreamDesc2 = cre_StreamDesc(1,Parms2), MediaDesc2 = cre_MediaDesc(StreamDesc2), AmmReq2 = cre_AmmReq([#megaco_term_id{id = ?A4445}], [{mediaDescriptor, MediaDesc2}]), CmdReq2 = cre_CmdReq({modReq, AmmReq2}), %% Cmd 3) V = cre_PropParm("v", "0"), C = cre_PropParm("c", "IN IP4 125.125.125.111"), M = cre_PropParm("m", "audio 1111 RTP/AVP 4"), RD = cre_LocalRemoteDesc([[V, C, M]]), Parms3 = cre_StreamParmsR(RD), StreamDesc3 = cre_StreamDesc(2,Parms3), MediaDesc3 = cre_MediaDesc(StreamDesc3), AmmReq3 = cre_AmmReq([#megaco_term_id{id = ?A4445}], [{mediaDescriptor, MediaDesc3}]), CmdReq3 = cre_CmdReq({modReq, AmmReq3}), msg_request(Mid, 10005, 2000, [CmdReq1, CmdReq2, CmdReq3]). %% -------------------------- msg15() -> msg15(?MG1_MID). msg15(Mid) -> Reply = cre_AmmsReply([#megaco_term_id{id = ?A4444}]), Reply2 = cre_AmmsReply([#megaco_term_id{id = ?A4445}]), msg_reply(Mid, 10005, 2000, [{modReply, Reply}, {modReply, Reply2}]). %% -------------------------- msg16() -> msg16(?MG2_MID). msg16(Mid) -> TimeStamp = cre_TimeNot("19990729","22020002"), Event = cre_ObsEv("al/of",TimeStamp), Desc = cre_ObsEvsDesc(1234,[Event]), NotifyReq = cre_NotifyReq([#megaco_term_id{id = ?A5555}],Desc), CmdReq = cre_CmdReq({notifyReq, NotifyReq}), msg_request(Mid, 50005, 5000, [CmdReq]). %% -------------------------- msg17() -> msg17(?MGC_MID). msg17(Mid) -> Reply = cre_NotifyRep([#megaco_term_id{id = ?A5555}]), msg_reply(Mid, 50005, ?megaco_null_context_id, [{notifyReply, Reply}]). %% -------------------------- msg18() -> msg18(?MGC_MID). msg18(Mid) -> On = cre_ReqedEv("al/on"), EventsDesc = cre_EvsDesc(1235,[On]), AmmReq = cre_AmmReq([#megaco_term_id{id = ?A5555}], [{eventsDescriptor, EventsDesc}, {signalsDescriptor, []}]), CmdReq = cre_CmdReq({modReq, AmmReq}), msg_request(Mid, 50006, 5000, [CmdReq]). %% -------------------------- msg19() -> msg19(?MG2_MID). msg19(Mid) -> Reply = cre_AmmsReply([#megaco_term_id{id = ?A4445}]), msg_reply(Mid, 50006, 5000, [{modReply, Reply}]). %% -------------------------- msg20() -> msg20(?MGC_MID). msg20(Mid) -> LCD = cre_LocalControlDesc(sendRecv), Parms = cre_StreamParms(LCD), StreamDesc = cre_StreamDesc(1,Parms), MediaDesc = cre_MediaDesc(StreamDesc), AmmReq = cre_AmmReq([#megaco_term_id{id = ?A4445}], [{mediaDescriptor, MediaDesc}]), CmdReq = cre_CmdReq({modReq, AmmReq}), AmmReq2 = cre_AmmReq([#megaco_term_id{id = ?A4444}], [{signalsDescriptor, []}]), CmdReq2 = cre_CmdReq({modReq, AmmReq2}), msg_request(Mid, 10006, 2000, [CmdReq, CmdReq2]). %% -------------------------- msg21() -> msg21(?MGC_MID). msg21(Mid) -> Tokens = [mediaToken, eventsToken, signalsToken, digitMapToken, statsToken, packagesToken], AuditDesc = cre_AuditDesc(Tokens), Req = cre_AuditReq(#megaco_term_id{id = ?A5556},AuditDesc), CmdReq = cre_CmdReq({auditValueRequest, Req}), msg_request(Mid, 50007, ?megaco_null_context_id, [CmdReq]). %% -------------------------- msg22a() -> msg22(1). msg22b() -> msg22(10). msg22c() -> msg22(25). msg22d() -> msg22(50). msg22e() -> msg22(75). msg22f() -> msg22(100). msg22(N) -> msg22(?MG2_MID, N). msg22(Mid, N) -> Jit = cre_PropParm("nt/jit", "40"), LCD = cre_LocalControlDesc(sendRecv,[Jit]), LDV = cre_PropParm("v", "0"), LDC = cre_PropParm("c", "IN IP4 125.125.125.111"), LDM = cre_PropParm("m", "audio 1111 RTP/AVP 4"), LDA = cre_PropParm("a", "ptime:30"), LD = cre_LocalRemoteDesc([[LDV, LDC, LDM, LDA]]), RDV = cre_PropParm("v", "0"), RDC = cre_PropParm("c", "IN IP4 124.124.124.222"), RDM = cre_PropParm("m", "audio 2222 RTP/AVP 4"), RDA = cre_PropParm("a", "ptime:30"), RD = cre_LocalRemoteDesc([[RDV, RDC, RDM, RDA]]), StreamParms = cre_StreamParms(LCD,LD,RD), StreamDesc = cre_StreamDesc(1,StreamParms), Media = cre_MediaDesc(StreamDesc), PackagesItem = cre_PkgsItem("nt",1), PackagesItem2 = cre_PkgsItem("rtp",1), Stat = cre_StatsParm("rtp/ps","1200"), Stat2 = cre_StatsParm("nt/os","62300"), Stat3 = cre_StatsParm("rtp/pr","700"), Stat4 = cre_StatsParm("nt/or","45100"), Stat5 = cre_StatsParm("rtp/pl","0.2"), Stat6 = cre_StatsParm("rtp/jit","20"), Stat7 = cre_StatsParm("rtp/delay","40"), Statistics = [Stat, Stat2, Stat3, Stat4, Stat5, Stat6, Stat7], Audits = [{mediaDescriptor, Media}, {packagesDescriptor, [PackagesItem, PackagesItem2]}, {statisticsDescriptor, Statistics}], Reply = {auditResult, cre_AuditRes(#megaco_term_id{id = ?A5556},Audits)}, msg_reply(Mid, 50007, ?megaco_null_context_id, lists:duplicate(N,{auditValueReply, Reply})). %% msg_reply(Mid, 50007, ?megaco_null_context_id, %% lists.duplicate([{auditValueReply, Reply}]). %% -------------------------- msg23a() -> msg23a(?MG2_MID). msg23a(Mid) -> TimeStamp = cre_TimeNot("19990729","24020002"), Event = cre_ObsEv("al/on",TimeStamp), Desc = cre_ObsEvsDesc(1235,[Event]), NotifyReq = cre_NotifyReq([#megaco_term_id{id = ?A5555}],Desc), CmdReq = cre_CmdReq({notifyReq, NotifyReq}), msg_request(Mid, 50008, 5000, [CmdReq]). msg23b() -> msg23b(?MG2_MID). msg23b(Mid) -> TimeStamp = cre_TimeNot("19990729","24020002"), Event = cre_ObsEv("al/on",TimeStamp), Desc = cre_ObsEvsDesc(1235,[Event]), NotifyReq1 = cre_NotifyReq([#megaco_term_id{id = ?A5555}],Desc), CmdReq1 = cre_CmdReq({notifyReq, NotifyReq1}), NotifyReq2 = cre_NotifyReq([#megaco_term_id{id = ?A5556}],Desc), CmdReq2 = cre_CmdReq({notifyReq, NotifyReq2}), ActionInfo = [{5000, [CmdReq1]}, {5001, [CmdReq2]}], TransInfo = [{50008, ActionInfo}], msg_request(Mid, TransInfo). msg23c() -> msg23c(?MG2_MID). msg23c(Mid) -> TimeStamp = cre_TimeNot("19990729","24020002"), Event = cre_ObsEv("al/on",TimeStamp), Desc = cre_ObsEvsDesc(1235,[Event]), NotifyReq1 = cre_NotifyReq([#megaco_term_id{id = ?A5555}],Desc), CmdReq1 = cre_CmdReq({notifyReq, NotifyReq1}), NotifyReq2 = cre_NotifyReq([#megaco_term_id{id = ?A5556}],Desc), CmdReq2 = cre_CmdReq({notifyReq, NotifyReq2}), ActionInfo1 = [{5000, [CmdReq1]}], ActionInfo2 = [{5001, [CmdReq2]}], TransInfo = [{50008, ActionInfo1}, {50009, ActionInfo2}], msg_request(Mid, TransInfo). msg23d() -> msg23d(?MG2_MID). msg23d(Mid) -> TimeStamp = cre_TimeNot("19990729","24020002"), Event = cre_ObsEv("al/on",TimeStamp), Desc = cre_ObsEvsDesc(1235,[Event]), NotifyReq1 = cre_NotifyReq([#megaco_term_id{id = ?A5555}],Desc), CmdReq1 = cre_CmdReq({notifyReq, NotifyReq1}), NotifyReq2 = cre_NotifyReq([#megaco_term_id{id = ?A5556}],Desc), CmdReq2 = cre_CmdReq({notifyReq, NotifyReq2}), NotifyReq3 = cre_NotifyReq([#megaco_term_id{id = ?A4444}],Desc), CmdReq3 = cre_CmdReq({notifyReq, NotifyReq3}), NotifyReq4 = cre_NotifyReq([#megaco_term_id{id = ?A4445}],Desc), CmdReq4 = cre_CmdReq({notifyReq, NotifyReq4}), ActionInfo1 = [{5000, [CmdReq1]}, {5001, [CmdReq2]}], ActionInfo2 = [{5003, [CmdReq3]}, {5004, [CmdReq4]}], TransInfo = [{50008, ActionInfo1}, {50009, ActionInfo2}], msg_request(Mid, TransInfo). %% -------------------------- msg24() -> msg24(?MGC_MID). msg24(Mid) -> AuditDesc = cre_AuditDesc([statsToken]), SubReq = cre_SubReq([#megaco_term_id{id = ?A5555}], AuditDesc), SubReq2 = cre_SubReq([#megaco_term_id{id = ?A5556}], AuditDesc), CmdReq = cre_CmdReq({subtractReq, SubReq}), CmdReq2 = cre_CmdReq({subtractReq, SubReq2}), msg_request(Mid, 50009, 5000, [CmdReq, CmdReq2]). %% -------------------------- msg25() -> msg25(?MG2_MID). msg25(Mid) -> Stat11 = cre_StatsParm("nt/os","45123"), Stat12 = cre_StatsParm("nt/dur", "40"), Stats1 = [Stat11, Stat12], Reply1 = cre_AmmsReply([#megaco_term_id{id = ?A5555}], [{statisticsDescriptor, Stats1}]), Stat21 = cre_StatsParm("rtp/ps","1245"), Stat22 = cre_StatsParm("nt/os", "62345"), Stat23 = cre_StatsParm("rtp/pr", "780"), Stat24 = cre_StatsParm("nt/or", "45123"), Stat25 = cre_StatsParm("rtp/pl", "10"), Stat26 = cre_StatsParm("rtp/jit", "27"), Stat27 = cre_StatsParm("rtp/delay","48"), Stats2 = [Stat21, Stat22, Stat23, Stat24, Stat25, Stat26, Stat27], Reply2 = cre_AmmsReply([#megaco_term_id{id = ?A5556}], [{statisticsDescriptor, Stats2}]), msg_reply(Mid, 50009, 5000, [{subtractReply, Reply1}, {subtractReply, Reply2}]). msg30a() -> msg_ack(?MG2_MID, [{9,9}]). msg30b() -> msg_ack(?MG2_MID, [{9,13}]). msg30c() -> msg_ack(?MG2_MID, [{9,13}, {15,15}, {33,40}, {50,60}, {70,80}, {85,90}, {101,105},{109,119},{121,130},{140,160},{170,175},{180,189}, {201,205},{209,219},{221,230},{240,260},{270,275},{280,289}, {301,305},{309,319},{321,330},{340,360},{370,375},{380,389}, {401,405},{409,419},{421,430},{440,460},{470,475},{480,489}, {501,505},{509,519},{521,530},{540,560},{570,575},{580,589} ]). %% Don't think this will be used by the megaco stack, but since it %% seem's to be a valid construction... msg30d() -> msg_ack(?MG2_MID, [[{9,13}, {15,15}, {33,40}, {50,60}, {70,80}, {85,90}], [{101,105},{109,119},{121,130},{140,160},{170,175},{180,189}], [{201,205},{209,219},{221,230},{240,260},{270,275},{280,289}], [{301,305},{309,319},{321,330},{340,360},{370,375},{380,389}], [{401,405},{409,419},{421,430},{440,460},{470,475},{480,489}], [{501,505},{509,519},{521,530},{540,560},{570,575},{580,589}] ]). msg40() -> msg40(?MG1_MID_NO_PORT, "901 mg col boot"). msg40(Mid, Reason) when is_list(Reason) -> Address = {portNumber, ?DEFAULT_PORT}, Profile = cre_SvcChProf("resgw",1), Parm = cre_SvcChParm(restart,Address,[Reason],Profile), Req = cre_SvcChReq([?megaco_root_termination_id],Parm), CmdReq = cre_CmdReq({serviceChangeReq, Req}), Auth = cre_AuthHeader(), msg_request(Auth, Mid, 9998, ?megaco_null_context_id, [CmdReq]). msg50(Mid, APT) -> AD = cre_AuditDesc(asn1_NOVALUE, APT), Req = cre_AuditReq(#megaco_term_id{id = ?A5556},AD), CmdReq = cre_CmdReq({auditValueRequest, Req}), msg_request(Mid, 50007, ?megaco_null_context_id, [CmdReq]). %% IndAudMediaDescriptor: msg51(Mid, IATSDorStream) -> IAMD = cre_IndAudMediaDesc(IATSDorStream), IAP = cre_IndAudParam(IAMD), APT = [IAP], msg50(Mid, APT). msg51a() -> msg51a(?MG2_MID). msg51a(Mid) -> PP = cre_IndAudPropertyParm("tdmc/gain"), PPs = [PP], IATSD = cre_IndAudTermStateDesc(PPs), msg51(Mid, IATSD). msg51b() -> msg51b(?MG2_MID). msg51b(Mid) -> PP = cre_IndAudPropertyParm("nt/jit"), PPs = [PP], IATSD = cre_IndAudTermStateDesc(PPs), msg51(Mid, IATSD). msg51c() -> msg51c(?MG2_MID). msg51c(Mid) -> IATSD = cre_IndAudTermStateDesc([], asn1_NOVALUE, 'NULL'), msg51(Mid, IATSD). msg51d() -> msg51d(?MG2_MID). msg51d(Mid) -> IATSD = cre_IndAudTermStateDesc([], 'NULL', asn1_NOVALUE), msg51(Mid, IATSD). msg51e() -> msg51e(?MG2_MID). msg51e(Mid) -> IALCD = cre_IndAudLocalControlDesc('NULL', asn1_NOVALUE, asn1_NOVALUE, asn1_NOVALUE), IASP = cre_IndAudStreamParms(IALCD), msg51(Mid, IASP). msg51f() -> msg51f(?MG2_MID). msg51f(Mid) -> IALCD = cre_IndAudLocalControlDesc(asn1_NOVALUE, 'NULL', asn1_NOVALUE, asn1_NOVALUE), IASP = cre_IndAudStreamParms(IALCD), msg51(Mid, IASP). msg51g() -> msg51g(?MG2_MID). msg51g(Mid) -> IALCD = cre_IndAudLocalControlDesc(asn1_NOVALUE, asn1_NOVALUE, 'NULL', asn1_NOVALUE), IASP = cre_IndAudStreamParms(IALCD), msg51(Mid, IASP). msg51h() -> msg51h(?MG2_MID). msg51h(Mid) -> Name = "nt/jit", IAPP = cre_IndAudPropertyParm(Name), IALCD = cre_IndAudLocalControlDesc(asn1_NOVALUE, asn1_NOVALUE, asn1_NOVALUE, [IAPP]), IASP = cre_IndAudStreamParms(IALCD), SID = 123, IASD = cre_IndAudStreamDesc(SID, IASP), msg51(Mid, [IASD]). msg51i() -> msg51i(?MG2_MID). msg51i(Mid) -> Name = "nt/jit", Name2 = "tdmc/ec", IAPP = cre_IndAudPropertyParm(Name), IAPP2 = cre_IndAudPropertyParm(Name2), IALCD = cre_IndAudLocalControlDesc('NULL', 'NULL', 'NULL', [IAPP, IAPP2]), IASP = cre_IndAudStreamParms(IALCD), SID = 123, IASD = cre_IndAudStreamDesc(SID, IASP), msg51(Mid, [IASD]). %% IndAudEventsDescriptor: msg52() -> msg52(?MG2_MID). msg52(Mid) -> RequestID = 1235, PkgdName = "tonedet/std", IAED = cre_IndAudEvsDesc(RequestID, PkgdName), IAP = cre_IndAudParam(IAED), APT = [IAP], msg50(Mid, APT). %% IndAudEventBufferDescriptor: msg53() -> msg53(?MG2_MID). msg53(Mid) -> EN = "tonedet/std", SID = 1, IAEBD = cre_IndAudEvBufDesc(EN, SID), IAP = cre_IndAudParam(IAEBD), APT = [IAP], msg50(Mid, APT). %% IndAudSignalsDescriptor: msg54(Mid, Sig) -> IASD = cre_IndAudSigsDesc(Sig), IAP = cre_IndAudParam(IASD), APT = [IAP], msg50(Mid, APT). msg54a() -> msg54a(?MG2_MID). msg54a(Mid) -> SN = "tonegen/pt", Sig = cre_IndAudSig(SN), msg54(Mid, Sig). msg54b() -> msg54b(?MG2_MID). msg54b(Mid) -> SN = "dg/d0", Sig = cre_IndAudSig(SN), msg54(Mid, Sig). msg54c() -> msg54c(?MG2_MID). msg54c(Mid) -> SN = "ct/ct", Sig = cre_IndAudSig(SN), ID = 4321, SSL = cre_IndAudSeqSigList(ID, Sig), msg54(Mid, SSL). %% IndAudDigitMapDescriptor: msg55() -> msg55(?MG2_MID). msg55(Mid) -> DMN = "dialplan00", IADMD = cre_IndAudDigitMapDesc(DMN), IAP = cre_IndAudParam(IADMD), APT = [IAP], msg50(Mid, APT). %% IndAudStatisticsDescriptor: msg56() -> msg56(?MG2_MID). msg56(Mid) -> SN = "nt/dur", IASD = cre_IndAudStatsDesc(SN), IAP = cre_IndAudParam(IASD), APT = [IAP], msg50(Mid, APT). %% IndAudPackagesDescriptor: msg57() -> msg57(?MG2_MID). msg57(Mid) -> PN = "al", PV = 1, IAPD = cre_IndAudPkgsDesc(PN, PV), IAP = cre_IndAudParam(IAPD), APT = [IAP], msg50(Mid, APT). %% Sum it up: msg58_iaMediaDesc_iap(IATSD) -> IAMD = cre_IndAudMediaDesc(IATSD), cre_IndAudParam(IAMD). msg58_iaMediaDesc_iap_a() -> PP = cre_IndAudPropertyParm("tdmc/gain"), PPs = [PP], IATSD = cre_IndAudTermStateDesc(PPs), msg58_iaMediaDesc_iap(IATSD). msg58_iaMediaDesc_iap_b() -> IATSD = cre_IndAudTermStateDesc([], 'NULL', asn1_NOVALUE), msg58_iaMediaDesc_iap(IATSD). msg58_iaEvsDesc_iap() -> RequestID = 1235, PkgdName = "tonedet/std", IAED = cre_IndAudEvsDesc(RequestID, PkgdName), cre_IndAudParam(IAED). msg58_iaEvBufDesc_iap() -> EN = "tonedet/std", SID = 1, IAEBD = cre_IndAudEvBufDesc(EN, SID), cre_IndAudParam(IAEBD). msg58_iaSigsDesc_iap(S) -> IASD = cre_IndAudSigsDesc(S), cre_IndAudParam(IASD). msg58_iaSigsDesc_iap_a() -> SN = "tonegen/pt", Sig = cre_IndAudSig(SN), msg58_iaSigsDesc_iap(Sig). msg58_iaSigsDesc_iap_b() -> SN = "ct/ct", Sig = cre_IndAudSig(SN), ID = 4321, SSL = cre_IndAudSeqSigList(ID, Sig), msg58_iaSigsDesc_iap(SSL). msg58_iaDigMapDesc_iap() -> DMN = "dialplan00", IADMD = cre_IndAudDigitMapDesc(DMN), cre_IndAudParam(IADMD). msg58_iaStatsDesc_iap() -> SN = "nt/dur", IASD = cre_IndAudStatsDesc(SN), cre_IndAudParam(IASD). msg58_iaPacksDesc_iap() -> PN = "al", PV = 1, IAPD = cre_IndAudPkgsDesc(PN, PV), cre_IndAudParam(IAPD). msg58a() -> msg58a(?MG2_MID). msg58a(Mid) -> IAMD = msg58_iaMediaDesc_iap_a(), IAED = msg58_iaEvsDesc_iap(), IAEBD = msg58_iaEvBufDesc_iap(), IASiD = msg58_iaSigsDesc_iap_a(), IADMD = msg58_iaDigMapDesc_iap(), IAStD = msg58_iaStatsDesc_iap(), IAPD = msg58_iaPacksDesc_iap(), APT = [IAMD, IAED, IAEBD, IASiD, IADMD, IAStD, IAPD], msg50(Mid, APT). msg58b() -> msg58b(?MG2_MID). msg58b(Mid) -> IAMD = msg58_iaMediaDesc_iap_b(), IAED = msg58_iaEvsDesc_iap(), IAEBD = msg58_iaEvBufDesc_iap(), IASiD = msg58_iaSigsDesc_iap_b(), IADMD = msg58_iaDigMapDesc_iap(), IAStD = msg58_iaStatsDesc_iap(), IAPD = msg58_iaPacksDesc_iap(), APT = [IAMD, IAED, IAEBD, IASiD, IADMD, IAStD, IAPD], msg50(Mid, APT). %% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - %% Tests some of the changes in the v2 corr 1 (EmergencyOff and ModemDesc) %% Emergency On/Off (optional) tests msg61(EM) -> TS = cre_TimeNot("19990729", "22000000"), Event = cre_ObsEv("al/of",TS), Desc = cre_ObsEvsDesc(2222,[Event]), NotReq = cre_NotifyReq([#megaco_term_id{id = ?A4444}],Desc), Cmd = ?MSG_LIB:cre_Command(notifyReq, NotReq), CmdReq = cre_CmdReq(Cmd), CtxReq = ?MSG_LIB:cre_ContextRequest(15, EM), ActReq = ?MSG_LIB:cre_ActionRequest(1, CtxReq, [CmdReq]), Acts = [ActReq], TR = ?MSG_LIB:cre_TransactionRequest(9898, Acts), Trans = ?MSG_LIB:cre_Transaction(TR), Mess = ?MSG_LIB:cre_Message(?VERSION, ?MG1_MID, [Trans]), ?MSG_LIB:cre_MegacoMessage(Mess). msg61a() -> msg61(false). msg61b() -> msg61(true). msg61c() -> msg61(asn1_NOVALUE). msg62a() -> MT = ?MSG_LIB:cre_ModemType(v18), PP = cre_PropParm("c", "IN IP4 $ "), MD = ?MSG_LIB:cre_ModemDescriptor([MT], [PP]), AmmDesc = ?MSG_LIB:cre_AmmDescriptor(MD), TermIDs = [#megaco_term_id{id = ?A4444}], AmmReq = ?MSG_LIB:cre_AmmRequest(TermIDs, [AmmDesc]), Cmd = ?MSG_LIB:cre_Command(addReq, AmmReq), CmdReq = ?MSG_LIB:cre_CommandRequest(Cmd), ActReq = ?MSG_LIB:cre_ActionRequest(2, [CmdReq]), Acts = [ActReq], TR = ?MSG_LIB:cre_TransactionRequest(9898, Acts), Trans = ?MSG_LIB:cre_Transaction(TR), Mess = ?MSG_LIB:cre_Message(?VERSION, ?MG1_MID, [Trans]), ?MSG_LIB:cre_MegacoMessage(Mess). msg62b() -> MP = "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Transaction = 9898 { Context = 2 { Add = 11111111/00000000/00000000 { Modem[V18] { tdmc/gain=2 } } } }", % MC = % "!/" ?VERSION_STR " [124.124.124.222]:55555\nT=9898{C=2{A=11111111/00000000/00000000{MD[V18]{tdmc/gain=2}}}}", list_to_binary(MP). %% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - %% Pretty RFC 3525 messages: %% Added Reason rfc3525_msg1() -> "MEGACO/" ?VERSION_STR " [124.124.124.222] Transaction = 9998 { Context = - { ServiceChange = ROOT { Services { Method = Restart, Reason = 901, ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". rfc3525_msg2() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Reply = 9998 { Context = - { ServiceChange = ROOT { Services { ServiceChangeAddress = 55555, Profile = ResGW/1 } } } }". %% Removed "," after LocalControl ending "}" rfc3525_msg3() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 9999 { Context = - { Modify = A4444 { Media { Stream = 1 { LocalControl { Mode = SendReceive, tdmc/gain=2, ; in dB, tdmc/ec=on } } }, Events = 2222 { al/of {strict=state} } } } }". %% Removed the outermost "{}" pair (before the Reply token) rfc3525_msg4() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 9999 { Context = - { Modify = A4444 } }". rfc3525_msg6() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Transaction = 10000 { Context = - { Notify = A4444 { ObservedEvents =2222 { 19990729T22000000:al/of{init=false} } } } }". rfc3525_msg7() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Reply = 10000 { Context = - { Notify = A4444 } }". rfc3525_msg8() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 10001 { Context = - { Modify = A4444 { Events = 2223 { al/on {strict=state}, dd/ce {DigitMap=Dialplan0} }, Signals {cg/dt}, DigitMap = Dialplan0 { (0| 00|[1-7]xxx|8xxxxxxx|fxxxxxxx|exx|91xxxxxxxxxx|9011x.) } } } }". rfc3525_msg9() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10001 { Context = - { Modify = A4444 } }". rfc3525_msg10() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Transaction = 10002 { Context = - { Notify = A4444 { ObservedEvents =2223 { 19990729T22010001:dd/ce { ds=\"916135551212\", Meth=UM } } } } }". rfc3525_msg11() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Reply = 10002 { Context = - { Notify = A4444 } }". %% Added ? rfc3525_msg12() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 10003 { Context = $ { Add = A4444, Add = $ { Media { Stream = 1 { LocalControl { Mode = ReceiveOnly, nt/jit=40 ; in ms }, Local { v=0 c=IN IP4 $ m=audio $ RTP/AVP 4 a=ptime:30 v=0 c=IN IP4 $ m=audio $ RTP/AVP 0 } } } } } }". %% Added ? rfc3525_msg13() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10003 { Context = 2000 { Add = A4444, Add = A4445 { Media { Stream = 1 { Local { v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 a=recvonly } ; RTP profile for G.723.1 is 4 } } } } }". %% %% Added ? rfc3525_msg14() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 50003 { Context = $ { Add = A5555 { Media { Stream = 1 { LocalControl { Mode = SendReceive } } }, Events = 1234 { al/of {strict=state} }, Signals {al/ri} }, Add = $ { Media { Stream = 1 { LocalControl { Mode = SendReceive, nt/jit=40 ; in ms }, Local { v=0 c=IN IP4 $ m=audio $ RTP/AVP 4 a=ptime:30 }, Remote { v=0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 } ; RTP profile for G.723.1 is 4 } } } } }". %% Added ? rfc3525_msg15() -> "MEGACO/" ?VERSION_STR " [125.125.125.111]:55555 Reply = 50003 { Context = 5000 { Add = A5555, Add = A5556 { Media { Stream = 1 { Local { v=0 o=- 7736844526 7736842807 IN IP4 125.125.125.111 s=- t= 0 0 c=IN IP4 125.125.125.111 m=audio 1111 RTP/AVP 4 } ; RTP profile for G723.1 is 4 } } } } }". %% Added ? rfc3525_msg16a() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 10005 { Context = 2000 { Modify = A4444 { Signals {cg/rt} }, Modify = A4445 { Media { Stream = 1 { Remote { v=0 o=- 7736844526 7736842807 IN IP4 125.125.125.111 s=- t= 0 0 c=IN IP4 125.125.125.111 m=audio 1111 RTP/AVP 4 } ; RTP profile for G723.1 is 4 } } } } }". rfc3525_msg16b() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10005 { Context = 2000 { Modify = A4444, Modify = A4445 } }". rfc3525_msg17a() -> "MEGACO/" ?VERSION_STR " [125.125.125.111]:55555 Transaction = 50005 { Context = 5000 { Notify = A5555 { ObservedEvents = 1234 { 19990729T22020002:al/of{init=false} } } } }". rfc3525_msg17b() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Reply = 50005 { Context = - { Notify = A5555 } }". %% Removed "{ }" after Signals rfc3525_msg17c() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 50006 { Context = 5000 { Modify = A5555 { Events = 1235 { al/on{strict=state} }, Signals ; to turn off ringing } } }". rfc3525_msg17d() -> "MEGACO/" ?VERSION_STR " [125.125.125.111]:55555 Reply = 50006 { Context = 5000 { Modify = A4445 } }". %% Removed "{ }" after Signals rfc3525_msg18a() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 10006 { Context = 2000 { Modify = A4445 { Media { Stream = 1 { LocalControl { Mode = SendReceive } } } }, Modify = A4444 { Signals } } }". rfc3525_msg18b() -> "MEGACO/" ?VERSION_STR " [124.124.124.222]:55555 Reply = 10006 { Context = 2000 { Modify = A4445, Modify = A4444 } }". rfc3525_msg19() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 50007 { Context = - { AuditValue = A5556 { Audit { Media, DigitMap, Events, Signals, Packages, Statistics } } } }". %% Added ? rfc3525_msg20() -> "MEGACO/" ?VERSION_STR " [125.125.125.111]:55555 Reply = 50007 { Context = - { AuditValue = A5556 { Media { TerminationState { ServiceStates = InService, Buffer = OFF }, Stream = 1 { LocalControl { Mode = SendReceive, nt/jit=40 }, Local { v=0 o=- 7736844526 7736842807 IN IP4 125.125.125.111 s=- t= 0 0 c=IN IP4 125.125.125.111 m=audio 1111 RTP/AVP 4 a=ptime:30 }, Remote { v=0 o=- 2890844526 2890842807 IN IP4 124.124.124.222 s=- t= 0 0 c=IN IP4 124.124.124.222 m=audio 2222 RTP/AVP 4 a=ptime:30 } } }, Events, Signals, DigitMap, Packages {nt-1, rtp-1}, Statistics { rtp/ps=1200, ; packets sent nt/os=62300, ; octets sent rtp/pr=700, ; packets received nt/or=45100, ; octets received rtp/pl=0.2, ; % packet loss rtp/jit=20, rtp/delay=40 ; avg latency } } } }". rfc3525_msg21a() -> "MEGACO/" ?VERSION_STR " [125.125.125.111]:55555 Transaction = 50008 { Context = 5000 { Notify = A5555 { ObservedEvents =1235 { 19990729T24020002:al/on {init=false} } } } }". rfc3525_msg21b() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Reply = 50008 { Context = - { Notify = A5555 } }". rfc3525_msg22a() -> "MEGACO/" ?VERSION_STR " [123.123.123.4]:55555 Transaction = 50009 { Context = 5000 { Subtract = A5555 { Audit { Statistics } }, Subtract = A5556 { Audit { Statistics } } } }". %% Added ? rfc3525_msg22b() -> "MEGACO/" ?VERSION_STR " [125.125.125.111]:55555 Reply = 50009 { Context = 5000 { Subtract = A5555 { Statistics { nt/os=45123, ; Octets Sent nt/dur=40 ; in seconds } }, Subtract = A5556 { Statistics { rtp/ps=1245, ; packets sent nt/os=62345, ; octets sent rtp/pr=780, ; packets received nt/or=45123, ; octets received rtp/pl=10, ; % packets lost rtp/jit=27, rtp/delay=48 ; average latency } } } }". rfc3525_msgs() -> [ {msg1, rfc3525_msg1()}, {msg2, rfc3525_msg2()}, {msg3, rfc3525_msg3()}, {msg4, rfc3525_msg4()}, {msg6, rfc3525_msg6()}, {msg7, rfc3525_msg7()}, {msg8, rfc3525_msg8()}, {msg9, rfc3525_msg9()}, {msg10, rfc3525_msg10()}, {msg11, rfc3525_msg11()}, {msg12, rfc3525_msg12()}, {msg13, rfc3525_msg13()}, {msg14, rfc3525_msg14()}, {msg15, rfc3525_msg15()}, {msg16a, rfc3525_msg16a()}, {msg16b, rfc3525_msg16b()}, {msg17a, rfc3525_msg17a()}, {msg17b, rfc3525_msg17b()}, {msg17c, rfc3525_msg17c()}, {msg17d, rfc3525_msg17d()}, {msg18a, rfc3525_msg18a()}, {msg18b, rfc3525_msg18b()}, {msg19, rfc3525_msg19()}, {msg20, rfc3525_msg20()}, {msg21a, rfc3525_msg21a()}, {msg21b, rfc3525_msg21b()}, {msg22a, rfc3525_msg22a()}, {msg22b, rfc3525_msg22b()} ]. rfc3525_msgs_display() -> Msgs = rfc3525_msgs(), Fun = fun({Name, Msg}) -> io:format("~w: ~n~s~n~n", [Name, Msg]) end, lists:foreach(Fun, Msgs). rfc3525_msgs_test() -> put(dbg,true), Res = rfc3525_msgs_test(megaco_pretty_text_encoder, [], 2), erase(dbg), io:format("~w~n", [Res]). rfc3525_msgs_test(Codec, Config, Ver) -> io:format("-----------------------------------------" "~ntesting with" "~n Codec: ~w" "~n Config: ~w" "~n Version: ~w" "~n", [Codec, Config, Ver]), Msgs = rfc3525_msgs(), Test = fun({N,M1}) -> %% io:format("testing ~w: ", [N]), io:format("~n*** testing ~w *** ~n~s~n", [N,M1]), Bin1 = erlang:list_to_binary(M1), case (catch Codec:decode_message(Config, Ver, Bin1)) of {ok, M2} -> %% io:format("d", []), io:format("decoded:~n~p~n", [M2]), case (catch Codec:encode_message(Config, Ver, M2)) of {ok, Bin2} when is_binary(Bin2) -> %% io:format("e~n", []), io:format("encode: ~n~s~n", [erlang:binary_to_list(Bin2)]), {N,ok}; {ok, M3} -> %% io:format("e~n", []), io:format("encode: ~n~s~n", [M3]), {N,ok}; E -> io:format("~n~p~n", [E]), {N,encode_error} end; E -> io:format("~n~p~n", [E]), {N,decode_error} end end, [Test(M) || M <- Msgs]. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% skip(Reason) -> megaco_codec_test_lib:skip(Reason). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% decode_message(Codec, DynamicDecode, Conf, Bin) -> megaco_codec_test_lib:decode_message(Codec, DynamicDecode, ?VERSION, Conf, Bin). encode_message(Codec, Conf, Msg) -> megaco_codec_test_lib:encode_message(Codec, ?VERSION, Conf, Msg). test_msgs(Codec, DynamicDecode, Conf, Msgs) -> megaco_codec_test_lib:test_msgs(Codec, DynamicDecode, ?VERSION, Conf, fun chk_MegacoMessage/2, Msgs). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% decode_mini_message(Codec, Conf, Bin) -> Codec:decode_mini_message(Conf, dynamic, Bin). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% chk_MegacoMessage(M1, M2) -> ?MSG_LIB:chk_MegacoMessage(M1, M2). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% cre_MegacoMessage(Mess) -> ?MSG_LIB:cre_MegacoMessage(Mess). cre_MegacoMessage(V, Mid, Body) -> Mess = ?MSG_LIB:cre_Message(V, Mid, Body), ?MSG_LIB:cre_MegacoMessage(Mess). cre_AuthHeader() -> SecParmIdx = [239, 205, 171, 137], SeqNum = [18, 52, 86, 120], AD = [18, 52, 86, 120, 137, 171, 205, 239, 118, 84, 50, 16], cre_AuthHeader(SecParmIdx, SeqNum, AD). cre_Msg(Mid, Body) -> cre_Msg(?VERSION, Mid, Body). cre_Msg(V, Mid, Body) -> ?MSG_LIB:cre_Message(V, Mid, Body). cre_AuthHeader(Idx, Num, D) -> ?MSG_LIB:cre_AuthenticationHeader(Idx, Num, D). cre_TransId(TransId) -> ?MSG_LIB:cre_TransactionId(TransId). cre_Trans(Trans) -> ?MSG_LIB:cre_Transaction(Trans). cre_TransReq(TransId, Actions) -> ?MSG_LIB:cre_TransactionRequest(TransId, Actions). cre_TransRep(TransId, Actions) -> ?MSG_LIB:cre_TransactionReply(TransId, Actions). cre_TransAck(First, Last) -> ?MSG_LIB:cre_TransactionAck(First, Last). cre_ActReq(CtxId, CmdReqs) -> ?MSG_LIB:cre_ActionRequest(CtxId, CmdReqs). cre_ActRep(CtxId, CmdReply) -> ?MSG_LIB:cre_ActionReply(CtxId, CmdReply). cre_CtxID(Id) -> ?MSG_LIB:cre_ContextID(Id). %% Ind Aud related: cre_IndAudParam(IAP) -> ?MSG_LIB:cre_IndAuditParameter(IAP). cre_IndAudMediaDesc(D) -> ?MSG_LIB:cre_IndAudMediaDescriptor(D). cre_IndAudStreamDesc(SID, SP) -> ?MSG_LIB:cre_IndAudStreamDescriptor(SID, SP). cre_IndAudStreamParms(LCD) -> ?MSG_LIB:cre_IndAudStreamParms(LCD). cre_IndAudLocalControlDesc(SM, RV, RG, PP) -> ?MSG_LIB:cre_IndAudLocalControlDescriptor(SM, RV, RG, PP). cre_IndAudPropertyParm(Name) -> ?MSG_LIB:cre_IndAudPropertyParm(Name). cre_IndAudTermStateDesc(PP) -> ?MSG_LIB:cre_IndAudTerminationStateDescriptor(PP). cre_IndAudTermStateDesc(PP, EBC, SS) -> ?MSG_LIB:cre_IndAudTerminationStateDescriptor(PP, EBC, SS). cre_IndAudEvsDesc(RID, PN) when is_integer(RID) -> ?MSG_LIB:cre_IndAudEventsDescriptor(RID, PN). cre_IndAudEvBufDesc(EN, SID) -> ?MSG_LIB:cre_IndAudEventBufferDescriptor(EN, SID). cre_IndAudSigsDesc(D) -> ?MSG_LIB:cre_IndAudSignalsDescriptor(D). cre_IndAudSig(SN) -> ?MSG_LIB:cre_IndAudSignal(SN). cre_IndAudSeqSigList(ID, SL) -> ?MSG_LIB:cre_IndAudSeqSigList(ID, SL). cre_IndAudDigitMapDesc(DMN) -> ?MSG_LIB:cre_IndAudDigitMapDescriptor(DMN). cre_IndAudStatsDesc(SN) -> ?MSG_LIB:cre_IndAudStatisticsDescriptor(SN). cre_IndAudPkgsDesc(PN, PV) -> ?MSG_LIB:cre_IndAudPackagesDescriptor(PN, PV). %% Parameter related cre_PropParm(Name, Val) -> ?MSG_LIB:cre_PropertyParm(Name, [Val]). %% Statistics related cre_StatsParm(Name, Val) -> ?MSG_LIB:cre_StatisticsParameter(Name, [Val]). % Event related cre_EvParm(Name, Val) -> ?MSG_LIB:cre_EventParameter(Name, Val). cre_ObsEv(Name, Not) -> ?MSG_LIB:cre_ObservedEvent(Name, Not). cre_ObsEv(Name, Not, Par) -> ?MSG_LIB:cre_ObservedEvent(Name, Par, Not). cre_ReqedEv(Name) -> ?MSG_LIB:cre_RequestedEvent(Name). cre_ReqedEv(Name, Action) -> ?MSG_LIB:cre_RequestedEvent(Name, Action). cre_ObsEvsDesc(Id, EvList) -> ?MSG_LIB:cre_ObservedEventsDescriptor(Id, EvList). cre_EvsDesc(Id, EvList) -> ?MSG_LIB:cre_EventsDescriptor(Id, EvList). %% Service change related cre_SvcChParm(M, A, R, P) -> ?MSG_LIB:cre_ServiceChangeParm(M, A, P, R). cre_SvcChResParm(A, P) -> ?MSG_LIB:cre_ServiceChangeResParm(A, P). cre_SvcChReq(Tids, P) -> ?MSG_LIB:cre_ServiceChangeRequest(Tids, P). cre_SvcChProf(Name, Ver) -> ?MSG_LIB:cre_ServiceChangeProfile(Name, Ver). cre_SvcChRep(Tids, Res) -> ?MSG_LIB:cre_ServiceChangeReply(Tids, Res). %% Stream related cre_StreamParms(Lcd) -> ?MSG_LIB:cre_StreamParms(Lcd). cre_StreamParms(Lcd, Ld) -> ?MSG_LIB:cre_StreamParms(Lcd, Ld). cre_StreamParms(Lcd, Ld, Rd) -> ?MSG_LIB:cre_StreamParms(Lcd, Ld, Rd). cre_StreamParmsL(Ld) -> ?MSG_LIB:cre_StreamParms(asn1_NOVALUE, Ld, asn1_NOVALUE). cre_StreamParmsR(Rd) -> ?MSG_LIB:cre_StreamParms(asn1_NOVALUE, asn1_NOVALUE, Rd). cre_StreamDesc(Id, P) -> ?MSG_LIB:cre_StreamDescriptor(Id, P). %% "Local" related cre_LocalControlDesc(Mode) -> ?MSG_LIB:cre_LocalControlDescriptor(Mode). cre_LocalControlDesc(Mode, Parms) -> ?MSG_LIB:cre_LocalControlDescriptor(Mode, Parms). cre_LocalRemoteDesc(Grps) -> ?MSG_LIB:cre_LocalRemoteDescriptor(Grps). %% DigitMap related cre_DigitMapDesc() -> ?MSG_LIB:cre_DigitMapDescriptor(). cre_DigitMapDesc(NameOrVal) -> ?MSG_LIB:cre_DigitMapDescriptor(NameOrVal). cre_DigitMapDesc(Name, Val) -> ?MSG_LIB:cre_DigitMapDescriptor(Name, Val). cre_DigitMapValue(Body) -> ?MSG_LIB:cre_DigitMapValue(Body). cre_DigitMapValue(Body, Start, Short, Long) -> ?MSG_LIB:cre_DigitMapValue(Start, Short, Long, Body). %% Media related cre_MediaDesc(SD) when is_record(SD, 'StreamDescriptor') -> cre_MediaDesc([SD]); cre_MediaDesc(SDs) -> ?MSG_LIB:cre_MediaDescriptor(SDs). %% Notify related cre_NotifyReq(Tids, EvsDesc) -> ?MSG_LIB:cre_NotifyRequest(Tids, EvsDesc). cre_NotifyRep(Tids) -> ?MSG_LIB:cre_NotifyReply(Tids). %% Subtract related cre_SubReq(Tids, Desc) -> ?MSG_LIB:cre_SubtractRequest(Tids, Desc). %% Audit related cre_AuditDesc(Tokens) -> ?MSG_LIB:cre_AuditDescriptor(Tokens). cre_AuditDesc(Tokens, PropertTokens) -> ?MSG_LIB:cre_AuditDescriptor(Tokens, PropertTokens). cre_AuditReq(Tid, Desc) -> ?MSG_LIB:cre_AuditRequest(Tid, Desc). cre_AuditRes(Tid, Res) -> ?MSG_LIB:cre_AuditResult(Tid, Res). %% AMM/AMMS related cre_AmmReq(Tids, Descs) -> ?MSG_LIB:cre_AmmRequest(Tids, Descs). cre_AmmsReply(Tids) -> ?MSG_LIB:cre_AmmsReply(Tids). cre_AmmsReply(Tids, Descs) -> ?MSG_LIB:cre_AmmsReply(Tids, Descs). %% Command related %% cre_command(Tag, Req) -> %% ?MSG_LIB:cre_Command(Tag, Req). cre_CmdReq(Cmd) -> ?MSG_LIB:cre_CommandRequest(Cmd). %% Actions related cre_ReqedActs(DmName) -> EDM = ?MSG_LIB:cre_EventDM(DmName), ?MSG_LIB:cre_RequestedActions(EDM). %% Signal related cre_Sig(Name) -> ?MSG_LIB:cre_Signal(Name). %% Others cre_TimeNot(D,T) -> ?MSG_LIB:cre_TimeNotation(D, T). cre_PkgsItem(Name, Ver) -> ?MSG_LIB:cre_PackagesItem(Name, Ver). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% flex_init(Config) -> megaco_codec_flex_lib:init(Config). flex_finish(Config) -> megaco_codec_flex_lib:finish(Config). flex_scanner_conf(Config) -> megaco_codec_flex_lib:scanner_conf(Config). start_flex_scanner() -> megaco_codec_flex_lib:start(). stop_flex_scanner(Pid) -> megaco_codec_flex_lib:stop(Pid). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% t(F,A) -> p(printable(get(severity),trc),trc,F,A). d(F,A) -> p(printable(get(severity),dbg),dbg,F,A). l(F,A) -> p(printable(get(severity),log),log,F,A). e(F,A) -> p(printable(get(severity),err),err,F,A). printable(trc,_) -> true; printable(dbg,trc) -> false; printable(dbg,_) -> true; printable(log,log) -> true; printable(log,err) -> true; printable(err,err) -> true; printable(_,_) -> false. p(true,L,F,A) -> io:format("~s: " ++ F ++ "~n", [image_of(L)|A]); p(_,_,_,_) -> ok. image_of(trc) -> "T"; image_of(dbg) -> "D"; image_of(log) -> "L"; image_of(err) -> "E"; image_of(L) -> io_lib:format("~p",[L]).