Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3f4435b5 authored by Shuah Khan (Samsung OSG)'s avatar Shuah Khan (Samsung OSG)
Browse files

selftests: lib.mk: add SKIP handling to RUN_TESTS define



RUN_TESTS which is the common function that implements run_tests target,
treats all non-zero return codes from tests as failures. When tests are
skipped with non-zero return code, because of unmet dependencies and/or
unsupported configuration, it reports them as failed. This will lead to
too many false negatives even on the tests that couldn't be run.

RUN_TESTS is changed to test for SKIP=4 return from tests to enable the
framework for individual tests to return special SKIP code.

Tests will be changed as needed to report SKIP instead FAIL/PASS when
they get skipped.

Signed-off-by: default avatarShuah Khan (Samsung OSG) <shuah@kernel.org>
parent 42b44c34
Loading
Loading
Loading
Loading
+13 −2
Original line number Diff line number Diff line
@@ -22,6 +22,7 @@ all: $(TEST_GEN_PROGS) $(TEST_GEN_PROGS_EXTENDED) $(TEST_GEN_FILES)
define RUN_TESTS
	@export KSFT_TAP_LEVEL=`echo 1`;		\
	test_num=`echo 0`;				\
	skip=`echo 4`;					\
	echo "TAP version 13";				\
	for TEST in $(1); do				\
		BASENAME_TEST=`basename $$TEST`;	\
@@ -34,9 +35,19 @@ define RUN_TESTS
		else					\
			cd `dirname $$TEST` > /dev/null; \
			if [ "X$(summary)" != "X" ]; then	\
				(./$$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]";		\
				(./$$BASENAME_TEST > /tmp/$$BASENAME_TEST 2>&1 && \
				echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || \
				(if [ $$? -eq $$skip ]; then	\
					echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [SKIP]";				\
				else echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";					\
				fi;)			\
			else				\
				(./$$BASENAME_TEST && echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") || echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";					\
				(./$$BASENAME_TEST &&	\
				echo "ok 1..$$test_num selftests: $$BASENAME_TEST [PASS]") ||						\
				(if [ $$? -eq $$skip ]; then \
					echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [SKIP]"; \
				else echo "not ok 1..$$test_num selftests:  $$BASENAME_TEST [FAIL]";				\
				fi;)		\
			fi;				\
			cd - > /dev/null;		\
		fi;					\