chore(rebar.config.erl): better release matrix support

This commit is contained in:
Zaiming Shi 2021-03-06 13:21:03 +01:00
parent 00a2daba19
commit 08aa022029
1 changed files with 24 additions and 30 deletions

View File

@ -102,17 +102,18 @@ test_compile_opts() ->
]. ].
profiles() -> profiles() ->
Vsn = get_vsn(),
[ {'emqx', [ {erl_opts, prod_compile_opts()} [ {'emqx', [ {erl_opts, prod_compile_opts()}
, {relx, relx('emqx')} , {relx, relx(Vsn, cloud, bin)}
]} ]}
, {'emqx-pkg', [ {erl_opts, prod_compile_opts()} , {'emqx-pkg', [ {erl_opts, prod_compile_opts()}
, {relx, relx('emqx-pkg')} , {relx, relx(Vsn, cloud, pkg)}
]} ]}
, {'emqx-edge', [ {erl_opts, prod_compile_opts()} , {'emqx-edge', [ {erl_opts, prod_compile_opts()}
, {relx, relx('emqx-edge')} , {relx, relx(Vsn, edge, bin)}
]} ]}
, {'emqx-edge-pkg', [ {erl_opts, prod_compile_opts()} , {'emqx-edge-pkg', [ {erl_opts, prod_compile_opts()}
, {relx, relx('emqx-edge-pkg')} , {relx, relx(Vsn, edge, pkg)}
]} ]}
, {check, [ {erl_opts, test_compile_opts()} , {check, [ {erl_opts, test_compile_opts()}
]} ]}
@ -121,41 +122,30 @@ profiles() ->
, {erl_opts, test_compile_opts() ++ erl_opts_i()} , {erl_opts, test_compile_opts() ++ erl_opts_i()}
, {extra_src_dirs, [{"test", [{recursive,true}]}]} , {extra_src_dirs, [{"test", [{recursive,true}]}]}
]} ]}
]. ] ++ ee_profiles(Vsn).
relx(Profile) -> %% RelType: cloud (full size) | edge (slim size)
Vsn = get_vsn(), %% PkgType: bin | pkg
relx(Vsn, RelType, PkgType) ->
[ {include_src,false} [ {include_src,false}
, {include_erts, true} , {include_erts, true}
, {extended_start_script,false} , {extended_start_script,false}
, {generate_start_script,false} , {generate_start_script,false}
, {sys_config,false} , {sys_config,false}
, {vm_args,false} , {vm_args,false}
] ++ do_relx(Profile, Vsn). , {release, {emqx, Vsn}, relx_apps(RelType)}
, {overlay, relx_overlay(RelType)}
do_relx('emqx', Vsn) -> , {overlay_vars, [ {built_on_arch, rebar_utils:get_arch()}
[ {release, {emqx, Vsn}, relx_apps(cloud)} , overlay_vars_rel(RelType)
, {overlay, relx_overlay(cloud)} , overlay_vars_pkg(PkgType)
, {overlay_vars, overlay_vars(["vars/vars-cloud.config","vars/vars-bin.config"])} ]}
];
do_relx('emqx-pkg', Vsn) ->
[ {release, {emqx, Vsn}, relx_apps(cloud)}
, {overlay, relx_overlay(cloud)}
, {overlay_vars, overlay_vars(["vars/vars-cloud.config","vars/vars-pkg.config"])}
];
do_relx('emqx-edge', Vsn) ->
[ {release, {emqx, Vsn}, relx_apps(edge)}
, {overlay, relx_overlay(edge)}
, {overlay_vars, overlay_vars(["vars/vars-edge.config","vars/vars-bin.config"])}
];
do_relx('emqx-edge-pkg', Vsn) ->
[ {release, {emqx, Vsn}, relx_apps(edge)}
, {overlay, relx_overlay(edge)}
, {overlay_vars, overlay_vars(["vars/vars-edge.config","vars/vars-pkg.config"])}
]. ].
overlay_vars(Files) -> overlay_vars_rel(cloud) -> "vars/vars-cloud.config";
[{built_on_arch, rebar_utils:get_arch()} | Files]. overlay_vars_rel(edge) -> "vars/vars-edge.config".
overlay_vars_pkg(bin) -> "vars/vars-bin.config";
overlay_vars_pkg(pkg) -> "vars/vars-pkg.config".
relx_apps(ReleaseType) -> relx_apps(ReleaseType) ->
[ kernel [ kernel
@ -400,3 +390,7 @@ coveralls() ->
list_dir(Dir) -> list_dir(Dir) ->
{ok, Names} = file:list_dir(Dir), {ok, Names} = file:list_dir(Dir),
[list_to_atom(Name) || Name <- Names, filelib:is_dir(filename:join([Dir, Name]))]. [list_to_atom(Name) || Name <- Names, filelib:is_dir(filename:join([Dir, Name]))].
%% ==== Enterprise supports below ==================================================================
ee_profiles(_Vsn) -> [].