diff options
| author | Sverker Eriksson <[email protected]> | 2017-08-29 16:16:33 +0200 | 
|---|---|---|
| committer | Sverker Eriksson <[email protected]> | 2017-08-30 16:26:40 +0200 | 
| commit | d83975178956dbaed84c315ba249a571ce796cb3 (patch) | |
| tree | 9fed01d1f57c753b7e470b7b70371ce9bd0afc86 /lib | |
| parent | 7c5fcd3f2701cbb614930682ac52ff75b9c26e6c (diff) | |
| download | otp-d83975178956dbaed84c315ba249a571ce796cb3.tar.gz otp-d83975178956dbaed84c315ba249a571ce796cb3.tar.bz2 otp-d83975178956dbaed84c315ba249a571ce796cb3.zip | |
Revert "remove unused purify functions"
This reverts commit d8c8e0c66d6faf5402682f3a8568362eedebdfee.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/common_test/src/test_server.erl | 67 | ||||
| -rw-r--r-- | lib/common_test/src/test_server_ctrl.erl | 9 | ||||
| -rw-r--r-- | lib/stdlib/test/id_transform_SUITE.erl | 9 | 
3 files changed, 77 insertions, 8 deletions
| diff --git a/lib/common_test/src/test_server.erl b/lib/common_test/src/test_server.erl index ee3a5e4bba..a47b3f824f 100644 --- a/lib/common_test/src/test_server.erl +++ b/lib/common_test/src/test_server.erl @@ -21,7 +21,7 @@  -define(DEFAULT_TIMETRAP_SECS, 60).  %%% TEST_SERVER_CTRL INTERFACE %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% --export([run_test_case_apply/1,init_target_info/0]). +-export([run_test_case_apply/1,init_target_info/0,init_purify/0]).  -export([cover_compile/1,cover_analyse/2]).  %%% TEST_SERVER_SUP INTERFACE %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% @@ -49,6 +49,10 @@  -export([break/1,break/2,break/3,continue/0,continue/1]). +%%% DEBUGGER INTERFACE %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +-export([purify_new_leaks/0, purify_format/2, purify_new_fds_inuse/0, +	 purify_is_running/0]). +  %%% PRIVATE EXPORTED %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  -export([]). @@ -69,6 +73,10 @@ init_target_info() ->  		 username=test_server_sup:get_username(),  		 cookie=atom_to_list(erlang:get_cookie())}. +init_purify() -> +    purify_new_leaks(). + +  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  %% cover_compile(#cover{app=App,incl=Include,excl=Exclude,cross=Cross}) ->  %%        {ok,#cover{mods=AnalyseModules}} | {error,Reason} @@ -358,7 +366,8 @@ stick_all_sticky(Node,Sticky) ->  %% compensate timetraps for runtime delays introduced by e.g. tools like  %% cover. -run_test_case_apply({Mod,Func,Args,Name,RunInit,TimetrapData}) -> +run_test_case_apply({CaseNum,Mod,Func,Args,Name,RunInit,TimetrapData}) -> +    purify_format("Test case #~w ~w:~w/1", [CaseNum, Mod, Func]),      case is_valgrind() of  	false ->  	    ok; @@ -370,6 +379,7 @@ run_test_case_apply({Mod,Func,Args,Name,RunInit,TimetrapData}) ->      Result = run_test_case_apply(Mod, Func, Args, Name, RunInit,  				 TimetrapData),      ProcAft = erlang:system_info(process_count), +    purify_new_leaks(),      DetFail = get(test_server_detected_fail),      {Result,DetFail,ProcBef,ProcAft}. @@ -1826,6 +1836,7 @@ timetrap_scale_factor() ->      timetrap_scale_factor([  	{ 2, fun() -> has_lock_checking() end},  	{ 3, fun() -> has_superfluous_schedulers() end}, +	{ 5, fun() -> purify_is_running() end},  	{ 6, fun() -> is_debug() end},  	{10, fun() -> is_cover() end},          {10, fun() -> is_valgrind() end} @@ -2740,6 +2751,58 @@ is_valgrind() ->  	_ -> true      end. +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +%%                     DEBUGGER INTERFACE                    %% +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +%% purify_is_running() -> false|true +%% +%% Tests if Purify is currently running. + +purify_is_running() -> +    case catch erlang:system_info({error_checker, running}) of +	{'EXIT', _} -> false; +	Res -> Res +    end. + +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +%% purify_new_leaks() -> false|BytesLeaked +%% BytesLeaked = integer() +%% +%% Checks for new memory leaks if Purify is active. +%% Returns the number of bytes leaked, or false if Purify +%% is not running. +purify_new_leaks() -> +    case catch erlang:system_info({error_checker, memory}) of +	{'EXIT', _} -> false; +	Leaked when is_integer(Leaked) -> Leaked +    end. + +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +%% purify_new_fds_inuse() -> false|FdsInuse +%% FdsInuse = integer() +%% +%% Checks for new file descriptors in use. +%% Returns the number of new file descriptors in use, or false +%% if Purify is not running. +purify_new_fds_inuse() -> +    case catch erlang:system_info({error_checker, fd}) of +	{'EXIT', _} -> false; +	Inuse when is_integer(Inuse) -> Inuse +    end. + +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +%% purify_format(Format, Args) -> ok +%% Format = string() +%% Args = lists() +%% +%% Outputs the formatted string to Purify's logfile,if Purify is active. +purify_format(Format, Args) -> +    (catch erlang:system_info({error_checker, io_lib:format(Format, Args)})), +    ok. + + +  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  %%  %% Apply given function and reply to caller or proxy. diff --git a/lib/common_test/src/test_server_ctrl.erl b/lib/common_test/src/test_server_ctrl.erl index 9412c43187..48fe90a4d5 100644 --- a/lib/common_test/src/test_server_ctrl.erl +++ b/lib/common_test/src/test_server_ctrl.erl @@ -2163,6 +2163,7 @@ do_add_end_per_suite_and_skip(LastMod, LastRef, Mod, FwMod) ->  %% Runs the specified tests, then displays/logs the summary.  run_test_cases(TestSpec, Config, TimetrapData) -> +    test_server:init_purify(),      case lists:member(no_src, get(test_server_logopts)) of  	true ->  	    ok; @@ -3796,7 +3797,7 @@ run_test_case1(Ref, Num, Mod, Func, Args, RunInit,      %% run the test case      {Result,DetectedFail,ProcsBefore,ProcsAfter} = -	run_test_case_apply(Mod, Func, [UpdatedArgs], GrName, +	run_test_case_apply(Num, Mod, Func, [UpdatedArgs], GrName,  			    RunInit, TimetrapData),      {Time,RetVal,Loc,Opts,Comment} =  	case Result of @@ -4366,7 +4367,7 @@ do_format_exception(Reason={Error,Stack}) ->  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%% run_test_case_apply(Mod, Func, Args, Name, RunInit, +%% run_test_case_apply(CaseNum, Mod, Func, Args, Name, RunInit,  %%                     TimetrapData) ->  %%  {{Time,RetVal,Loc,Opts,Comment},DetectedFail,ProcessesBefore,ProcessesAfter} |  %%  {{died,Reason,unknown,Comment},DetectedFail,ProcessesBefore,ProcessesAfter} @@ -4380,9 +4381,9 @@ do_format_exception(Reason={Error,Stack}) ->  %% ProcessesBefore = ProcessesAfter = integer()  %% -run_test_case_apply(Mod, Func, Args, Name, RunInit, +run_test_case_apply(CaseNum, Mod, Func, Args, Name, RunInit,  		    TimetrapData) -> -    test_server:run_test_case_apply({Mod,Func,Args,Name,RunInit, +    test_server:run_test_case_apply({CaseNum,Mod,Func,Args,Name,RunInit,  				     TimetrapData}).  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% diff --git a/lib/stdlib/test/id_transform_SUITE.erl b/lib/stdlib/test/id_transform_SUITE.erl index 3d4ae1a189..54f452825f 100644 --- a/lib/stdlib/test/id_transform_SUITE.erl +++ b/lib/stdlib/test/id_transform_SUITE.erl @@ -61,8 +61,13 @@ id_transform(Config) when is_list(Config) ->  			"erl_id_trans.erl"]),      {ok,erl_id_trans,Bin} = compile:file(File,[binary]),      {module,erl_id_trans} = code:load_binary(erl_id_trans, File, Bin), -    ct:timetrap({hours,1}), -    run_in_test_suite(). +    case test_server:purify_is_running() of +	false -> +	    ct:timetrap({hours,1}), +	    run_in_test_suite(); +	true -> +	    {skip,"Valgrind (too slow)"} +    end.  run_in_test_suite() ->      SuperDir = filename:dirname(filename:dirname(code:which(?MODULE))), | 
