Adding transitive deps test #1

This commit is contained in:
Dave Smith 2010-06-08 14:51:49 -06:00
parent a2f1b62d74
commit 1df2b6d41c
6 changed files with 61 additions and 0 deletions

4
inttest/tdeps1/a.erl Normal file
View file

@ -0,0 +1,4 @@
-module(a).
-include_lib("b/include/b.hrl").

View file

@ -0,0 +1,2 @@
{deps, [{b, "1", {hg, "../repo/b", "tip"}}]}.

3
inttest/tdeps1/b.hrl Normal file
View file

@ -0,0 +1,3 @@
-include_lib("c/include/c.hrl").

View file

@ -0,0 +1,2 @@
{deps, [{c, "1", {hg, "../repo/c", "tip"}}]}.

2
inttest/tdeps1/c.hrl Normal file
View file

@ -0,0 +1,2 @@
-define(HELLO, hello).

View file

@ -0,0 +1,48 @@
-module(tdeps1_rt).
-compile(export_all).
%% Exercise transitive dependencies
%% A -> B -> C, where A includes a .hrl from B which includes .hrl from C
files() ->
[
%% A application
{create, "ebin/a.app", app(a)},
{copy, "a.rebar.config", "rebar.config"},
{copy, "a.erl", "src/a.erl"},
{copy, "../../rebar", "rebar"},
%% B application
{create, "repo/b/ebin/b.app", app(b)},
{copy, "b.rebar.config", "repo/b/rebar.config"},
{copy, "b.hrl", "repo/b/include/b.hrl"},
%% C application
{create, "repo/c/ebin/c.app", app(c)},
{copy, "c.hrl", "repo/c/include/c.hrl"}
].
run(_Dir) ->
%% Initialize the b/c apps as mercurial repos so that dependencies pull
%% properly
HgCmd = "hg init && hg add && hg commit -m 'Initial commit'",
retest_log:log(debug, "~s\n", [os:cmd("(cd repo/b && " ++ HgCmd ++ ")")]),
retest_log:log(debug, "~s\n", [os:cmd("(cd repo/c && " ++ HgCmd ++ ")")]),
retest_log:log(debug, "~s\n", [os:cmd("./rebar get-deps compile")]),
ok.
%%
%% Generate the contents of a simple .app file
%%
app(Name) ->
App = {application, Name,
[{description, atom_to_list(Name)},
{vsn, "1"},
{modules, []},
{registered, []},
{applications, [kernel, stdlib]}]},
io_lib:format("~p.\n", [App]).