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/bs_match_SUITE.erl | 35 | 
2 files changed, 51 insertions, 9 deletions
| diff --git a/lib/compiler/test/beam_validator_SUITE.erl b/lib/compiler/test/beam_validator_SUITE.erl index de5a3c2873..6b1438abdd 100644 --- a/lib/compiler/test/beam_validator_SUITE.erl +++ b/lib/compiler/test/beam_validator_SUITE.erl @@ -35,7 +35,7 @@  	 map_field_lists/1,cover_bin_opt/1,  	 val_dsetel/1,bad_tuples/1,bad_try_catch_nesting/1,           receive_stacked/1,aliased_types/1,type_conflict/1, -         infer_on_eq/1]). +         infer_on_eq/1,infer_dead_value/1]).  -include_lib("common_test/include/ct.hrl"). @@ -65,7 +65,7 @@ groups() ->         map_field_lists,cover_bin_opt,val_dsetel,         bad_tuples,bad_try_catch_nesting,         receive_stacked,aliased_types,type_conflict, -       infer_on_eq]}]. +       infer_on_eq,infer_dead_value]}].  init_per_suite(Config) ->      test_lib:recompile(?MODULE), @@ -679,6 +679,27 @@ infer_on_eq_4(T) ->      true = erlang:tuple_size(T) =:= 1,      {ok, erlang:element(1, T)}. +%% ERIERL-348; types were inferred for dead values, causing validation to fail. + +infer_dead_value(Config) when is_list(Config) -> +    a = idv_1({a, b, c, d, e, f, g}, {0, 0, 0, 0, 0, 0, 0}), +    b = idv_1({a, b, c, d, 0, 0, 0}, {a, b, c, d, 0, 0, 0}), +    c = idv_1({0, 0, 0, 0, 0, f, g}, {0, 0, 0, 0, 0, f, g}), +    error = idv_1(gurka, gaffel), +    ok. + +idv_1({_A, _B, _C, _D, _E, _F, _G}, +      {0, 0, 0, 0, 0, 0, 0}) -> +    a; +idv_1({A, B, C, D,_E, _F, _G}=_Tuple1, +      {A, B, C, D, 0, 0, 0}=_Tuple2) -> +    b; +idv_1({_A, _B, _C, _D, _E, F, G}, +      {0, 0, 0, 0, 0, F, G}) -> +    c; +idv_1(_A, _B) -> +    error. +  %%%-------------------------------------------------------------------------  transform_remove(Remove, Module) -> diff --git a/lib/compiler/test/bs_match_SUITE.erl b/lib/compiler/test/bs_match_SUITE.erl index 41e4918b1e..d97f49c56e 100644 --- a/lib/compiler/test/bs_match_SUITE.erl +++ b/lib/compiler/test/bs_match_SUITE.erl @@ -1891,15 +1891,37 @@ expression_before_match_1(R) ->  %% Make sure that context positions are updated on calls.  restore_on_call(Config) when is_list(Config) -> -    ok = restore_on_call_1(<<0, 1, 2>>). +    ok = restore_on_call_plain(<<0, 1, 2>>), +    <<"x">> = restore_on_call_match(<<0, "x">>), +    ok. -restore_on_call_1(<<0, Rest/binary>>) -> -    <<2>> = restore_on_call_2(Rest), -    <<2>> = restore_on_call_2(Rest), %% {badmatch, <<>>} on missing restore. +restore_on_call_plain(<<0, Rest/binary>>) -> +    <<2>> = restore_on_call_plain_1(Rest), +    %% {badmatch, <<>>} on missing restore. +    <<2>> = restore_on_call_plain_1(Rest),      ok. -restore_on_call_2(<<1, Rest/binary>>) -> Rest; -restore_on_call_2(Other) -> Other. +restore_on_call_plain_1(<<1, Rest/binary>>) -> Rest; +restore_on_call_plain_1(Other) -> Other. + +%% Calls a function that moves the match context passed to it, and then matches +%% on its result to confuse the reposition algorithm's success/fail logic. +restore_on_call_match(<<0, Bin/binary>>) -> +    case skip_until_zero(Bin) of +        {skipped, Rest} -> +            Rest; +        not_found -> +            %% The match context did not get repositioned before the +            %% bs_get_tail instruction here. +            Bin +    end. + +skip_until_zero(<<0,Rest/binary>>) -> +    {skipped, Rest}; +skip_until_zero(<<_C,Rest/binary>>) -> +    skip_until_zero(Rest); +skip_until_zero(_) -> +    not_found.  %% 'catch' must invalidate positions.  restore_after_catch(Config) when is_list(Config) -> @@ -1983,5 +2005,4 @@ do_matching_meets_apply(_Bin, {Handler, State}) ->      %% Another case of the above.      Handler:abs(State). -  id(I) -> I. | 
