From dda1901dc7077ac4cf18d4d78b9e0cd548c85837 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= Date: Thu, 24 Sep 2015 14:47:08 +0200 Subject: Add tests for dependency fetching order --- test/core_deps.mk | 88 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 87 insertions(+), 1 deletion(-) (limited to 'test') diff --git a/test/core_deps.mk b/test/core_deps.mk index 23d899d..bac2cf7 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 dep-commit doc fetch-cp fetch-custom fetch-fail-bad fetch-fail-unknown fetch-git fetch-hex fetch-hg fetch-legacy fetch-svn otp pkg rel search shell test +CORE_DEPS_CASES = build-c-8cc build-c-imagejs build-erl build-js dep-commit doc fetch-cp fetch-custom fetch-fail-bad fetch-fail-unknown fetch-git fetch-hex fetch-hg fetch-legacy fetch-svn order-first order-top otp pkg rel search shell test CORE_DEPS_TARGETS = $(addprefix core-deps-,$(CORE_DEPS_CASES)) CORE_DEPS_CLEAN_TARGETS = $(addprefix clean-,$(CORE_DEPS_TARGETS)) @@ -457,6 +457,92 @@ endif {ok, \"1.0.0\"} = application:get_key(cowlib, vsn), \ halt()" +# A lower-level dependency of the first dependency always +# wins over a lower-level dependency of the second dependency. +core-deps-order-first: build clean-core-deps-order-first + + $i "Bootstrap a new OTP library named $(APP)" + $t mkdir $(APP)/ + $t cp ../erlang.mk $(APP)/ + $t $(MAKE) -C $(APP) -f erlang.mk bootstrap-lib $v + + $i "Bootstrap a new OTP library named my_dep inside $(APP)" + $t mkdir $(APP)/my_dep + $t cp ../erlang.mk $(APP)/my_dep/ + $t $(MAKE) -C $(APP)/my_dep/ -f erlang.mk bootstrap-lib $v + + $i "Add Cowlib 1.0.0 to the list of dependencies for my_dep" + $t sed -i.bak '2i\ +DEPS = cowlib\ +dep_cowlib = git https://github.com/ninenines/cowlib 1.0.0\ +' $(APP)/my_dep/Makefile + + $i "Add Cowboy package and my_dep to the list of dependencies" + $t sed -i.bak '2i\ +DEPS = my_dep cowboy\ +dep_my_dep = cp $(CURDIR)/$(APP)/my_dep/\ +' $(APP)/Makefile + +ifdef LEGACY + $i "Add Cowboy and my_dep to the applications key in the .app.src file" + $t sed -i.bak '8i\ + cowboy,\ + my_dep,' $(APP)/src/$(APP).app.src +endif + + $i "Build the application" + $t $(MAKE) -C $(APP) $v + + $i "Check that all dependencies were fetched" + $t test -d $(APP)/deps/cowboy + $t test -d $(APP)/deps/cowlib + $t test -d $(APP)/deps/my_dep + $t test -d $(APP)/deps/ranch + + $i "Check that the application was compiled correctly" + $t $(ERL) -pa $(APP)/ebin/ $(APP)/deps/*/ebin/ -eval " \ + [ok = application:load(App) || App <- [$(APP), cowboy, cowlib, my_dep, ranch]], \ + {ok, Deps} = application:get_key($(APP), applications), \ + true = lists:member(cowboy, Deps), \ + {ok, \"1.0.0\"} = application:get_key(cowlib, vsn), \ + halt()" + +# A higher-level dependency always wins. +core-deps-order-top: build clean-core-deps-order-top + + $i "Bootstrap a new OTP library named $(APP)" + $t mkdir $(APP)/ + $t cp ../erlang.mk $(APP)/ + $t $(MAKE) -C $(APP) -f erlang.mk bootstrap-lib $v + + $i "Add Cowboy package and Cowlib 1.0.0 to the list of dependencies" + $t sed -i.bak '2i\ +DEPS = cowboy cowlib\ +dep_cowlib = git https://github.com/ninenines/cowlib 1.0.0\ +' $(APP)/Makefile + +ifdef LEGACY + $i "Add Cowboy to the applications key in the .app.src file" + $t sed -i.bak '8i\ + cowboy,' $(APP)/src/$(APP).app.src +endif + + $i "Build the application" + $t $(MAKE) -C $(APP) $v + + $i "Check that all dependencies were fetched" + $t test -d $(APP)/deps/cowboy + $t test -d $(APP)/deps/cowlib + $t test -d $(APP)/deps/ranch + + $i "Check that the application was compiled correctly" + $t $(ERL) -pa $(APP)/ebin/ $(APP)/deps/*/ebin/ -eval " \ + [ok = application:load(App) || App <- [$(APP), cowboy, cowlib, ranch]], \ + {ok, Deps} = application:get_key($(APP), applications), \ + true = lists:member(cowboy, Deps), \ + {ok, \"1.0.0\"} = application:get_key(cowlib, vsn), \ + halt()" + ifndef LEGACY core-deps-otp: build clean-core-deps-otp -- cgit v1.2.3