mirror of
https://github.com/correl/rebar.git
synced 2024-11-23 19:19:54 +00:00
Ongoing reltool integration work; now better able to identify issues with missing apps in code path
This commit is contained in:
parent
33e53942d3
commit
89dc8095b0
1 changed files with 81 additions and 16 deletions
|
@ -28,6 +28,7 @@
|
||||||
clean/2]).
|
clean/2]).
|
||||||
|
|
||||||
-include("rebar.hrl").
|
-include("rebar.hrl").
|
||||||
|
-include_lib("reltool/src/reltool.hrl").
|
||||||
|
|
||||||
%% ===================================================================
|
%% ===================================================================
|
||||||
%% Public API
|
%% Public API
|
||||||
|
@ -35,15 +36,16 @@
|
||||||
|
|
||||||
generate(Config, ReltoolFile) ->
|
generate(Config, ReltoolFile) ->
|
||||||
%% Load the reltool configuration from the file
|
%% Load the reltool configuration from the file
|
||||||
case file:consult(ReltoolFile) of
|
ReltoolConfig = load_config(ReltoolFile),
|
||||||
{ok, [{sys, ReltoolConfig}]} ->
|
|
||||||
ok;
|
|
||||||
Other ->
|
|
||||||
ReltoolConfig = undefined,
|
|
||||||
?ERROR("Failed to load expected config from ~s: ~p\n", [ReltoolFile, Other]),
|
|
||||||
?FAIL
|
|
||||||
end,
|
|
||||||
|
|
||||||
|
%% Spin up reltool server and load our config into it
|
||||||
|
{ok, Server} = reltool:start_server([{sys, ReltoolConfig}]),
|
||||||
|
|
||||||
|
%% Do some validation of the reltool configuration; error messages out of
|
||||||
|
%% reltool are still pretty cryptic
|
||||||
|
validate_rel_apps(Server, ReltoolConfig),
|
||||||
|
|
||||||
|
%% Finally, run reltool
|
||||||
case catch(run_reltool(Config, ReltoolConfig)) of
|
case catch(run_reltool(Config, ReltoolConfig)) of
|
||||||
ok ->
|
ok ->
|
||||||
ok;
|
ok;
|
||||||
|
@ -56,7 +58,10 @@ generate(Config, ReltoolFile) ->
|
||||||
|
|
||||||
|
|
||||||
clean(Config, ReltoolFile) ->
|
clean(Config, ReltoolFile) ->
|
||||||
ok.
|
ReltoolConfig = load_config(ReltoolFile),
|
||||||
|
TargetDir = target_dir(Config, ReltoolConfig),
|
||||||
|
rebar_file_utils:rm_rf(TargetDir),
|
||||||
|
rebar_file_utils:delete_each(["reltool.spec"]).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -64,6 +69,17 @@ clean(Config, ReltoolFile) ->
|
||||||
%% Internal functions
|
%% Internal functions
|
||||||
%% ===================================================================
|
%% ===================================================================
|
||||||
|
|
||||||
|
load_config(ReltoolFile) ->
|
||||||
|
%% Load the reltool configuration from the file
|
||||||
|
case file:consult(ReltoolFile) of
|
||||||
|
{ok, [{sys, ReltoolConfig}]} ->
|
||||||
|
ReltoolConfig;
|
||||||
|
Other ->
|
||||||
|
?ERROR("Failed to load expected config from ~s: ~p\n", [ReltoolFile, Other]),
|
||||||
|
?FAIL
|
||||||
|
end.
|
||||||
|
|
||||||
|
|
||||||
%%
|
%%
|
||||||
%% Determine the name of the target directory; try the user provided name
|
%% Determine the name of the target directory; try the user provided name
|
||||||
%% first, or fall back to the release name if that's available. If neither
|
%% first, or fall back to the release name if that's available. If neither
|
||||||
|
@ -82,16 +98,65 @@ target_dir(Config, ReltoolConfig) ->
|
||||||
Name
|
Name
|
||||||
end.
|
end.
|
||||||
|
|
||||||
|
validate_rel_apps(ReltoolServer, ReltoolConfig) ->
|
||||||
|
case lists:keysearch(rel, 1, ReltoolConfig) of
|
||||||
|
{value, {rel, _Name, _Vsn, Apps}} ->
|
||||||
|
%% Identify all the apps that do NOT exist, based on what's available
|
||||||
|
%% from the reltool server
|
||||||
|
Missing = lists:sort([App || App <- Apps,
|
||||||
|
app_exists(App, ReltoolServer) == false]),
|
||||||
|
case Missing of
|
||||||
|
[] ->
|
||||||
|
ok;
|
||||||
|
_ ->
|
||||||
|
?ERROR("Apps in {rel, ...} section not found by reltool: ~p\n", [Missing]),
|
||||||
|
?FAIL
|
||||||
|
end;
|
||||||
|
{value, Rel} ->
|
||||||
|
%% Invalid release format!
|
||||||
|
?ERROR("Invalid {rel, ...} section in reltools.config: ~p\n", [Rel]),
|
||||||
|
?FAIL;
|
||||||
|
false ->
|
||||||
|
ok
|
||||||
|
end.
|
||||||
|
|
||||||
|
app_exists(App, Server) when is_atom(App) ->
|
||||||
|
case reltool_server:get_app(Server, App) of
|
||||||
|
{ok, _} ->
|
||||||
|
true;
|
||||||
|
_ ->
|
||||||
|
false
|
||||||
|
end;
|
||||||
|
app_exists(AppTuple, Server) when is_tuple(AppTuple) ->
|
||||||
|
app_exists(element(1, AppTuple), Server).
|
||||||
|
|
||||||
|
|
||||||
run_reltool(Config, ReltoolConfig) ->
|
run_reltool(Config, ReltoolConfig) ->
|
||||||
{ok, Server} = reltool:start_server([{sys, ReltoolConfig}]),
|
{ok, Server} = reltool:start_server([{sys, ReltoolConfig}]),
|
||||||
{ok, Spec} = reltool:get_target_spec(Server),
|
case reltool:get_target_spec(Server) of
|
||||||
TargetDir = target_dir(Config, ReltoolConfig),
|
{ok, Spec} ->
|
||||||
ok = file:make_dir(TargetDir),
|
dump_spec(Spec),
|
||||||
case reltool:eval_target_spec(Spec, code:root_dir(), TargetDir) of
|
TargetDir = target_dir(Config, ReltoolConfig),
|
||||||
ok ->
|
ok = file:make_dir(TargetDir),
|
||||||
ok;
|
case reltool:eval_target_spec(Spec, code:root_dir(), TargetDir) of
|
||||||
|
ok ->
|
||||||
|
ok;
|
||||||
|
{error, Reason} ->
|
||||||
|
?ERROR("Failed to generate target from spec: ~p\n", [Reason]),
|
||||||
|
?FAIL
|
||||||
|
end;
|
||||||
{error, Reason} ->
|
{error, Reason} ->
|
||||||
?ERROR("Failed to generate target from spec: ~p\n", [Reason]),
|
?ERROR("Unable to generate spec: ~s\n", [Reason]),
|
||||||
?FAIL
|
?FAIL
|
||||||
end.
|
end.
|
||||||
|
|
||||||
|
|
||||||
|
dump_spec(Spec) ->
|
||||||
|
case rebar_config:get_global(dump_spec, "0") of
|
||||||
|
"1" ->
|
||||||
|
SpecBin = list_to_binary(io_lib:print(Spec, 1, 120, -1)),
|
||||||
|
ok = file:write_file("reltool.spec", SpecBin);
|
||||||
|
_ ->
|
||||||
|
ok
|
||||||
|
end.
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue