Don't run tests on build, make it it's own recipe
This commit is contained in:
32
Makefile
32
Makefile
@@ -31,7 +31,6 @@ VM_OUT=$(DIST)/avm.out
|
|||||||
TEST_DIST=$(DIST)/test
|
TEST_DIST=$(DIST)/test
|
||||||
TEST_SRC=test
|
TEST_SRC=test
|
||||||
|
|
||||||
TEST_LIB_CFLAGS:=$(GENERAL-FLAGS) -I$(TEST_SRC) $(DEBUG-FLAGS) -D VERBOSE=$(VERBOSE)
|
|
||||||
TEST_LIB_SRC=$(TEST_SRC)/lib
|
TEST_LIB_SRC=$(TEST_SRC)/lib
|
||||||
TEST_LIB_DIST=$(TEST_DIST)/lib
|
TEST_LIB_DIST=$(TEST_DIST)/lib
|
||||||
TEST_LIB_OUT=$(DIST)/test-lib.out
|
TEST_LIB_OUT=$(DIST)/test-lib.out
|
||||||
@@ -42,11 +41,11 @@ DEPFLAGS = -MT $@ -MMD -MP -MF
|
|||||||
DEPS:=$(LIB_CODE:$(LIB_SRC)/%.c=$(DEPDIR)/lib/%.d) $(VM_CODE:$(VM_SRC)/%.c=$(DEPDIR)/vm/%.d) $(DEPDIR)/vm/main.d $(DEPDIR)/test/lib/main.d
|
DEPS:=$(LIB_CODE:$(LIB_SRC)/%.c=$(DEPDIR)/lib/%.d) $(VM_CODE:$(VM_SRC)/%.c=$(DEPDIR)/vm/%.d) $(DEPDIR)/vm/main.d $(DEPDIR)/test/lib/main.d
|
||||||
|
|
||||||
# Things you want to build on `make`
|
# Things you want to build on `make`
|
||||||
all: $(DIST) lib vm run-test-lib
|
all: $(DIST) lib vm tests
|
||||||
|
|
||||||
lib: $(LIB_OBJECTS)
|
lib: $(LIB_OBJECTS)
|
||||||
vm: $(VM_OUT)
|
vm: $(VM_OUT)
|
||||||
test-lib: $(TEST_LIB_OUT)
|
tests: $(TEST_LIB_OUT)
|
||||||
|
|
||||||
# Recipes
|
# Recipes
|
||||||
$(LIB_DIST)/%.o: $(LIB_SRC)/%.c | $(LIB_DIST) $(DEPDIR)/lib
|
$(LIB_DIST)/%.o: $(LIB_SRC)/%.c | $(LIB_DIST) $(DEPDIR)/lib
|
||||||
@@ -66,20 +65,11 @@ $(TEST_LIB_OUT): $(LIB_OBJECTS) $(TEST_LIB_DIST)/main.o
|
|||||||
@echo "$(TERM_GREEN)$@$(TERM_RESET): $^"
|
@echo "$(TERM_GREEN)$@$(TERM_RESET): $^"
|
||||||
|
|
||||||
$(TEST_LIB_DIST)/main.o: $(TEST_LIB_SRC)/main.c | $(TEST_LIB_DIST) $(DEPDIR)/test/lib
|
$(TEST_LIB_DIST)/main.o: $(TEST_LIB_SRC)/main.c | $(TEST_LIB_DIST) $(DEPDIR)/test/lib
|
||||||
@$(CC) $(TEST_LIB_CFLAGS) $(DEPFLAGS) $(DEPDIR)/test/lib/main.d -c $< -o $@ $(LIBS)
|
@$(CC) $(CFLAGS) $(DEPFLAGS) $(DEPDIR)/test/lib/main.d -c $< -o $@ $(LIBS)
|
||||||
@echo "$(TERM_YELLOW)$@$(TERM_RESET): $<"
|
@echo "$(TERM_YELLOW)$@$(TERM_RESET): $<"
|
||||||
|
|
||||||
.PHONY: run-test-lib
|
.PHONY: test
|
||||||
.ONESHELL:
|
test: run-test-lib
|
||||||
run-test-lib: $(TEST_LIB_OUT)
|
|
||||||
@echo "$(TERM_YELLOW)test/lib$(TERM_RESET): Starting test"
|
|
||||||
@./$^;
|
|
||||||
if [ $$? -ne 0 ];
|
|
||||||
then
|
|
||||||
echo "$(TERM_RED)test/lib$(TERM_RESET): Test failed";
|
|
||||||
else
|
|
||||||
echo "$(TERM_GREEN)test/lib$(TERM_RESET): Test succeeded";
|
|
||||||
fi
|
|
||||||
|
|
||||||
.PHONY: run
|
.PHONY: run
|
||||||
run: $(DIST)/$(VM_OUT)
|
run: $(DIST)/$(VM_OUT)
|
||||||
@@ -93,6 +83,18 @@ clean:
|
|||||||
interpret: $(VM_OUT)
|
interpret: $(VM_OUT)
|
||||||
@$(VM_OUT) $(BYTECODE)
|
@$(VM_OUT) $(BYTECODE)
|
||||||
|
|
||||||
|
.PHONY: run-test-lib
|
||||||
|
.ONESHELL:
|
||||||
|
run-test-lib: $(TEST_LIB_OUT)
|
||||||
|
@echo "$(TERM_YELLOW)test/lib$(TERM_RESET): Starting test"
|
||||||
|
@./$^;
|
||||||
|
if [ $$? -ne 0 ];
|
||||||
|
then
|
||||||
|
echo "$(TERM_RED)test/lib$(TERM_RESET): Test failed";
|
||||||
|
else
|
||||||
|
echo "$(TERM_GREEN)test/lib$(TERM_RESET): Test passed";
|
||||||
|
fi
|
||||||
|
|
||||||
# Directories
|
# Directories
|
||||||
$(DIST):
|
$(DIST):
|
||||||
mkdir -p $@
|
mkdir -p $@
|
||||||
|
|||||||
Reference in New Issue
Block a user