diff options
Diffstat (limited to 'inttest/tdeps1/tdeps1_rt.erl')
-rw-r--r-- | inttest/tdeps1/tdeps1_rt.erl | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/inttest/tdeps1/tdeps1_rt.erl b/inttest/tdeps1/tdeps1_rt.erl new file mode 100644 index 0000000..8005741 --- /dev/null +++ b/inttest/tdeps1/tdeps1_rt.erl @@ -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]). |