summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/rebar_erlc_compiler.erl6
-rw-r--r--src/rebar_prv_common_test.erl43
2 files changed, 39 insertions, 10 deletions
diff --git a/src/rebar_erlc_compiler.erl b/src/rebar_erlc_compiler.erl
index 14e6349..330f20b 100644
--- a/src/rebar_erlc_compiler.erl
+++ b/src/rebar_erlc_compiler.erl
@@ -265,9 +265,11 @@ opts_changed(Opts, Target) ->
case code:load_abs(ObjectFile) of
{module, Mod} ->
Compile = Mod:module_info(compile),
+ %% dialyzer and eunit have trouble without the next two lines
+ code:delete(Mod),
+ code:purge(Mod),
lists:sort(Opts) =/= lists:sort(proplists:get_value(options,
- Compile,
- undefined));
+ Compile));
{error, nofile} -> true
end.
diff --git a/src/rebar_prv_common_test.erl b/src/rebar_prv_common_test.erl
index 5de1618..b697d37 100644
--- a/src/rebar_prv_common_test.erl
+++ b/src/rebar_prv_common_test.erl
@@ -55,7 +55,8 @@ do(State) ->
Path = code:get_path(),
true = code:add_patha(OutDir),
CTOpts = resolve_ct_opts(State, Opts, OutDir),
- Result = handle_results(ct:run_test(CTOpts)),
+ Verbose = proplists:get_value(verbose, Opts, false),
+ Result = run_test(CTOpts, Verbose),
true = code:set_path(Path),
case Result of
{error, Reason} ->
@@ -70,6 +71,19 @@ format_error({failures_running_tests, FailedCount}) ->
format_error({error_running_tests, Reason}) ->
io_lib:format("Error running tests: ~p", [Reason]).
+run_test(CTOpts, true) ->
+ handle_results(ct:run_test(CTOpts));
+run_test(CTOpts, false) ->
+ Pid = self(),
+ LogDir = proplists:get_value(logdir, CTOpts),
+ erlang:spawn_monitor(fun() ->
+ {ok, F} = file:open(filename:join([LogDir, "ct.latest.log"]),
+ [write]),
+ true = group_leader(F, self()),
+ Pid ! ct:run_test(CTOpts)
+ end),
+ receive Result -> handle_quiet_results(CTOpts, Result) end.
+
ct_opts(State) ->
DefaultLogsDir = filename:join([rebar_state:dir(State), "logs"]),
[{dir, undefined, "dir", string, help(dir)}, %% comma-seperated list
@@ -104,7 +118,8 @@ ct_opts(State) ->
{until, undefined, "until", string, help(until)}, %% format: YYMoMoDD[HHMMSS]
{force_stop, undefined, "force_stop", string, help(force_stop)}, % enum: skip_rest, bool
{basic_html, undefined, "basic_html", boolean, help(basic_html)}, %% Booloean
- {ct_hooks, undefined, "ct_hooks", string, help(ct_hooks)} %% List: [CTHModule | {CTHModule, CTHInitArgs}] where CTHModule is atom CthInitArgs is term
+ {ct_hooks, undefined, "ct_hooks", string, help(ct_hooks)}, %% List: [CTHModule | {CTHModule, CTHInitArgs}] where CTHModule is atom CthInitArgs is term
+ {verbose, $v, "verbose", boolean, help(verbose)}
].
help(outdir) ->
@@ -166,7 +181,9 @@ help(basic_html) ->
help(ct_hooks) ->
"";
help(userconfig) ->
- "".
+ "";
+help(verbose) ->
+ "Verbose output".
split_ct_dirs(State, RawOpts) ->
%% preserve the override nature of command line opts by only checking
@@ -339,9 +356,19 @@ handle_results([Result|Results]) when is_list(Results) ->
Error ->
Error
end;
-handle_results({_, 0, _}) ->
- ok;
-handle_results({_, FailedCount, _}) ->
- {error, {failures_running_tests, FailedCount}};
handle_results({error, Reason}) ->
- {error, {error_running_tests, Reason}}.
+ {error, {error_running_tests, Reason}};
+handle_results(_) -> ok.
+
+handle_quiet_results(_, {Passed, 0, {0, 0}}) ->
+ io:format(" All ~p tests passed.~n", [Passed]);
+handle_quiet_results(_, {Passed, 0, {UserSkipped, AutoSkipped}}) ->
+ io:format(" All ~p tests passed. Skipped ~p tests.~n",
+ [Passed, UserSkipped + AutoSkipped]);
+handle_quiet_results(CTOpts, {_, Failed, _}) ->
+ LogDir = proplists:get_value(logdir, CTOpts),
+ Index = filename:join([LogDir, "index.html"]),
+ io:format(" ~p tests failed.~n Results written to ~p.~n", [Failed, Index]);
+handle_quiet_results(_CTOpts, {'DOWN', _, _, _, Reason}) ->
+ handle_results({error, Reason});
+handle_quiet_results(_CTOpts, Result) -> handle_results(Result).