diff options
author | Loïc Hoguin <[email protected]> | 2015-09-22 17:33:19 +0200 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2015-09-22 17:33:19 +0200 |
commit | 707c8656a12aff8104f627310271da8bee5efc9a (patch) | |
tree | 389c9164e2a2546aa33e49550b618bf821cae671 /test/core_deps.mk | |
parent | 6811c6505015fafdae3cb2d110fb1c2b8c39209f (diff) | |
download | erlang.mk-707c8656a12aff8104f627310271da8bee5efc9a.tar.gz erlang.mk-707c8656a12aff8104f627310271da8bee5efc9a.tar.bz2 erlang.mk-707c8656a12aff8104f627310271da8bee5efc9a.zip |
Add REL_DEPS along with its test
Diffstat (limited to 'test/core_deps.mk')
-rw-r--r-- | test/core_deps.mk | 70 |
1 files changed, 67 insertions, 3 deletions
diff --git a/test/core_deps.mk b/test/core_deps.mk index 5439563..0a90501 100644 --- a/test/core_deps.mk +++ b/test/core_deps.mk @@ -1,6 +1,6 @@ # Core: Packages and dependencies. -CORE_DEPS_CASES = build-c-8cc build-c-imagejs build-erl build-js doc otp pkg search +CORE_DEPS_CASES = build-c-8cc build-c-imagejs build-erl build-js doc otp pkg rel search CORE_DEPS_TARGETS = $(addprefix core-deps-,$(CORE_DEPS_CASES)) CORE_DEPS_CLEAN_TARGETS = $(addprefix clean-,$(CORE_DEPS_TARGETS)) @@ -145,8 +145,8 @@ EDOC_OPTS = {doclet, edown_doclet}\ $i "Build the application" $t $(MAKE) -C $(APP) $v - $i "Check that documentation dependencies were not fetched" - $t test ! -e $(APP)/deps/edown + $i "Check that no dependencies were fetched" + $t test ! -e $(APP)/deps $i "Check that the application was compiled correctly" $t $(ERL) -pa $(APP)/ebin/ $(APP)/deps/*/ebin/ -eval " \ @@ -225,6 +225,70 @@ endif true = lists:member(cowboy, Deps), \ halt()" +core-deps-rel: build clean-core-deps-rel + + $i "Bootstrap a new release-enabled OTP application named $(APP)" + $t mkdir $(APP)/ + $t cp ../erlang.mk $(APP)/ + $t $(MAKE) -C $(APP) -f erlang.mk bootstrap-lib bootstrap-rel $v + + $i "Add Recon to the list of dependencies" + $t sed -i.bak '2i\ +REL_DEPS = recon\ +' $(APP)/Makefile + + $i "Add Recon to the relx.config file" + $t $(ERL) -eval " \ + {ok, Conf0} = file:consult(\"$(APP)/relx.config\"), \ + Conf = lists:keyreplace(release, 1, Conf0, {release, {$(APP)_release, \"1\"}, [$(APP), recon]}), \ + ok = file:write_file(\"$(APP)/relx.config\", \ + lists:map(fun(Term) -> io_lib:format(\"~p.~n\", [Term]) end, Conf)), \ + halt()" + + $i "Build the application and its dependencies" + $t $(MAKE) -C $(APP) deps app $v + + $i "Check that no dependencies were fetched" + $t test ! -e $(APP)/deps + + $i "Check that the application was compiled correctly" + $t $(ERL) -pa $(APP)/ebin/ $(APP)/deps/*/ebin/ -eval " \ + [ok = application:load(App) || App <- [$(APP)]], \ + {ok, Deps} = application:get_key($(APP), applications), \ + false = lists:member(recon, Deps), \ + halt()" + + $i "Build the release" + $t $(MAKE) -C $(APP) $v + + $i "Check that all dependencies were fetched" + $t test -d $(APP)/deps/recon + + $i "Check that the application was compiled correctly" + $t $(ERL) -pa $(APP)/ebin/ $(APP)/deps/*/ebin/ -eval " \ + [ok = application:load(App) || App <- [$(APP)]], \ + {ok, Deps} = application:get_key($(APP), applications), \ + false = lists:member(recon, Deps), \ + halt()" + + $i "Start the release and check that Recon is loaded" +ifeq ($(PLATFORM),msys2) + $t $(APP)/_rel/$(APP)_release/bin/$(APP)_release.cmd install $v + $t $(APP)/_rel/$(APP)_release/bin/$(APP)_release.cmd start $v +else + $t $(APP)/_rel/$(APP)_release/bin/$(APP)_release start $v +endif + + $t test -n "`$(APP)/_rel/$(APP)_release/bin/$(APP)_release rpcterms \ + application loaded_applications | grep recon`" + +ifeq ($(PLATFORM),msys2) + $t $(APP)/_rel/$(APP)_release/bin/$(APP)_release.cmd stop $v + $t $(APP)/_rel/$(APP)_release/bin/$(APP)_release.cmd uninstall $v +else + $t $(APP)/_rel/$(APP)_release/bin/$(APP)_release stop $v +endif + core-deps-search: build clean-core-deps-search $i "Bootstrap a new OTP library named $(APP)" |