aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/core_compat.mk56
1 files changed, 54 insertions, 2 deletions
diff --git a/test/core_compat.mk b/test/core_compat.mk
index 04921b2..93178d3 100644
--- a/test/core_compat.mk
+++ b/test/core_compat.mk
@@ -6,6 +6,8 @@ CORE_COMPAT_CASES = auto-rebar rebar rebar-deps rebar-deps-pkg rebar-erlc-opts
CORE_COMPAT_TARGETS = $(addprefix core-compat-,$(CORE_COMPAT_CASES))
CORE_COMPAT_CLEAN_TARGETS = $(addprefix clean-,$(CORE_COMPAT_TARGETS))
+REBAR_BINARY = https://github.com/rebar/rebar/releases/download/2.6.0/rebar
+
.PHONY: core-compat $(CORE_COMPAT_TARGETS) clean-core-compat $(CORE_COMPAT_CLEAN_TARGETS)
clean-core-compat: $(CORE_COMPAT_CLEAN_TARGETS)
@@ -49,6 +51,16 @@ core-compat-auto-rebar: build clean-core-compat-auto-rebar
$i "Check that rebar.config can be loaded"
$t $(ERL) -eval "{ok, _} = file:consult(\"$(APP)/rebar.config\"), halt()"
+ $i "Distclean the application"
+ $t $(MAKE) -C $(APP) distclean $v
+
+ $i "Download rebar"
+ $t curl -s -L -o $(APP)/rebar $(REBAR_BINARY)
+ $t chmod +x $(APP)/rebar
+
+ $i "Use rebar to build the application"
+ $t cd $(APP) && ./rebar compile $v
+
core-compat-rebar: build clean-core-compat-rebar
$i "Bootstrap a new OTP library named $(APP)"
@@ -80,6 +92,16 @@ core-compat-rebar: build clean-core-compat-rebar
$i "Check that rebar.config can be loaded"
$t $(ERL) -eval "{ok, _} = file:consult(\"$(APP)/rebar.config\"), halt()"
+ $i "Distclean the application"
+ $t $(MAKE) -C $(APP) distclean $v
+
+ $i "Download rebar"
+ $t curl -s -L -o $(APP)/rebar $(REBAR_BINARY)
+ $t chmod +x $(APP)/rebar
+
+ $i "Use rebar to build the application"
+ $t cd $(APP) && ./rebar compile $v
+
core-compat-rebar-deps: build clean-core-compat-rebar-deps
$i "Bootstrap a new OTP library named $(APP)"
@@ -90,7 +112,7 @@ core-compat-rebar-deps: build clean-core-compat-rebar-deps
$i "Add Cowboy as a dependency"
$t sed -i.bak '2i\
DEPS = cowboy\
-dep_cowboy = git repo commit\
+dep_cowboy = git https://github.com/ninenines/cowboy master\
' $(APP)/Makefile
$i "Run 'make rebar.config'"
@@ -102,9 +124,19 @@ dep_cowboy = git repo commit\
$i "Check that Cowboy is listed in rebar.config"
$t $(ERL) -eval " \
{ok, C} = file:consult(\"$(APP)/rebar.config\"), \
- {_, [{cowboy, _, {git, \"repo\", \"commit\"}}]} = lists:keyfind(deps, 1, C), \
+ {_, [{cowboy, _, {git, _, \"master\"}}]} = lists:keyfind(deps, 1, C), \
halt()"
+ $i "Distclean the application"
+ $t $(MAKE) -C $(APP) distclean $v
+
+ $i "Download rebar"
+ $t curl -s -L -o $(APP)/rebar $(REBAR_BINARY)
+ $t chmod +x $(APP)/rebar
+
+ $i "Use rebar to build the application"
+ $t cd $(APP) && ./rebar get-deps compile $v
+
core-compat-rebar-deps-pkg: build clean-core-compat-rebar-deps-pkg
$i "Bootstrap a new OTP library named $(APP)"
@@ -129,6 +161,16 @@ DEPS = cowboy\
{_, [{cowboy, _, {git, \"https://github.com/\" ++ _, _}}]} = lists:keyfind(deps, 1, C), \
halt()"
+ $i "Distclean the application"
+ $t $(MAKE) -C $(APP) distclean $v
+
+ $i "Download rebar"
+ $t curl -s -L -o $(APP)/rebar $(REBAR_BINARY)
+ $t chmod +x $(APP)/rebar
+
+ $i "Use rebar to build the application"
+ $t cd $(APP) && ./rebar get-deps compile $v
+
core-compat-rebar-erlc-opts: build clean-core-compat-rebar-erlc-opts
$i "Bootstrap a new OTP library named $(APP)"
@@ -167,3 +209,13 @@ core-compat-rebar-erlc-opts: build clean-core-compat-rebar-erlc-opts
true = lists:member(warn_missing_spec, Opts), \
true = lists:member(warn_untyped_record, Opts), \
halt()"
+
+ $i "Distclean the application"
+ $t $(MAKE) -C $(APP) distclean $v
+
+ $i "Download rebar"
+ $t curl -s -L -o $(APP)/rebar $(REBAR_BINARY)
+ $t chmod +x $(APP)/rebar
+
+ $i "Use rebar to build the application"
+ $t cd $(APP) && ./rebar compile $v