瀏覽代碼

merge overlay entries into a single {overlay, list()} for relx

pull/1009/head
Tristan Sloughter 9 年之前
父節點
當前提交
fe7b4aa3ed
共有 2 個檔案被更改,包括 34 行新增2 行删除
  1. +11
    -1
      src/rebar_relx.erl
  2. +23
    -1
      test/rebar_release_SUITE.erl

+ 11
- 1
src/rebar_relx.erl 查看文件

@ -30,8 +30,9 @@ do(Module, Command, Provider, State) ->
relx:main([{lib_dirs, LibDirs}
,{caller, api} | output_dir(OutputDir, Options)], AllOptions);
Config ->
Config1 = merge_overlays(Config),
relx:main([{lib_dirs, LibDirs}
,{config, Config}
,{config, Config1}
,{caller, api} | output_dir(OutputDir, Options)], AllOptions)
end,
rebar_hooks:run_all_hooks(Cwd, post, Provider, Providers, State),
@ -49,3 +50,12 @@ format_error(Reason) ->
output_dir(OutputDir, Options) ->
[{output_dir, OutputDir} || not(lists:member("-o", Options))
andalso not(lists:member("--output-dir", Options))].
merge_overlays(Config) ->
{Overlays, Others} =
lists:partition(fun(C) when element(1, C) =:= overlay -> true;
(_) -> false
end, Config),
%% Have profile overlay entries come before others to match how profiles work elsewhere
NewOverlay = lists:reverse(lists:flatmap(fun({overlay, Overlay}) -> Overlay end, Overlays)),
[{overlay, NewOverlay} | Others].

+ 23
- 1
test/rebar_release_SUITE.erl 查看文件

@ -10,7 +10,7 @@ all() -> [release,
profile_ordering_sys_config_extend,
profile_ordering_sys_config_extend_3_tuple_merge,
extend_release,
user_output_dir].
user_output_dir, profile_overlays].
init_per_testcase(Case, Config0) ->
Config = rebar_test_utils:init_rebar_state(Config0),
@ -193,3 +193,25 @@ user_output_dir(Config) ->
{ok, RelxState2} = rlx_prv_app_discover:do(RelxState1),
{ok, RelxState3} = rlx_prv_rel_discover:do(RelxState2),
rlx_state:get_realized_release(RelxState3, list_to_atom(Name), Vsn).
profile_overlays(Config) ->
AppDir = ?config(apps, Config),
Name = ?config(name, Config),
Vsn = "1.0.0",
{ok, RebarConfig} =
file:consult(rebar_test_utils:create_config(AppDir,
[{relx, [{release, {list_to_atom(Name), Vsn},
[list_to_atom(Name)]},
{overlay, [{mkdir, "randomdir"}]},
{lib_dirs, [AppDir]}]},
{profiles, [{prod, [{relx, [{overlay, [{mkdir, "otherrandomdir"}]}]}]}]}])),
ReleaseDir = filename:join([AppDir, "./_build/prod/rel/", Name]),
rebar_test_utils:run_and_check(
Config, RebarConfig,
["as", "prod", "release"],
{ok, [{release, list_to_atom(Name), Vsn, false},
{dir, filename:join(ReleaseDir, "otherrandomdir")},
{dir, filename:join(ReleaseDir, "randomdir")}]}
).

Loading…
取消
儲存