summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorTristan Sloughter <tristan.sloughter@gmail.com>2014-12-21 14:30:00 -0600
committerTristan Sloughter <tristan.sloughter@gmail.com>2014-12-21 14:30:00 -0600
commit3aeb76c10b7f9311b4070d473f39032996170145 (patch)
tree3cdd87e1e733d8e0b87f99456b90b3c58872d473 /test
parent2f5d54aacb7d7183de4e04c184d26dc1ac709368 (diff)
parent54a41ca6c4fb819aa5adf4883f51d0c785a56be3 (diff)
Merge pull request #70 from rebar/provider-namespaces
Provider namespaces
Diffstat (limited to 'test')
-rw-r--r--test/rebar_compile_SUITE.erl2
-rw-r--r--test/rebar_deps_SUITE.erl2
-rw-r--r--test/rebar_namespace_SUITE.erl93
3 files changed, 95 insertions, 2 deletions
diff --git a/test/rebar_compile_SUITE.erl b/test/rebar_compile_SUITE.erl
index 83b868d..03f9c1f 100644
--- a/test/rebar_compile_SUITE.erl
+++ b/test/rebar_compile_SUITE.erl
@@ -33,5 +33,5 @@ build_basic_app(Config) ->
Vsn = rebar_test_utils:create_random_vsn(),
rebar_test_utils:create_app(AppDir, Name, Vsn, [kernel, stdlib]),
- rebar_test_utils:run_and_check(Config, [], "compile", {ok, [{app, Name}]}).
+ rebar_test_utils:run_and_check(Config, [], ["compile"], {ok, [{app, Name}]}).
diff --git a/test/rebar_deps_SUITE.erl b/test/rebar_deps_SUITE.erl
index c6f24c0..d67efe4 100644
--- a/test/rebar_deps_SUITE.erl
+++ b/test/rebar_deps_SUITE.erl
@@ -195,7 +195,7 @@ circular_skip(Config) -> run(Config).
run(Config) ->
{ok, RebarConfig} = file:consult(?config(rebarconfig, Config)),
rebar_test_utils:run_and_check(
- Config, RebarConfig, "install_deps", ?config(expect, Config)
+ Config, RebarConfig, ["install_deps"], ?config(expect, Config)
),
check_warnings(warning_calls(), ?config(warnings, Config), ?config(deps_type, Config)).
diff --git a/test/rebar_namespace_SUITE.erl b/test/rebar_namespace_SUITE.erl
new file mode 100644
index 0000000..40b7238
--- /dev/null
+++ b/test/rebar_namespace_SUITE.erl
@@ -0,0 +1,93 @@
+-module(rebar_namespace_SUITE).
+-compile(export_all).
+-include_lib("common_test/include/ct.hrl").
+-include_lib("eunit/include/eunit.hrl").
+
+all() -> [implicit_compile, default_compile, do_compile,
+ as_default_compile, as_do_compile,
+ notfound, do_notfound, default_notfound, ns_notfound].
+
+init_per_testcase(Case, Config0) ->
+ Config = rebar_test_utils:init_rebar_state(Config0),
+ AppDir = ?config(apps, Config),
+ Name = rebar_test_utils:create_random_name("app1_"++atom_to_list(Case)),
+ Vsn = rebar_test_utils:create_random_vsn(),
+ rebar_test_utils:create_app(AppDir, Name, Vsn, [kernel, stdlib]),
+ [{name, Name} | Config].
+
+end_per_testcase(_, Config) ->
+ Config.
+
+implicit_compile(Config) ->
+ Name = ?config(name, Config),
+ rebar_test_utils:run_and_check(Config, [],
+ ["compile"],
+ {ok, [{app, Name}]}).
+
+default_compile(Config) ->
+ Name = ?config(name, Config),
+ rebar_test_utils:run_and_check(Config, [],
+ ["default","compile"],
+ {ok, [{app, Name}]}).
+
+do_compile(Config) ->
+ Name = ?config(name, Config),
+ rebar_test_utils:run_and_check(Config, [],
+ ["do", "compile"],
+ {ok, [{app, Name}]}).
+
+as_default_compile(Config) ->
+ Name = ?config(name, Config),
+ rebar_test_utils:run_and_check(Config, [],
+ ["as", "prod", "default", "compile"],
+ {ok, [{app, Name}]}).
+
+as_do_compile(Config) ->
+ Name = ?config(name, Config),
+ rebar_test_utils:run_and_check(Config, [],
+ ["as", "prod", "do", "compile"],
+ {ok, [{app, Name}]}).
+
+notfound(Config) ->
+ Command = ["fakecommand"],
+ rebar_test_utils:run_and_check(
+ Config, [], Command,
+ {error, io_lib:format("Command ~p not found", [fakecommand])}
+ ).
+
+do_notfound(Config) ->
+ Command = ["do", "fakecommand"],
+ rebar_test_utils:run_and_check(
+ Config, [], Command,
+ {error, io_lib:format("Command ~p not found", [fakecommand])}
+ ).
+
+default_notfound(Config) ->
+ Command = ["default", "fakecommand"],
+ rebar_test_utils:run_and_check(
+ Config, [], Command,
+ {error, io_lib:format("Command ~p not found", [fakecommand])}
+ ).
+
+ns_notfound(Config) ->
+ Command = ["ns", "fakecommand"],
+ rebar_test_utils:run_and_check(
+ add_fake_ns_provider(Config), [], Command,
+ {error, io_lib:format("Command ~p not found in namespace ~p",
+ [fakecommand, ns])}
+ ).
+
+%%% Helpers %%%
+add_fake_ns_provider(Config) ->
+ State = ?config(state, Config),
+ State1 = rebar_state:add_provider(
+ State,
+ providers:create(
+ [{name, fake_provider},
+ {module, fake_provider},
+ {namespace, ns},
+ {deps, []},
+ {opts, []}]
+ )
+ ),
+ [{state, State1} | Config].