diff options
Diffstat (limited to 'lib/compiler/test')
| -rw-r--r-- | lib/compiler/test/beam_validator_SUITE.erl | 25 | ||||
| -rw-r--r-- | lib/compiler/test/core_fold_SUITE.erl | 16 | 
2 files changed, 37 insertions, 4 deletions
| diff --git a/lib/compiler/test/beam_validator_SUITE.erl b/lib/compiler/test/beam_validator_SUITE.erl index 263fd2ca7e..ca85eef688 100644 --- a/lib/compiler/test/beam_validator_SUITE.erl +++ b/lib/compiler/test/beam_validator_SUITE.erl @@ -32,7 +32,8 @@  	 bad_bin_match/1,bad_dsetel/1,  	 state_after_fault_in_catch/1,no_exception_in_catch/1,  	 undef_label/1,illegal_instruction/1,failing_gc_guard_bif/1, -	 map_field_lists/1,cover_bin_opt/1]). +	 map_field_lists/1,cover_bin_opt/1, +	 val_dsetel/1]).  -include_lib("common_test/include/ct.hrl"). @@ -60,7 +61,7 @@ groups() ->         freg_state,bad_bin_match,bad_dsetel,         state_after_fault_in_catch,no_exception_in_catch,         undef_label,illegal_instruction,failing_gc_guard_bif, -       map_field_lists,cover_bin_opt]}]. +       map_field_lists,cover_bin_opt,val_dsetel]}].  init_per_suite(Config) ->      Config. @@ -546,3 +547,23 @@ beam_val(M) ->      _ = [io:put_chars(beam_validator:format_error(E)) ||  	    E <- Errors],      Errors. + +%%%------------------------------------------------------------------------- + +val_dsetel(_Config) -> +    self() ! 13, +    {'EXIT',{{try_clause,participating},_}} = (catch night(0)), +    ok. + +night(Turned) -> +    receive +	13 -> +	    try participating of engine -> 16 after false end +    end, +    %% The setelement/3 call is unreachable. +    Turned(setelement(#{true => Turned}, +		      participating(Turned, "suit", 40, []), +		      Turned < Turned)), +    ok. + +participating(_, _, _, _) -> ok. diff --git a/lib/compiler/test/core_fold_SUITE.erl b/lib/compiler/test/core_fold_SUITE.erl index 376d2c8e9a..ced0e39d06 100644 --- a/lib/compiler/test/core_fold_SUITE.erl +++ b/lib/compiler/test/core_fold_SUITE.erl @@ -26,7 +26,7 @@  	 unused_multiple_values_error/1,unused_multiple_values/1,  	 multiple_aliases/1,redundant_boolean_clauses/1,  	 mixed_matching_clauses/1,unnecessary_building/1, -	 no_no_file/1]). +	 no_no_file/1,configuration/1]).  -export([foo/0,foo/1,foo/2,foo/3]). @@ -45,7 +45,7 @@ groups() ->         unused_multiple_values_error,unused_multiple_values,         multiple_aliases,redundant_boolean_clauses,         mixed_matching_clauses,unnecessary_building, -       no_no_file]}]. +       no_no_file,configuration]}].  init_per_suite(Config) -> @@ -499,4 +499,16 @@ experiment() ->      end,      ok. + +%% Make sure we don't try to move a fun into a guard. +configuration(_Config) -> +    {'EXIT',_} = (catch configuration()), +    ok. + +configuration() -> +    [forgotten || Components <- enemy, is_tuple(fun art/0)]. + +art() -> + creating. +  id(I) -> I. | 
