summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorTristan Sloughter <t@crashfast.com>2015-02-24 08:24:26 -0600
committerTristan Sloughter <t@crashfast.com>2015-02-24 18:07:01 -0600
commit235436a41090e45397e97c33cf0ef9d3413fc23c (patch)
tree36599dea2e020098b21b26937ad603552f57d1a2 /test
parentef83d4e82153bb4142c116286d1f96ffeff8676a (diff)
profiles: combine lists of values for conflicting config options
Diffstat (limited to 'test')
-rw-r--r--test/rebar_profiles_SUITE.erl22
-rw-r--r--test/rebar_xref_SUITE.erl2
2 files changed, 21 insertions, 3 deletions
diff --git a/test/rebar_profiles_SUITE.erl b/test/rebar_profiles_SUITE.erl
index 802b772..0b378cb 100644
--- a/test/rebar_profiles_SUITE.erl
+++ b/test/rebar_profiles_SUITE.erl
@@ -6,14 +6,15 @@
end_per_testcase/2,
all/0,
profile_new_key/1,
- profile_merge_keys/1]).
+ profile_merge_keys/1,
+ profile_merges/1]).
-include_lib("common_test/include/ct.hrl").
-include_lib("eunit/include/eunit.hrl").
-include_lib("kernel/include/file.hrl").
all() ->
- [profile_new_key, profile_merge_keys].
+ [profile_new_key, profile_merge_keys, profile_merges].
init_per_suite(Config) ->
application:start(meck),
@@ -80,3 +81,20 @@ profile_merge_keys(Config) ->
["as", "ct", "compile"], {ok, [{app, Name}
,{dep, "a", "1.0.0"}
,{dep, "b", "2.0.0"}]}).
+
+profile_merges(_Config) ->
+ RebarConfig = [{test1, [{key1, 1, 2}, key2]},
+ {test2, "hello"},
+ {profiles,
+ [{profile1,
+ [{test1, [{key3, 5}, key1]}]},
+ {profile2, [{test2, "goodbye"}]}]}],
+ State = rebar_state:new(RebarConfig),
+ State1 = rebar_state:apply_profiles(State, [profile1, profile2]),
+
+ %% Combine lists
+ ?assertEqual(lists:sort([key1, key2, {key1, 1, 2}, {key3, 5}]),
+ lists:sort(rebar_state:get(State1, test1))),
+
+ %% Use new value for strings
+ "goodbye" = rebar_state:get(State1, test2).
diff --git a/test/rebar_xref_SUITE.erl b/test/rebar_xref_SUITE.erl
index fde8c8f..067be07 100644
--- a/test/rebar_xref_SUITE.erl
+++ b/test/rebar_xref_SUITE.erl
@@ -57,7 +57,7 @@ end_per_testcase(_, Config) ->
%% we are about to remove the directory and there may be
%% subsequent test cases that error out when the code path tries
%% to include one of these soon-to-be nonexistent directories.
- true = code:del_path(AppDir ++ "/."),
+ code:del_path(AppDir ++ "/."),
true = code:del_path(rebar_dir:ebin_dir()),
file:set_cwd(OrigDir),
ec_file:remove(AppDir, [recursive]),