%%
%% %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])).