diff options
Diffstat (limited to 'lib/common_test/src')
| -rw-r--r-- | lib/common_test/src/ct.erl | 6 | ||||
| -rw-r--r-- | lib/common_test/src/ct_cover.erl | 5 | ||||
| -rw-r--r-- | lib/common_test/src/ct_framework.erl | 34 | ||||
| -rw-r--r-- | lib/common_test/src/ct_logs.erl | 10 | ||||
| -rw-r--r-- | lib/common_test/src/ct_master.erl | 4 | ||||
| -rw-r--r-- | lib/common_test/src/ct_release_test.erl | 20 | ||||
| -rw-r--r-- | lib/common_test/src/ct_repeat.erl | 2 | ||||
| -rw-r--r-- | lib/common_test/src/ct_run.erl | 8 | ||||
| -rw-r--r-- | lib/common_test/src/ct_telnet.erl | 2 | ||||
| -rw-r--r-- | lib/common_test/src/ct_util.erl | 5 | ||||
| -rw-r--r-- | lib/common_test/src/ct_util.hrl | 1 | ||||
| -rw-r--r-- | lib/common_test/src/cth_log_redirect.erl | 27 | ||||
| -rw-r--r-- | lib/common_test/src/cth_surefire.erl | 2 | ||||
| -rw-r--r-- | lib/common_test/src/test_server_ctrl.erl | 46 | 
14 files changed, 93 insertions, 79 deletions
| diff --git a/lib/common_test/src/ct.erl b/lib/common_test/src/ct.erl index 778ea2e9e2..bfa7b25862 100644 --- a/lib/common_test/src/ct.erl +++ b/lib/common_test/src/ct.erl @@ -390,11 +390,7 @@ testcases(TestDir, Suite) ->      end.  make_and_load(Dir, Suite) -> -    EnvInclude = -	case os:getenv("CT_INCLUDE_PATH") of -	    false -> []; -	    CtInclPath -> string:lexemes(CtInclPath, [$:,$ ,$,]) -	end, +    EnvInclude = string:lexemes(os:getenv("CT_INCLUDE_PATH", ""), [$:,$ ,$,]),      StartInclude =  	case init:get_argument(include) of  	    {ok,[Dirs]} -> Dirs; diff --git a/lib/common_test/src/ct_cover.erl b/lib/common_test/src/ct_cover.erl index d286f20a4d..bcd98dcc58 100644 --- a/lib/common_test/src/ct_cover.erl +++ b/lib/common_test/src/ct_cover.erl @@ -262,6 +262,11 @@ get_app_info(App=#cover{app=Name}, [{src_files,Name,Src1}|Terms], Dir) ->      Src = App#cover.src,      get_app_info(App#cover{src=Src++Src1},Terms,Dir); +get_app_info(App=#cover{app=none}, [{local_only,Bool}|Terms], Dir) -> +    get_app_info(App, [{local_only,none,Bool}|Terms], Dir); +get_app_info(App=#cover{app=Name}, [{local_only,Name,Bool}|Terms], Dir) -> +    get_app_info(App#cover{local_only=Bool},Terms,Dir); +  get_app_info(App, [_|Terms], Dir) ->      get_app_info(App, Terms, Dir); diff --git a/lib/common_test/src/ct_framework.erl b/lib/common_test/src/ct_framework.erl index 134ae0e1cc..506147474f 100644 --- a/lib/common_test/src/ct_framework.erl +++ b/lib/common_test/src/ct_framework.erl @@ -314,8 +314,8 @@ add_defaults(Mod,Func, GroupPath) ->  	    ErrStr = io_lib:format("~n*** ERROR *** "  				   "~w:suite/0 failed: ~tp~n",  				   [Suite,Reason]), -	    io:format(ErrStr, []), -	    io:format(?def_gl, ErrStr, []), +	    io:format("~ts", [ErrStr]), +	    io:format(?def_gl, "~ts", [ErrStr]),  	    {suite0_failed,{exited,Reason}};  	SuiteInfo when is_list(SuiteInfo) ->  	    case lists:all(fun(E) when is_tuple(E) -> true; @@ -337,16 +337,16 @@ add_defaults(Mod,Func, GroupPath) ->  					   "Invalid return value from "  					   "~w:suite/0: ~tp~n",  					   [Suite,SuiteInfo]), -		    io:format(ErrStr, []), -		    io:format(?def_gl, ErrStr, []), +		    io:format("~ts", [ErrStr]), +		    io:format(?def_gl, "~ts", [ErrStr]),  		    {suite0_failed,bad_return_value}  	    end;  	SuiteInfo ->  	    ErrStr = io_lib:format("~n*** ERROR *** "  				   "Invalid return value from "  				   "~w:suite/0: ~tp~n", [Suite,SuiteInfo]), -	    io:format(ErrStr, []), -	    io:format(?def_gl, ErrStr, []), +	    io:format("~ts", [ErrStr]), +	    io:format(?def_gl, "~ts", [ErrStr]),  	    {suite0_failed,bad_return_value}      end. @@ -373,8 +373,8 @@ add_defaults1(Mod,Func, GroupPath, SuiteInfo) ->  				      "Invalid return value from "  				      "~w:group(~tw): ~tp~n",  				      [Mod,GrName,BadGr0Val]), -	    io:format(Gr0ErrStr, []), -	    io:format(?def_gl, Gr0ErrStr, []), +	    io:format("~ts", [Gr0ErrStr]), +	    io:format(?def_gl, "~ts", [Gr0ErrStr]),  	    {group0_failed,bad_return_value};  	_ ->  	    Args = if Func == init_per_group ; Func == end_per_group -> @@ -395,8 +395,8 @@ add_defaults1(Mod,Func, GroupPath, SuiteInfo) ->  					      "Invalid return value from "  					      "~w:~tw/0: ~tp~n",  					      [Mod,Func,BadTC0Val]), -		    io:format(TC0ErrStr, []), -		    io:format(?def_gl, TC0ErrStr, []), +		    io:format("~ts", [TC0ErrStr]), +		    io:format(?def_gl, "~ts", [TC0ErrStr]),  		    {testcase0_failed,bad_return_value};  		_ ->  		    %% let test case info (also for all config funcs) override @@ -972,11 +972,10 @@ error_notification(Mod,Func,_Args,{Error,Loc}) ->      end,      PrintError = fun(ErrorFormat, ErrorArgs) -> -		       Div = "~n- - - - - - - - - - - - - - - - - - - " -			     "- - - - - - - - - - - - - - - - - - - - -~n", +                      Div = "\n- - - - - - - - - - - - - - - - - - - " +                            "- - - - - - - - - - - - - - - - - - - - -\n",  		       ErrorStr2 = io_lib:format(ErrorFormat, ErrorArgs), -		       io:format(?def_gl, lists:concat([Div,ErrorStr2,Div,"~n"]), -				 []), +                      io:format(?def_gl, "~ts~n", [lists:concat([Div,ErrorStr2,Div])]),  		       Link =  			   "\n\n<a href=\"#end\">"  			   "Full error description and stacktrace" @@ -985,7 +984,8 @@ error_notification(Mod,Func,_Args,{Error,Loc}) ->  		       ct_logs:tc_log(ct_error_notify,  				      ?MAX_IMPORTANCE,  				      "CT Error Notification", -				      ErrorHtml2++Link, [], []) +                                      "~ts", [ErrorHtml2++Link], +                                      [])  	       end,      case Loc of  	[{?MODULE,error_in_suite}] -> @@ -1168,7 +1168,7 @@ get_all(Mod, ConfTests) ->  		case code:which(Mod) of  		    non_existing ->  			list_to_atom(atom_to_list(Mod)++ -					 " can not be compiled or loaded"); +					 " cannot be compiled or loaded");  		    _ ->  			list_to_atom(atom_to_list(Mod)++":all/0 is missing")  		end, @@ -1181,7 +1181,7 @@ get_all(Mod, ConfTests) ->  		    ErrStr = io_lib:format("~n*** ERROR *** "  					   "~w:all/0 failed: ~tp~n",  					   [Mod,ExitReason]), -		    io:format(?def_gl, ErrStr, []), +		    io:format(?def_gl, "~ts", [ErrStr]),  		    %% save the error info so it doesn't get printed twice  		    ct_util:set_testdata_async({{error_in_suite,Mod},  						ExitReason}); diff --git a/lib/common_test/src/ct_logs.erl b/lib/common_test/src/ct_logs.erl index 07a1693d5d..814b80b8bd 100644 --- a/lib/common_test/src/ct_logs.erl +++ b/lib/common_test/src/ct_logs.erl @@ -542,7 +542,7 @@ tc_print(Category,Importance,Format,Args,Opts) ->                      undefined -> atom_to_list(Category);                      Hd        -> Hd                  end, -            Str = lists:concat([get_header(Heading),Format,"\n\n"]), +            Str = lists:flatten([get_header(Heading),Format,"\n\n"]),              try                  io:format(?def_gl, Str, Args)              catch @@ -935,7 +935,7 @@ create_io_fun(FromPid, CtLogFd, EscChars) ->  		    {_HdOrFt,S,A} -> {false,S,A};  		    {S,A}         -> {true,S,A}  		end, -	    try io_lib:format(Str, Args) of +	    try io_lib:format(lists:flatten(Str), Args) of  		IoStr when Escapable, EscChars, IoList == [] ->  		    escape_chars(IoStr);  		IoStr when Escapable, EscChars -> @@ -1138,10 +1138,10 @@ set_evmgr_gl(GL) ->  open_ctlog(MiscIoName) ->      {ok,Fd} = file:open(?ct_log_name,[write,{encoding,utf8}]), -    io:format(Fd, header("Common Test Framework Log", {[],[1,2],[]}), []), +    io:format(Fd, "~ts", [header("Common Test Framework Log", {[],[1,2],[]})]),      case file:consult(ct_run:variables_file_name("../")) of  	{ok,Vars} -> -	    io:format(Fd, config_table(Vars), []); +	    io:format(Fd, "~ts", [config_table(Vars)]);  	{error,Reason} ->  	    {ok,Cwd} = file:get_cwd(),  	    Dir = filename:dirname(Cwd), @@ -1213,7 +1213,7 @@ print_style_error(Fd, IoFormat, StyleSheet, Reason) ->  close_ctlog(Fd) ->      io:format(Fd, "\n</pre>\n", []), -    io:format(Fd, [xhtml("<br><br>\n", "<br /><br />\n") | footer()], []), +    io:format(Fd, "~ts", [[xhtml("<br><br>\n", "<br /><br />\n") | footer()]]),      ok = file:close(Fd).  %%%----------------------------------------------------------------- diff --git a/lib/common_test/src/ct_master.erl b/lib/common_test/src/ct_master.erl index fd33ee2280..9fc169789c 100644 --- a/lib/common_test/src/ct_master.erl +++ b/lib/common_test/src/ct_master.erl @@ -350,7 +350,7 @@ master_loop(#state{node_ctrl_pids=[],  			  io_lib:format("~-40.40.*ts~tp\n",  					[$_,atom_to_list(Node),Result])  		  end,lists:reverse(Finished)), -    log(all,"TEST RESULTS",Str,[]), +    log(all,"TEST RESULTS","~ts", [Str]),      log(all,"Info","Updating log files",[]),      refresh_logs(LogDirs,[]), @@ -574,7 +574,7 @@ refresh_logs([],Refreshed) ->  			  io_lib:format("Refreshing logs in ~tp... ~tp",  					[D,Result])  		  end,Refreshed), -    log(all,"Info",Str,[]). +    log(all,"Info","~ts", [Str]).  %%%-----------------------------------------------------------------  %%% NODE CONTROLLER, runs and controls tests on a test node. diff --git a/lib/common_test/src/ct_release_test.erl b/lib/common_test/src/ct_release_test.erl index 60d17f43dc..ac3dcab7c9 100644 --- a/lib/common_test/src/ct_release_test.erl +++ b/lib/common_test/src/ct_release_test.erl @@ -152,10 +152,10 @@  %% returned configuration must therefore also be returned from  %% the calling `init_per_*'.  %% -%% If the initialization fails, e.g. if a required release can -%% not be found, the function returns `{skip,Reason}'. In +%% If the initialization fails, e.g. if a required release +%% cannot be found, the function returns `{skip,Reason}'. In  %% this case the other test support functions in this mudule -%% can not be used. +%% cannot be used.  %%  %% Example:  %% @@ -426,7 +426,7 @@ init_upgrade_test(Level) ->      case OldRel of  	false ->  	    ct:log("Release ~tp is not available." -		   " Upgrade on '~p' level can not be tested.", +		   " Upgrade on '~p' level cannot be tested.",  		   [FromVsn,Level]),  	    undefined;  	_ -> @@ -528,7 +528,7 @@ target_system(Apps,CreateDir,InstallDir,{FromVsn,_,AllAppsVsns,Path}) ->  				     {path,Path}]]),      %% Unpack the tar to complete the installation -    erl_tar:extract(RelName ++ ".tar.gz", [{cwd, InstallDir}, compressed]), +    ok = erl_tar:extract(RelName ++ ".tar.gz", [{cwd, InstallDir}, compressed]),      %% Add bin and log dirs      BinDir = filename:join([InstallDir, "bin"]), @@ -554,11 +554,11 @@ target_system(Apps,CreateDir,InstallDir,{FromVsn,_,AllAppsVsns,Path}) ->      %% create start_erl.data, sys.config and start.src      StartErlData = filename:join([InstallDir, "releases", "start_erl.data"]), -    write_file(StartErlData, io_lib:fwrite("~s ~s~n", [ErtsVsn, FromVsn])), +    ok = write_file(StartErlData, io_lib:fwrite("~s ~s~n", [ErtsVsn, FromVsn])),      SysConfig = filename:join([InstallDir, "releases", FromVsn, "sys.config"]), -    write_file(SysConfig, "[]."), +    ok = write_file(SysConfig, "[]."),      StartSrc = filename:join(ErtsBinDir,"start.src"), -    write_file(StartSrc,start_script()), +    ok = write_file(StartSrc,start_script()),      ok = file:change_mode(StartSrc,8#0755),      %% Make start_erl executable @@ -620,7 +620,7 @@ upgrade_system(Apps, FromRel, CreateDir, InstallDir, {_,ToVsn,_,_}) ->  			      [{path,[FromPath]},  			       {outdir,CreateDir}]]),      SysConfig = filename:join([CreateDir, "sys.config"]), -    write_file(SysConfig, "[]."), +    ok = write_file(SysConfig, "[]."),      ok = systools(make_tar,[RelName,[{erts,code:root_dir()}]]), @@ -858,7 +858,7 @@ subst_file(Src, Dest, Vars, Opts) ->      {ok, Bin} = file:read_file(Src),      Conts = unicode:characters_to_list(Bin),      NConts = subst(Conts, Vars), -    write_file(Dest, NConts), +    ok = write_file(Dest, NConts),      case lists:member(preserve, Opts) of          true ->              {ok, FileInfo} = file:read_file_info(Src), diff --git a/lib/common_test/src/ct_repeat.erl b/lib/common_test/src/ct_repeat.erl index 8b1c7d47bb..b97c6e59e7 100644 --- a/lib/common_test/src/ct_repeat.erl +++ b/lib/common_test/src/ct_repeat.erl @@ -278,7 +278,7 @@ log_loop_info(Args) ->  		    ForceStop ->  			io_lib:format("force_stop is set to: ~w",[ForceStop])  		end,			 -	    ct_logs:log("Test loop info",LogStr1++LogStr2++LogStr3++LogStr4,[]) +	    ct_logs:log("Test loop info","~ts", [LogStr1++LogStr2++LogStr3++LogStr4])      end.  ts(Secs) -> diff --git a/lib/common_test/src/ct_run.erl b/lib/common_test/src/ct_run.erl index c9d406f1fd..960252a6fe 100644 --- a/lib/common_test/src/ct_run.erl +++ b/lib/common_test/src/ct_run.erl @@ -2345,18 +2345,24 @@ start_cover(Opts=#opts{coverspec=CovData,cover_stop=CovStop},LogDir) ->       CovImport,       _CovExport,       #cover{app        = CovApp, +            local_only = LocalOnly,  	    level      = CovLevel,  	    excl_mods  = CovExcl,  	    incl_mods  = CovIncl,  	    cross      = CovCross,  	    src        = _CovSrc}} = CovData, +    case LocalOnly of +        true -> cover:local_only(); +        false -> ok +    end,      ct_logs:log("COVER INFO",  		"Using cover specification file: ~ts~n"  		"App: ~w~n" +                "Local only: ~w~n"  		"Cross cover: ~w~n"  		"Including ~w modules~n"  		"Excluding ~w modules", -		[CovFile,CovApp,CovCross, +		[CovFile,CovApp,LocalOnly,CovCross,  		 length(CovIncl),length(CovExcl)]),      %% Tell test_server to print a link in its coverlog diff --git a/lib/common_test/src/ct_telnet.erl b/lib/common_test/src/ct_telnet.erl index 174008c790..219f58dcf5 100644 --- a/lib/common_test/src/ct_telnet.erl +++ b/lib/common_test/src/ct_telnet.erl @@ -1127,7 +1127,7 @@ match_line(Name,Pid,Line,[Pattern|Patterns],FoundPrompt,Term,EO,RetTag) ->      end;  match_line(Name,Pid,Line,[],FoundPrompt,Term,EO,match) ->      match_line(Name,Pid,Line,EO#eo.haltpatterns,FoundPrompt,Term,EO,halt); -%% print any terminated line that can not be matched +%% print any terminated line that cannot be matched  match_line(Name,Pid,Line,[],_FoundPrompt,true,_EO,halt) ->      log(name_or_pid(Name,Pid),"       ~ts",[Line]),      nomatch; diff --git a/lib/common_test/src/ct_util.erl b/lib/common_test/src/ct_util.erl index d8fd401a64..9f489e9bfb 100644 --- a/lib/common_test/src/ct_util.erl +++ b/lib/common_test/src/ct_util.erl @@ -192,7 +192,10 @@ do_start(Parent, Mode, LogDir, Verbosity) ->  	    ok      end, -    ct_default_gl:start_link(group_leader()), +    case ct_default_gl:start_link(group_leader()) of +        {ok, _} -> ok; +        ignore -> ok +    end,      {StartTime,TestLogDir} = ct_logs:init(Mode, Verbosity), diff --git a/lib/common_test/src/ct_util.hrl b/lib/common_test/src/ct_util.hrl index 039c8168ec..d5c93d05ba 100644 --- a/lib/common_test/src/ct_util.hrl +++ b/lib/common_test/src/ct_util.hrl @@ -62,6 +62,7 @@  		   merge_tests=true}).  -record(cover, {app=none, +                local_only=false,  		level=details,  		excl_mods=[],  		incl_mods=[], diff --git a/lib/common_test/src/cth_log_redirect.erl b/lib/common_test/src/cth_log_redirect.erl index 4980d1ee4b..fe869a4373 100644 --- a/lib/common_test/src/cth_log_redirect.erl +++ b/lib/common_test/src/cth_log_redirect.erl @@ -124,7 +124,8 @@ start_log_handler() ->                    shutdown=>2000,                    type=>worker,                    modules=>[?MODULE]}, -            {ok,_} = supervisor:start_child(logger_sup,ChildSpec); +            {ok,_} = supervisor:start_child(logger_sup,ChildSpec), +            ok;          _Pid ->              ok      end, @@ -193,10 +194,10 @@ handle_call({log,      case LogFunc of          tc_log ->              ct_logs:tc_log(Category, ?STD_IMPORTANCE, -                           Header, String, [], []); +                           Header, "~ts", [String], []);          tc_log_async ->              ct_logs:tc_log_async(sasl, ?STD_IMPORTANCE, -                                 Header, String, []) +                                 Header, "~ts", [String])      end,      {reply,ok,State}; @@ -260,34 +261,34 @@ handle_remote_events(Bool) ->  format_header(#eh_state{curr_suite = undefined,  			curr_group = undefined,  			curr_func = undefined}) -> -    io_lib:format("System report", []); +    lists:flatten(io_lib:format("System report", []));  format_header(#eh_state{curr_suite = Suite,  			curr_group = undefined,  			curr_func = undefined}) -> -    io_lib:format("System report during ~w", [Suite]); +    lists:flatten(io_lib:format("System report during ~w", [Suite]));  format_header(#eh_state{curr_suite = Suite,  			curr_group = undefined,  			curr_func = TcOrConf}) -> -    io_lib:format("System report during ~w:~tw/1", -		  [Suite,TcOrConf]); +    lists:flatten(io_lib:format("System report during ~w:~tw/1", +                                [Suite,TcOrConf]));  format_header(#eh_state{curr_suite = Suite,  			curr_group = Group,  			curr_func = Conf}) when Conf == init_per_group;  						Conf == end_per_group -> -    io_lib:format("System report during ~w:~w/2 for ~tw", -		  [Suite,Conf,Group]); +    lists:flatten(io_lib:format("System report during ~w:~w/2 for ~tw", +                                [Suite,Conf,Group]));  format_header(#eh_state{curr_suite = Suite,  			curr_group = Group,  			parallel_tcs = true}) -> -    io_lib:format("System report during ~tw in ~w", -		  [Group,Suite]); +    lists:flatten(io_lib:format("System report during ~tw in ~w", +                                [Group,Suite]));  format_header(#eh_state{curr_suite = Suite,  			curr_group = Group,  			curr_func = TC}) -> -    io_lib:format("System report during ~w:~tw/1 in ~tw", -		  [Suite,TC,Group]). +    lists:flatten(io_lib:format("System report during ~w:~tw/1 in ~tw", +                                [Suite,TC,Group])). diff --git a/lib/common_test/src/cth_surefire.erl b/lib/common_test/src/cth_surefire.erl index b0742717ae..c9b4cb10c6 100644 --- a/lib/common_test/src/cth_surefire.erl +++ b/lib/common_test/src/cth_surefire.erl @@ -235,7 +235,7 @@ close_suite(#state{ test_cases = TCs, url_base = UrlBase } = State) ->  terminate(State = #state{ test_cases = [] }) ->      {ok,D} = file:open(State#state.filepath,[write,{encoding,utf8}]),      io:format(D, "<?xml version=\"1.0\" encoding= \"UTF-8\" ?>", []), -    io:format(D, to_xml(State), []), +    io:format(D, "~ts", [to_xml(State)]),      catch file:sync(D),      catch file:close(D);  terminate(State) -> diff --git a/lib/common_test/src/test_server_ctrl.erl b/lib/common_test/src/test_server_ctrl.erl index 8bd6cd583a..1518c6e8d6 100644 --- a/lib/common_test/src/test_server_ctrl.erl +++ b/lib/common_test/src/test_server_ctrl.erl @@ -1393,7 +1393,7 @@ temp_nodename([Chr|Base], Acc) ->  %%  %% Counts the test cases that are about to run and returns that number.  %% If there's a conf group in TestSpec with a repeat property, the total number -%% of cases can not be calculated and NoOfCases = unknown. +%% of cases cannot be calculated and NoOfCases = unknown.  count_test_cases(TopCases, SkipCases) when is_list(TopCases) ->      case collect_all_cases(TopCases, SkipCases) of  	{error,_Why} = Error -> @@ -1558,7 +1558,7 @@ do_test_cases(TopCases, SkipCases,  			 Html1}  		end, -	    print(html, Header), +	    print(html, "~ts", [Header]),  	    print(html, xhtml("<p>", "<h4>")),  	    print_timestamp(html, "Test started at "), @@ -1605,10 +1605,10 @@ do_test_cases(TopCases, SkipCases,  		  [?suitelog_name,CoverLog,?unexpected_io_log]),  	    print(html,  		  "<p>~ts</p>\n" ++ -		  xhtml(["<table bgcolor=\"white\" border=\"3\" cellpadding=\"5\">\n", -			 "<thead>\n"], -			["<table id=\"",?sortable_table_name,"\">\n", -			 "<thead>\n"]) ++ +		  xhtml("<table bgcolor=\"white\" border=\"3\" cellpadding=\"5\">\n" ++ +			 "<thead>\n", +			"<table id=\"" ++ ?sortable_table_name ++ "\">\n" ++ +			 "<thead>\n") ++  		      "<tr><th>Num</th><th>Module</th><th>Group</th>" ++  		      "<th>Case</th><th>Log</th><th>Time</th><th>Result</th>" ++  		      "<th>Comment</th></tr>\n</thead>\n<tbody>\n", @@ -3306,7 +3306,8 @@ skip_case1(Type, CaseNum, Mod, Func, Comment, Mode) ->         true ->  	    print(2,"*** Skipping test case #~w ~tw ***", [CaseNum,{Mod,Func}])      end, -    TR = xhtml("<tr valign=\"top\">", ["<tr class=\"",odd_or_even(),"\">"]),	        +    TR = xhtml("<tr valign=\"top\">", +               "<tr class=\"" ++ odd_or_even() ++ "\">"),      GroupName =	case get_name(Mode) of  		    undefined -> "";  		    Name      -> cast_to_list(Name) @@ -3796,8 +3797,8 @@ run_test_case1(Ref, Num, Mod, Func, Args, RunInit,      end,      print(minor, -	  escape_chars(io_lib:format("Config value:\n\n    ~tp\n", [Args2Print])), -	  []), +          "~ts", +	  [escape_chars(io_lib:format("Config value:\n\n    ~tp\n", [Args2Print]))]),      print(minor, "Current directory is ~tp\n", [Cwd]),      GrNameStr =	case GrName of @@ -3806,7 +3807,7 @@ run_test_case1(Ref, Num, Mod, Func, Args, RunInit,  		end,      print(major, "=started       ~s", [lists:flatten(timestamp_get(""))]),      {{Col0,Col1},Style} = get_font_style((RunInit==run_init), Mode), -    TR = xhtml("<tr valign=\"top\">", ["<tr class=\"",odd_or_even(),"\">"]), +    TR = xhtml("<tr valign=\"top\">", "<tr class=\"" ++ odd_or_even() ++ "\">"),      EncMinorBase = uri_encode(MinorBase),      print(html,	TR ++ "<td>" ++ Col0 ++ "~ts" ++ Col1 ++ "</td>"  	  "<td>" ++ Col0 ++ "~w" ++ Col1 ++ "</td>" @@ -3831,7 +3832,7 @@ run_test_case1(Ref, Num, Mod, Func, Args, RunInit,      print(minor, "<a name=\"end\"></a>", [], internal_raw),      print(minor, "\n", [], internal_raw),      print_timestamp(minor, "Ended at "), -    print(major, "=ended         ~s", [lists:flatten(timestamp_get(""))]), +    print(major, "=ended         ~s", [timestamp_get("")]),      do_unless_parallel(Main, fun() -> file:set_cwd(filename:dirname(TSDir)) end), @@ -4075,9 +4076,9 @@ progress(failed, CaseNum, Mod, Func, GrName, Loc, {testcase_aborted,Reason}, _T,      FormatLoc = test_server_sup:format_loc(Loc),      print(minor, "=== Location: ~ts", [FormatLoc]),      print(minor, -	  escape_chars(io_lib:format("=== Reason: {testcase_aborted,~tp}", -				     [Reason])), -	  []), +          "~ts", +	  [escape_chars(io_lib:format("=== Reason: {testcase_aborted,~tp}", +				     [Reason]))]),      failed;  progress(failed, CaseNum, Mod, Func, GrName, unknown, Reason, Time, @@ -4115,8 +4116,8 @@ progress(failed, CaseNum, Mod, Func, GrName, unknown, Reason, Time,      print(minor, "=== Location: ~w", [unknown]),      {FStr,FormattedReason} = format_exception(Reason),      print(minor, -	  escape_chars(io_lib:format("=== Reason: " ++ FStr, [FormattedReason])), -	  []), +          "~ts", +	  [escape_chars(io_lib:format("=== Reason: " ++ FStr, [FormattedReason]))]),      failed;  progress(failed, CaseNum, Mod, Func, GrName, Loc, Reason, Time, @@ -4150,8 +4151,9 @@ progress(failed, CaseNum, Mod, Func, GrName, Loc, Reason, Time,      FormatLoc = test_server_sup:format_loc(LocMin),      print(minor, "=== Location: ~ts", [FormatLoc]),      {FStr,FormattedReason} = format_exception(Reason), -    print(minor, "=== Reason: " ++ -	      escape_chars(io_lib:format(FStr, [FormattedReason])), []), +    print(minor, "~ts", +          ["=== Reason: " ++ +           escape_chars(io_lib:format(FStr, [FormattedReason]))]),      failed;  progress(ok, _CaseNum, Mod, Func, GrName, _Loc, RetVal, Time, @@ -4184,8 +4186,8 @@ progress(ok, _CaseNum, Mod, Func, GrName, _Loc, RetVal, Time,  	  "~ts</tr>\n",  	  [TimeStr,Comment]),      print(minor, -	  escape_chars(io_lib:format("=== Returned value: ~tp", [RetVal])), -	  []), +          "~ts", +	  [escape_chars(io_lib:format("=== Returned value: ~tp", [RetVal]))]),      ok.  %%-------------------------------------------------------------------- @@ -4542,7 +4544,7 @@ timestamp_get(Leader) ->  timestamp_get_internal(Leader, Format) ->      {YY,MM,DD,H,M,S} = time_get(), -    io_lib:format(Format, [Leader,YY,MM,DD,H,M,S]). +    lists:flatten(io_lib:format(Format, [Leader,YY,MM,DD,H,M,S])).  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  %% time_get() -> {YY,MM,DD,H,M,S} @@ -4906,7 +4908,7 @@ collect_files(Dir, Pattern, St, Mode) ->  fullname_to_mod(Path) when is_list(Path) ->      %% If this is called with a binary, then we are probably in +fnu      %% mode and have found a beam file with name encoded as latin1. We -    %% will let this crash since it can not work to load such a module +    %% will let this crash since it cannot work to load such a module      %% anyway. It should be removed or renamed!      list_to_atom(filename:rootname(filename:basename(Path))). | 
