%%
%% %CopyrightBegin%
%%
%% Copyright Ericsson AB 2009-2010. All Rights Reserved.
%%
%% The contents of this file are subject to the Erlang Public License,
%% Version 1.1, (the "License"); you may not use this file except in
%% compliance with the License. You should have received a copy of the
%% Erlang Public License along with this software. If not, it can be
%% retrieved online at http://www.erlang.org/.
%%
%% Software distributed under the License is distributed on an "AS IS"
%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
%% the License for the specific language governing rights and limitations
%% under the License.
%%
%% %CopyrightEnd%

-include_lib("wx/include/wx.hrl").

-define(flat_format(Format,Args), lists:flatten(io_lib:format(Format,Args))).
-define(log(Format,Args), reltool_test_lib:log(Format,Args,?FILE,?LINE)).
-define(warning(Format,Args), ?log("<WARNING>\n " ++ Format,Args)).
-define(error(Format,Args), reltool_test_lib:error(Format,Args,?FILE,?LINE)).
-define(verbose(Format,Args), reltool_test_lib:verbose(Format,Args,?FILE,?LINE)).

-define(fatal(Format,Args),
        ?error(Format, Args),
        exit({test_case_fatal, Format, Args, ?FILE, ?LINE})).

-define(skip(Format,Args),
        ?warning(Format, Args),
        exit({skipped, ?flat_format(Format, Args)})).

-define(ignore(Expr),
        fun() ->
                AcTuAlReS = (catch (Expr)),
		?verbose("ok: ~p\n",[AcTuAlReS]),
		AcTuAlReS
        end()).

-define(msym(ExpectedRes, Expr),
        fun() ->
                AcTuAlReS = (catch (Expr)),
                case AcTuAlReS of
                    ExpectedRes ->
                        ?verbose("ok: ~p\n",[AcTuAlReS]),
                        AcTuAlReS;
                    _ ->
                        reltool_test_lib:error("Not matching actual result was:\n ~p \nExpected ~s\n",
					       [AcTuAlReS, ??ExpectedRes], 
					       ?FILE, ?LINE),
                        AcTuAlReS
                end
        end()).

-define(m(ExpectedRes, Expr),
        fun() ->
                AcTuAlReS = (catch (Expr)),
                case AcTuAlReS of
                    ExpectedRes ->
                        ?verbose("ok: ~p\n",[AcTuAlReS]),
                        AcTuAlReS;
                    _ ->
                        reltool_test_lib:error("Not matching actual result was:\n\t~p \nExpected:\n\t~p\n",
					       [AcTuAlReS, ExpectedRes], 
					       ?FILE, ?LINE),
                        AcTuAlReS
                end
        end()).

-define(m_receive(ExpectedMsg),
        ?m(ExpectedMsg,reltool_test_lib:pick_msg())).

-define(m_multi_receive(ExpectedMsgs),
        fun() ->
                TmPeXpCtEdMsGs = lists:sort(ExpectedMsgs),              
                AcTuAlReS = 
                    lists:sort(lists:map(fun(_) ->
                                                 reltool_test_lib:pick_msg()
                                         end, TmPeXpCtEdMsGs)),
                case AcTuAlReS of
                    TmPeXpCtEdMsGs ->
                        ?verbose("ok: ~p\n",[AcTuAlReS]),
                        AcTuAlReS;
                    _ ->
                        reltool_test_lib:error("Not matching actual result was:\n ~p \nExpected ~p\n",
					       [AcTuAlReS, ExpectedMsgs], 
					       ?FILE, ?LINE),
                        AcTuAlReS
                end
        end()).