%% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*- %% ex: ts=4 sw=4 et %% ------------------------------------------------------------------- %% %% rebar: Erlang Build Tools %% %% Copyright (c) 2014 Tuncer Ayaz %% %% Permission is hereby granted, free of charge, to any person obtaining a copy %% of this software and associated documentation files (the "Software"), to deal %% in the Software without restriction, including without limitation the rights %% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell %% copies of the Software, and to permit persons to whom the Software is %% furnished to do so, subject to the following conditions: %% %% The above copyright notice and this permission notice shall be included in %% all copies or substantial portions of the Software. %% %% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR %% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, %% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE %% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER %% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, %% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN %% THE SOFTWARE. %% ------------------------------------------------------------------- -module(logging_rt). -export([files/0, run/1]). -define(APP_FILE, "ebin/logging.app"). files() -> [ {copy, "../../rebar", "rebar"}, {create, ?APP_FILE, app(invalid_name, [])} ]. run(_Dir) -> SharedExpected = "==> logging_rt \\(compile\\)", %% provoke ERROR due to an invalid app file retest:log(info, "Check 'compile' failure output~n"), {Error, Warn, Info, Debug} = case application:get_env(rebar, log_colored) of {ok, true} -> { "\\e\\[1m\\e\\[31mERROR: \\e\\[0m", "\\e\\[33mWARN: \\e\\[0m", "\\e\\[32mINFO: \\e\\[0m", "\\e\\[34mDEBUG: \\e\\[0m" }; _ -> { "ERROR: ", "WARN: ", "INFO: ", "DEBUG: " } end, ok = check_output("./rebar compile -q", should_fail, [SharedExpected, Error], [Warn, Info, Debug]), %% fix bad app file ok = file:write_file(?APP_FILE, app(logging, [])), retest:log(info, "Check 'compile' success output~n"), ok = check_output("./rebar compile", should_succeed, [SharedExpected], [Error, Warn, Info, Debug]), retest:log(info, "Check 'compile -v' success output~n"), ok = check_output("./rebar compile -v", should_succeed, [SharedExpected], [Error, Info, Debug]), retest:log(info, "Check 'compile -vv' success output~n"), ok = check_output("./rebar compile -vv", should_succeed, [SharedExpected, Debug], [Error, Info]), ok. check_output(Cmd, FailureMode, Expected, Unexpected) -> case {retest:sh(Cmd), FailureMode} of {{error, _}=Error, should_succeed} -> retest:log(error, "cmd '~s' failed:~n~p~n", [Cmd, Error]), Error; {{ok, Captured}, should_succeed} -> Joined = string:join(Captured, "\n"), check_output1(Cmd, Joined, Expected, Unexpected); {{error, {stopped, {_Rc, Captured}}}, should_fail} -> Joined = string:join(Captured, "\n"), check_output1(Cmd, Joined, Expected, Unexpected) end. check_output1(Cmd, Captured, Expected, Unexpected) -> ReOpts = [{capture, all, list}, unicode], ExMatches = lists:zf( fun(Pattern) -> case re:run(Captured, Pattern, ReOpts) of nomatch -> retest:log(error, "Expected pattern '~s' missing " "in the following output:~n" "=== BEGIN ===~n~s~n=== END ===~n", [Pattern, Captured]), {true, Pattern}; {match, _} -> false end end, Expected), UnExMatches = lists:zf( fun(Pattern) -> case re:run(Captured, Pattern, ReOpts) of nomatch -> false; {match, [Match]} -> retest:log( error, "Unexpected output when running cmd '~s':~n~s~n", [Cmd, Match]), {true, Match} end end, Unexpected), case {ExMatches, UnExMatches} of {[], []} -> ok; _ -> error end. %% %% Generate the contents of a simple .app file %% app(Name, Modules) -> App = {application, Name, [{description, atom_to_list(Name)}, {vsn, "1"}, {modules, Modules}, {registered, []}, {applications, [kernel, stdlib]}]}, io_lib:format("~p.\n", [App]).