diff options
Diffstat (limited to 'lib/common_test/src/ct_run.erl')
| -rw-r--r-- | lib/common_test/src/ct_run.erl | 92 | 
1 files changed, 17 insertions, 75 deletions
| diff --git a/lib/common_test/src/ct_run.erl b/lib/common_test/src/ct_run.erl index 05b1e70098..c9d406f1fd 100644 --- a/lib/common_test/src/ct_run.erl +++ b/lib/common_test/src/ct_run.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 2004-2017. All Rights Reserved. +%% Copyright Ericsson AB 2004-2018. All Rights Reserved.  %%  %% Licensed under the Apache License, Version 2.0 (the "License");  %% you may not use this file except in compliance with the License. @@ -18,11 +18,6 @@  %% %CopyrightEnd%  %% -%%% @doc Common Test Framework test execution control module. -%%% -%%% <p>This module exports functions for installing and running tests -%%% withing the Common Test Framework.</p> -  -module(ct_run).  %% Script interface @@ -84,17 +79,6 @@  	       tests,  	       starter}). -%%%----------------------------------------------------------------- -%%% @spec script_start() -> term() -%%% -%%% @doc Start tests via the ct_run program or script. -%%% -%%% <p>Example:<br/><code>./ct_run -config config.ctc -dir -%%% $TEST_DIR</code></p> -%%% -%%% <p>Example:<br/><code>./ct_run -config config.ctc -suite -%%% $SUITE_PATH/$SUITE_NAME [-case $CASE_NAME]</code></p> -%%%  script_start() ->      process_flag(trap_exit, true),      Init = init:get_arguments(), @@ -147,7 +131,7 @@ script_start(Args) ->  	    CTVsn =  		case filename:basename(code:lib_dir(common_test)) of  		    CTBase when is_list(CTBase) -> -			case string:tokens(CTBase, "-") of +			case string:lexemes(CTBase, "-") of  			    ["common_test",Vsn] -> " v"++Vsn;  			    _ -> ""  			end @@ -317,7 +301,7 @@ script_start1(Parent, Args) ->  			{undefined,InclDirs};  		    CtInclPath ->  			AllInclDirs = -			    string:tokens(CtInclPath,[$:,$ ,$,]) ++ InclDirs, +			    string:lexemes(CtInclPath,[$:,$ ,$,]) ++ InclDirs,  			application:set_env(common_test, include, AllInclDirs),  			{undefined,AllInclDirs}  		end; @@ -442,11 +426,9 @@ script_start2(Opts = #opts{vts = undefined,                  TestSpecData ->  		    execute_all_specs(TestSpecData, Opts, Args, [])              catch -                throw:{error,Reason} -> -		    StackTrace = erlang:get_stacktrace(), +                throw:{error,Reason}:StackTrace ->  		    {error,{invalid_testspec,{Reason,StackTrace}}}; -                _:Reason -> -		    StackTrace = erlang:get_stacktrace(), +                _:Reason:StackTrace ->  		    {error,{invalid_testspec,{Reason,StackTrace}}}              end;  	[] -> @@ -801,9 +783,6 @@ script_start4(#opts{shell = true, cover = Cover}, _) ->  script_start4(Opts = #opts{tests = Tests}, Args) ->      do_run(Tests, [], Opts, Args). -%%%----------------------------------------------------------------- -%%% @spec script_usage() -> ok -%%% @doc Print usage information for <code>ct_run</code>.  script_usage() ->      io:format("\nUsage:\n\n"),      io:format("Run tests from command line:\n\n" @@ -887,9 +866,6 @@ script_usage() ->  	      "\n\t [-basic_html]"  	      "\n\t [-no_esc_chars]\n\n"). -%%%----------------------------------------------------------------- -%%% @hidden -%%% @equiv ct:install/1  install(Opts) ->      install(Opts, "."). @@ -933,15 +909,6 @@ install(Opts, LogDir) ->  variables_file_name(Dir) ->      filename:join(Dir, "variables-"++atom_to_list(node())). -%%%----------------------------------------------------------------- -%%% @spec run_test(Opts) -> Result -%%%   Opts = [tuple()] -%%%   Result = [TestResult] | {error,Reason} -%%% -%%% @doc Start tests from the erlang shell or from an erlang program. -%%% @equiv ct:run_test/1 -%%%----------------------------------------------------------------- -  run_test(StartOpt) when is_tuple(StartOpt) ->      run_test([StartOpt]); @@ -1101,7 +1068,7 @@ run_test2(StartOpts) ->  			application:set_env(common_test, include, InclDirs),  			{undefined,InclDirs};  		    CtInclPath -> -			InclDirs1 = string:tokens(CtInclPath, [$:,$ ,$,]), +			InclDirs1 = string:lexemes(CtInclPath, [$:,$ ,$,]),  			AllInclDirs = InclDirs1++InclDirs,  			application:set_env(common_test, include, AllInclDirs),  			{undefined,AllInclDirs} @@ -1211,11 +1178,9 @@ run_spec_file(Relaxed,  	TestSpecData ->  	    run_all_specs(TestSpecData, Opts, StartOpts, [])      catch -	throw:{error,CTReason} -> -	    StackTrace = erlang:get_stacktrace(), +	throw:{error,CTReason}:StackTrace ->  	    exit({error,{invalid_testspec,{CTReason,StackTrace}}}); -	_:CTReason -> -	    StackTrace = erlang:get_stacktrace(), +	_:CTReason:StackTrace ->  	    exit({error,{invalid_testspec,{CTReason,StackTrace}}})      end. @@ -1431,14 +1396,6 @@ run_dir(Opts = #opts{logdir = LogDir,  	    exit({error,{incorrect_start_options,{Dir,Suite,GsAndCs}}})      end. -%%%----------------------------------------------------------------- -%%% @spec run_testspec(TestSpec) -> Result -%%%   TestSpec = [term()] -%%% -%%% @doc Run test specified by <code>TestSpec</code>. The terms are -%%% the same as those used in test specification files. -%%% @equiv ct:run_testspec/1 -%%%-----------------------------------------------------------------  run_testspec(TestSpec) ->      CTPid = spawn(run_testspec1_fun(TestSpec)),      Ref = monitor(process, CTPid), @@ -1490,7 +1447,7 @@ run_testspec2(TestSpec) ->  		    false ->  			Opts#opts.include;  		    CtInclPath -> -			EnvInclude = string:tokens(CtInclPath, [$:,$ ,$,]), +			EnvInclude = string:lexemes(CtInclPath, [$:,$ ,$,]),  			EnvInclude++Opts#opts.include  		end,  	    application:set_env(common_test, include, AllInclude), @@ -1638,9 +1595,6 @@ delistify([E]) -> E;  delistify(E)   -> E. -%%%----------------------------------------------------------------- -%%% @hidden -%%% @equiv ct:run/3  run(TestDir, Suite, Cases) ->      case install([]) of  	ok -> @@ -1649,9 +1603,6 @@ run(TestDir, Suite, Cases) ->  	    Error      end. -%%%----------------------------------------------------------------- -%%% @hidden -%%% @equiv ct:run/2  run(TestDir, Suite) when is_list(TestDir), is_integer(hd(TestDir)) ->      case install([]) of  	ok -> @@ -1660,9 +1611,6 @@ run(TestDir, Suite) when is_list(TestDir), is_integer(hd(TestDir)) ->  	    Error      end. -%%%----------------------------------------------------------------- -%%% @hidden -%%% @equiv ct:run/1  run(TestDirs) ->      case install([]) of  	ok -> @@ -1961,7 +1909,8 @@ auto_compile(TestSuites) ->      SuiteMakeErrors =  	lists:flatmap(fun({TestDir,Suite} = TS) ->  			      case run_make(suites, TestDir,  -					    Suite, UserInclude) of +					    Suite, UserInclude, +                                            [nowarn_export_all]) of  				  {error,{make_failed,Bad}} ->  				      [{TS,Bad}];  				  {error,_} -> @@ -1979,7 +1928,7 @@ auto_compile(TestSuites) ->  		  case lists:member(Dir, Done) of  		      false ->  			  Failed1 = -			      case run_make(helpmods, Dir, Suite, UserInclude) of +			      case run_make(helpmods, Dir, Suite, UserInclude, []) of  				  {error,{make_failed,BadMods}} ->  				      [{{Dir,all},BadMods}|Failed];  				  {error,_} -> @@ -2072,16 +2021,9 @@ get_bad_suites([], BadSuites) ->      BadSuites. - -%%%----------------------------------------------------------------- -%%% @hidden -%%% @equiv ct:step/3  step(TestDir, Suite, Case) ->      step(TestDir, Suite, Case, []). -%%%----------------------------------------------------------------- -%%% @hidden -%%% @equiv ct:step/4  step(TestDir, Suite, Case, Opts) when is_list(TestDir),  				      is_atom(Suite), is_atom(Case),  				      Suite =/= all, Case =/= all -> @@ -2728,12 +2670,12 @@ get_name(Dir) ->  run_make(TestDir, Mod, UserInclude) -> -    run_make(suites, TestDir, Mod, UserInclude). +    run_make(suites, TestDir, Mod, UserInclude, [nowarn_export_all]). -run_make(Targets, TestDir0, Mod, UserInclude) when is_list(Mod) -> -    run_make(Targets, TestDir0, list_to_atom(Mod), UserInclude); +run_make(Targets, TestDir0, Mod, UserInclude, COpts) when is_list(Mod) -> +    run_make(Targets, TestDir0, list_to_atom(Mod), UserInclude, COpts); -run_make(Targets, TestDir0, Mod, UserInclude) -> +run_make(Targets, TestDir0, Mod, UserInclude, COpts) ->      case locate_test_dir(TestDir0, Mod) of  	{ok,TestDir} ->  	    %% send a start_make notification which may suspend @@ -2748,7 +2690,7 @@ run_make(Targets, TestDir0, Mod, UserInclude) ->  	    XmerlInclude = get_dir(xmerl, "include"),  	    ErlFlags = UserInclude ++ [{i,CtInclude},  				       {i,XmerlInclude}, -				       debug_info], +				       debug_info] ++ COpts,  	    Result =  		if Mod == all ; Targets == helpmods ->  			case (catch ct_make:all([noexec|ErlFlags])) of | 
