diff options
Diffstat (limited to 'lib/stdlib')
| -rw-r--r-- | lib/stdlib/src/erl_internal.erl | 2 | ||||
| -rw-r--r-- | lib/stdlib/src/otp_internal.erl | 6 | ||||
| -rw-r--r-- | lib/stdlib/src/supervisor.erl | 3 | ||||
| -rw-r--r-- | lib/stdlib/test/supervisor_1.erl | 6 | ||||
| -rw-r--r-- | lib/stdlib/test/supervisor_SUITE.erl | 93 | ||||
| -rw-r--r-- | lib/stdlib/vsn.mk | 2 | 
6 files changed, 108 insertions, 4 deletions
| diff --git a/lib/stdlib/src/erl_internal.erl b/lib/stdlib/src/erl_internal.erl index 478f05e792..0b9b8b8e17 100644 --- a/lib/stdlib/src/erl_internal.erl +++ b/lib/stdlib/src/erl_internal.erl @@ -263,7 +263,6 @@ bif(bit_size, 1) -> true;  bif(bitstring_to_list, 1) -> true;  bif(byte_size, 1) -> true;  bif(check_process_code, 2) -> true; -bif(concat_binary, 1) -> true;  bif(date, 0) -> true;  bif(delete_module, 1) -> true;  bif(demonitor, 1) -> true; @@ -405,7 +404,6 @@ old_bif(bit_size, 1) -> true;  old_bif(bitstring_to_list, 1) -> true;  old_bif(byte_size, 1) -> true;  old_bif(check_process_code, 2) -> true; -old_bif(concat_binary, 1) -> true;  old_bif(date, 0) -> true;  old_bif(delete_module, 1) -> true;  old_bif(disconnect_node, 1) -> true; diff --git a/lib/stdlib/src/otp_internal.erl b/lib/stdlib/src/otp_internal.erl index 39d017d430..db46670f61 100644 --- a/lib/stdlib/src/otp_internal.erl +++ b/lib/stdlib/src/otp_internal.erl @@ -449,7 +449,7 @@ obsolete_1(ssl_pkix, decode_cert, A) when A =:= 1; A =:= 2 ->  %% Added in R13B04.  obsolete_1(erlang, concat_binary, 1) -> -    {deprecated,{erlang,list_to_binary,1},"R15B"}; +    {removed,{erlang,list_to_binary,1},"R15B"};  %% Added in R14A.  obsolete_1(ssl, peercert, 2) -> @@ -461,6 +461,10 @@ obsolete_1(public_key, pem_to_der, 1) ->  obsolete_1(public_key, decode_private_key, A) when A =:= 1; A =:= 2 ->      {deprecated,{public_key,pem_entry_decode,1},"R15A"}; +%% Added in R15B +obsolete_1(asn1rt, F, _) when F == load_driver; F == unload_driver -> +    {deprecated,"deprecated (will be removed in R16A); has no effect as drivers are no longer used."}; +  obsolete_1(_, _, _) ->      no. diff --git a/lib/stdlib/src/supervisor.erl b/lib/stdlib/src/supervisor.erl index e60706ed05..023183c5f0 100644 --- a/lib/stdlib/src/supervisor.erl +++ b/lib/stdlib/src/supervisor.erl @@ -661,6 +661,9 @@ do_restart(_, normal, Child, State) ->  do_restart(_, shutdown, Child, State) ->      NState = state_del_child(Child, State),      {ok, NState}; +do_restart(_, {shutdown, _Term}, Child, State) -> +    NState = state_del_child(Child, State), +    {ok, NState};  do_restart(transient, Reason, Child, State) ->      report_error(child_terminated, Reason, Child, State#state.name),      restart(Child, State); diff --git a/lib/stdlib/test/supervisor_1.erl b/lib/stdlib/test/supervisor_1.erl index 3198be0fed..f819594c46 100644 --- a/lib/stdlib/test/supervisor_1.erl +++ b/lib/stdlib/test/supervisor_1.erl @@ -62,6 +62,12 @@ handle_info(die, State) ->  handle_info(stop, State) ->      {stop, normal, State}; +handle_info({'EXIT',_,shutdown}, State) -> +    {stop, shutdown, State}; + +handle_info({'EXIT',_,{shutdown,Term}}, State) -> +    {stop, {shutdown,Term}, State}; +  handle_info({sleep, Time}, State) ->      io:format("FOO: ~p~n", [Time]),      timer:sleep(Time), diff --git a/lib/stdlib/test/supervisor_SUITE.erl b/lib/stdlib/test/supervisor_SUITE.erl index ff5e4c629a..7a75114cb6 100644 --- a/lib/stdlib/test/supervisor_SUITE.erl +++ b/lib/stdlib/test/supervisor_SUITE.erl @@ -41,6 +41,8 @@  %% Tests concept permanent, transient and temporary   -export([ permanent_normal/1, transient_normal/1,  	  temporary_normal/1, +	  permanent_shutdown/1, transient_shutdown/1, +	  temporary_shutdown/1,  	  permanent_abnormal/1, transient_abnormal/1,  	  temporary_abnormal/1]). @@ -71,6 +73,7 @@ all() ->       {group, restart_simple_one_for_one},       {group, restart_rest_for_one},       {group, normal_termination}, +     {group, shutdown_termination},       {group, abnormal_termination}, child_unlink, tree,       count_children_memory, do_not_save_start_parameters_for_temporary_children,       do_not_save_child_specs_for_temporary_children, @@ -86,6 +89,8 @@ groups() ->         sup_stop_brutal_kill]},       {normal_termination, [],        [permanent_normal, transient_normal, temporary_normal]}, +     {shutdown_termination, [], +      [permanent_shutdown, transient_shutdown, temporary_shutdown]},       {abnormal_termination, [],        [permanent_abnormal, transient_abnormal,         temporary_abnormal]}, @@ -549,6 +554,87 @@ temporary_normal(Config) when is_list(Config) ->      [0,0,0,0] = get_child_counts(sup_test).  %%------------------------------------------------------------------------- +permanent_shutdown(doc) -> +    ["A permanent child should always be restarted"]; +permanent_shutdown(suite) -> []; +permanent_shutdown(Config) when is_list(Config) -> +    {ok, SupPid} = start_link({ok, {{one_for_one, 2, 3600}, []}}), +    Child1 = {child1, {supervisor_1, start_child, []}, permanent, 1000, +	      worker, []}, + +    {ok, CPid1} = supervisor:start_child(sup_test, Child1), + +    terminate(SupPid, CPid1, child1, shutdown), + +    [{child1, CPid2 ,worker,[]}] = supervisor:which_children(sup_test), +    case is_pid(CPid2) of +	true -> +	    ok; +	false -> +	    test_server:fail({permanent_child_not_restarted, Child1}) +    end, +    [1,1,0,1] = get_child_counts(sup_test), + +    terminate(SupPid, CPid2, child1, {shutdown, some_info}), + +    [{child1, CPid3 ,worker,[]}] = supervisor:which_children(sup_test), +    case is_pid(CPid3) of +	true -> +	    ok; +	false -> +	    test_server:fail({permanent_child_not_restarted, Child1}) +    end, + +    [1,1,0,1] = get_child_counts(sup_test). + +%%------------------------------------------------------------------------- +transient_shutdown(doc) -> +    ["A transient child should not be restarted if it exits with "  +     "reason shutdown or {shutdown,Term}"]; +transient_shutdown(suite) -> []; +transient_shutdown(Config) when is_list(Config) -> +    {ok, SupPid} = start_link({ok, {{one_for_one, 2, 3600}, []}}), +    Child1 = {child1, {supervisor_1, start_child, []}, transient, 1000, +	      worker, []}, + +    {ok, CPid1} = supervisor:start_child(sup_test, Child1), + +    terminate(SupPid, CPid1, child1, shutdown), + +    [{child1,undefined,worker,[]}] = supervisor:which_children(sup_test), +    [1,0,0,1] = get_child_counts(sup_test), + +    {ok, CPid2} = supervisor:restart_child(sup_test, child1), + +    terminate(SupPid, CPid2, child1, {shutdown, some_info}), + +    [{child1,undefined,worker,[]}] = supervisor:which_children(sup_test), +    [1,0,0,1] = get_child_counts(sup_test). + +%%------------------------------------------------------------------------- +temporary_shutdown(doc) -> +    ["A temporary process should never be restarted"]; +temporary_shutdown(suite) -> []; +temporary_shutdown(Config) when is_list(Config) -> +    {ok, SupPid} = start_link({ok, {{one_for_one, 2, 3600}, []}}), +    Child1 = {child1, {supervisor_1, start_child, []}, temporary, 1000, +	      worker, []}, + +    {ok, CPid1} = supervisor:start_child(sup_test, Child1), + +    terminate(SupPid, CPid1, child1, shutdown), + +    [] = supervisor:which_children(sup_test), +    [0,0,0,0] = get_child_counts(sup_test), + +    {ok, CPid2} = supervisor:start_child(sup_test, Child1), + +    terminate(SupPid, CPid2, child1, {shutdown, some_info}), + +    [] = supervisor:which_children(sup_test), +    [0,0,0,0] = get_child_counts(sup_test). + +%%-------------------------------------------------------------------------  permanent_abnormal(doc) ->      ["A permanent child should always be restarted"];  permanent_abnormal(suite) -> []; @@ -1251,6 +1337,13 @@ terminate(_, ChildPid, _, shutdown) ->  	{'DOWN', Ref, process, ChildPid, shutdown} ->  	    ok      end; +terminate(_, ChildPid, _, {shutdown, Term}) -> +    Ref = erlang:monitor(process, ChildPid), +    exit(ChildPid, {shutdown, Term}), +    receive +	{'DOWN', Ref, process, ChildPid, {shutdown, Term}} -> +	    ok +    end;  terminate(_, ChildPid, _, normal) ->      Ref = erlang:monitor(process, ChildPid),      ChildPid ! stop, diff --git a/lib/stdlib/vsn.mk b/lib/stdlib/vsn.mk index 9d4ed17774..2f0ecd3863 100644 --- a/lib/stdlib/vsn.mk +++ b/lib/stdlib/vsn.mk @@ -1 +1 @@ -STDLIB_VSN = 1.17.5 +STDLIB_VSN = 1.18 | 
