%% %% %CopyrightBegin% %% %% Copyright Ericsson AB 2010-2011. 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: Define common macros for testing %%---------------------------------------------------------------------- %% -define(FLUSH(), diameter_test_lib:flush()). -define(SLEEP(MSEC), diameter_test_lib:sleep(MSEC)). -define(M(), diameter_test_lib:millis()). -define(MDIFF(A,B), diameter_test_lib:millis_diff(A,B)). -define(HOURS(T), diameter_test_lib:hours(T)). -define(MINUTES(T), diameter_test_lib:minutes(T)). -define(SECONDS(T), diameter_test_lib:seconds(T)). -define(KEY1SEARCH(Key, L), diameter_test_lib:key1search(Key, L)). -define(APPLY(Proxy, Fun), Proxy ! {apply, Fun}). -define(LOG(Format, Args), diameter_test_lib:log(Format, Args, ?MODULE, ?LINE)). -define(ERROR(Reason), diameter_test_lib:error(Reason, ?MODULE, ?LINE)). -define(OS_BASED_SKIP(Skippable), diameter_test_lib:os_based_skip(Skippable)). -define(NON_PC_TC_MAYBE_SKIP(Config, Condition), diameter_test_lib:non_pc_tc_maybe_skip(Config, Condition, ?MODULE, ?LINE)). -define(FAIL(Reason), diameter_test_lib:fail(Reason, ?MODULE, ?LINE)). -define(SKIP(Reason), diameter_test_lib:skip(Reason, ?MODULE, ?LINE)). -define(VERIFYL(Expected, Expr), fun(A,B) when list(A), list(B) -> A1 = lists:sort(A), B1 = lists:sort(B), case A1 of B1 -> ?LOG("Ok, ~p~n", [B]); _ -> ?ERROR(B) end, B; (A,A) -> ?LOG("Ok, ~p~n", [A]), A; (A,B) -> ?ERROR(B), B end(Expected, (catch Expr))). -define(VERIFY(Expected, Expr), fun() -> AcTuAlReS = (catch (Expr)), case AcTuAlReS of Expected -> ?LOG("Ok, ~p~n", [AcTuAlReS]); _ -> ?ERROR(AcTuAlReS) end, AcTuAlReS end()). -define(RECEIVE(Expected), ?VERIFY(Expected, ?FLUSH())). -define(MULTI_RECEIVE(Expected), ?VERIFY(lists:sort(Expected), lists:sort(?FLUSH()))). -define(ACQUIRE_NODES(N, Config), diameter_test_lib:prepare_test_case([init, {stop_app, diameter}], N, Config, ?FILE, ?LINE)). -define(REPORT_IMPORTANT(Label, Content), ?REPORT_EVENT(20, Label, Content)). -define(REPORT_VERBOSE(Label, Content), ?REPORT_EVENT(40, Label, Content)). -define(REPORT_DEBUG(Label, Content), ?REPORT_EVENT(60, Label, Content)). -define(REPORT_TRACE(Label, Content), ?REPORT_EVENT(80, Label, Content)). -define(REPORT_EVENT(Severity, Label, Content), diameter_test_lib:report_event(Severity, Label, [{line, ?MODULE, ?LINE} | Content])).