|
@@ -6,7 +6,14 @@ ifeq (0,$(MAKELEVEL))
|
|
OUTPUT := $(shell pwd)
|
|
OUTPUT := $(shell pwd)
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
+# The following are built by lib.mk common compile rules.
|
|
|
|
+# TEST_CUSTOM_PROGS should be used by tests that require
|
|
|
|
+# custom build rule and prevent common build rule use.
|
|
|
|
+# TEST_PROGS are for test shell scripts.
|
|
|
|
+# TEST_CUSTOM_PROGS and TEST_PROGS will be run by common run_tests
|
|
|
|
+# and install targets. Common clean doesn't touch them.
|
|
TEST_GEN_PROGS := $(patsubst %,$(OUTPUT)/%,$(TEST_GEN_PROGS))
|
|
TEST_GEN_PROGS := $(patsubst %,$(OUTPUT)/%,$(TEST_GEN_PROGS))
|
|
|
|
+TEST_GEN_PROGS_EXTENDED := $(patsubst %,$(OUTPUT)/%,$(TEST_GEN_PROGS_EXTENDED))
|
|
TEST_GEN_FILES := $(patsubst %,$(OUTPUT)/%,$(TEST_GEN_FILES))
|
|
TEST_GEN_FILES := $(patsubst %,$(OUTPUT)/%,$(TEST_GEN_FILES))
|
|
|
|
|
|
all: $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES)
|
|
all: $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES)
|
|
@@ -20,17 +27,28 @@ define RUN_TESTS
|
|
test_num=`echo $$test_num+1 | bc`; \
|
|
test_num=`echo $$test_num+1 | bc`; \
|
|
echo "selftests: $$BASENAME_TEST"; \
|
|
echo "selftests: $$BASENAME_TEST"; \
|
|
echo "========================================"; \
|
|
echo "========================================"; \
|
|
- if [ ! -x $$BASENAME_TEST ]; then \
|
|
|
|
|
|
+ if [ ! -x $$TEST ]; then \
|
|
echo "selftests: Warning: file $$BASENAME_TEST is not executable, correct this.";\
|
|
echo "selftests: Warning: file $$BASENAME_TEST is not executable, correct this.";\
|
|
echo "not ok 1..$$test_num selftests: $$BASENAME_TEST [FAIL]"; \
|
|
echo "not ok 1..$$test_num selftests: $$BASENAME_TEST [FAIL]"; \
|
|
else \
|
|
else \
|
|
- cd `dirname $$TEST` > /dev/null; (./$$BASENAME_TEST && echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || echo "not ok 1..$$test_num selftests: $$BASENAME_TEST [FAIL]"; cd - > /dev/null;\
|
|
|
|
|
|
+ cd `dirname $$TEST` > /dev/null; (./$$BASENAME_TEST > /tmp/$$BASENAME_TEST 2>&1 && echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || echo "not ok 1..$$test_num selftests: $$BASENAME_TEST [FAIL]"; cd - > /dev/null;\
|
|
fi; \
|
|
fi; \
|
|
done;
|
|
done;
|
|
endef
|
|
endef
|
|
|
|
|
|
run_tests: all
|
|
run_tests: all
|
|
- $(call RUN_TESTS, $(TEST_GEN_PROGS) $(TEST_PROGS))
|
|
|
|
|
|
+ifneq ($(KBUILD_SRC),)
|
|
|
|
+ @if [ "X$(TEST_PROGS) $(TEST_PROGS_EXTENDED) $(TEST_FILES)" != "X" ]; then
|
|
|
|
+ @rsync -aq $(TEST_PROGS) $(TEST_PROGS_EXTENDED) $(TEST_FILES) $(OUTPUT)
|
|
|
|
+ fi
|
|
|
|
+ @if [ "X$(TEST_PROGS)" != "X" ]; then
|
|
|
|
+ $(call RUN_TESTS, $(TEST_GEN_PROGS) $(TEST_CUSTOM_PROGS) $(OUTPUT)/$(TEST_PROGS))
|
|
|
|
+ else
|
|
|
|
+ $(call RUN_TESTS, $(TEST_GEN_PROGS) $(TEST_CUSTOM_PROGS))
|
|
|
|
+ fi
|
|
|
|
+else
|
|
|
|
+ $(call RUN_TESTS, $(TEST_GEN_PROGS) $(TEST_CUSTOM_PROGS) $(TEST_PROGS))
|
|
|
|
+endif
|
|
|
|
|
|
define INSTALL_RULE
|
|
define INSTALL_RULE
|
|
@if [ "X$(TEST_PROGS)$(TEST_PROGS_EXTENDED)$(TEST_FILES)" != "X" ]; then \
|
|
@if [ "X$(TEST_PROGS)$(TEST_PROGS_EXTENDED)$(TEST_FILES)" != "X" ]; then \
|
|
@@ -38,10 +56,10 @@ define INSTALL_RULE
|
|
echo "rsync -a $(TEST_PROGS) $(TEST_PROGS_EXTENDED) $(TEST_FILES) $(INSTALL_PATH)/"; \
|
|
echo "rsync -a $(TEST_PROGS) $(TEST_PROGS_EXTENDED) $(TEST_FILES) $(INSTALL_PATH)/"; \
|
|
rsync -a $(TEST_PROGS) $(TEST_PROGS_EXTENDED) $(TEST_FILES) $(INSTALL_PATH)/; \
|
|
rsync -a $(TEST_PROGS) $(TEST_PROGS_EXTENDED) $(TEST_FILES) $(INSTALL_PATH)/; \
|
|
fi
|
|
fi
|
|
- @if [ "X$(TEST_GEN_PROGS)$(TEST_GEN_PROGS_EXTENDED)$(TEST_GEN_FILES)" != "X" ]; then \
|
|
|
|
|
|
+ @if [ "X$(TEST_GEN_PROGS)$(TEST_CUSTOM_PROGS)$(TEST_GEN_PROGS_EXTENDED)$(TEST_GEN_FILES)" != "X" ]; then \
|
|
mkdir -p ${INSTALL_PATH}; \
|
|
mkdir -p ${INSTALL_PATH}; \
|
|
- echo "rsync -a $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES) $(INSTALL_PATH)/"; \
|
|
|
|
- rsync -a $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES) $(INSTALL_PATH)/; \
|
|
|
|
|
|
+ echo "rsync -a $(TEST_GEN_PROGS) $(TEST_CUSTOM_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES) $(INSTALL_PATH)/"; \
|
|
|
|
+ rsync -a $(TEST_GEN_PROGS) $(TEST_CUSTOM_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES) $(INSTALL_PATH)/; \
|
|
fi
|
|
fi
|
|
endef
|
|
endef
|
|
|
|
|
|
@@ -53,15 +71,20 @@ else
|
|
endif
|
|
endif
|
|
|
|
|
|
define EMIT_TESTS
|
|
define EMIT_TESTS
|
|
- @for TEST in $(TEST_GEN_PROGS) $(TEST_PROGS); do \
|
|
|
|
|
|
+ @for TEST in $(TEST_GEN_PROGS) $(TEST_CUSTOM_PROGS) $(TEST_PROGS); do \
|
|
BASENAME_TEST=`basename $$TEST`; \
|
|
BASENAME_TEST=`basename $$TEST`; \
|
|
- echo "(./$$BASENAME_TEST && echo \"selftests: $$BASENAME_TEST [PASS]\") || echo \"selftests: $$BASENAME_TEST [FAIL]\""; \
|
|
|
|
|
|
+ echo "(./$$BASENAME_TEST > /tmp/$$BASENAME_TEST 2>&1 && echo \"selftests: $$BASENAME_TEST [PASS]\") || echo \"selftests: $$BASENAME_TEST [FAIL]\""; \
|
|
done;
|
|
done;
|
|
endef
|
|
endef
|
|
|
|
|
|
emit_tests:
|
|
emit_tests:
|
|
$(EMIT_TESTS)
|
|
$(EMIT_TESTS)
|
|
|
|
|
|
|
|
+# define if isn't already. It is undefined in make O= case.
|
|
|
|
+ifeq ($(RM),)
|
|
|
|
+RM := rm -f
|
|
|
|
+endif
|
|
|
|
+
|
|
define CLEAN
|
|
define CLEAN
|
|
$(RM) -r $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES) $(EXTRA_CLEAN)
|
|
$(RM) -r $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES) $(EXTRA_CLEAN)
|
|
endef
|
|
endef
|
|
@@ -69,6 +92,15 @@ endef
|
|
clean:
|
|
clean:
|
|
$(CLEAN)
|
|
$(CLEAN)
|
|
|
|
|
|
|
|
+# When make O= with kselftest target from main level
|
|
|
|
+# the following aren't defined.
|
|
|
|
+#
|
|
|
|
+ifneq ($(KBUILD_SRC),)
|
|
|
|
+LINK.c = $(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)
|
|
|
|
+COMPILE.S = $(CC) $(ASFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c
|
|
|
|
+LINK.S = $(CC) $(ASFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)
|
|
|
|
+endif
|
|
|
|
+
|
|
$(OUTPUT)/%:%.c
|
|
$(OUTPUT)/%:%.c
|
|
$(LINK.c) $^ $(LDLIBS) -o $@
|
|
$(LINK.c) $^ $(LDLIBS) -o $@
|
|
|
|
|