1*b9411a12SAndroid Build Coastguard Worker# SPDX-License-Identifier: GPL-2.0-only 2*b9411a12SAndroid Build Coastguard Worker 3*b9411a12SAndroid Build Coastguard Worker# Place the build output in one of two places depending on COV, so that code 4*b9411a12SAndroid Build Coastguard Worker# built with code coverage never mixes with code built without code coverage. 5*b9411a12SAndroid Build Coastguard Workerifeq ($(COV),1) 6*b9411a12SAndroid Build Coastguard Workertestobj := $(obj)/coverage 7*b9411a12SAndroid Build Coastguard Workerelse 8*b9411a12SAndroid Build Coastguard Workertestobj := $(obj)/tests 9*b9411a12SAndroid Build Coastguard Workerendif 10*b9411a12SAndroid Build Coastguard Worker 11*b9411a12SAndroid Build Coastguard Workerobjutil := $(testobj)/util 12*b9411a12SAndroid Build Coastguard Worker 13*b9411a12SAndroid Build Coastguard Workerinclude $(top)/tests/Makefile.common 14*b9411a12SAndroid Build Coastguard Worker 15*b9411a12SAndroid Build Coastguard Worker# Enable GDB debug build if requested 16*b9411a12SAndroid Build Coastguard WorkerGDB_DEBUG ?= 0 17*b9411a12SAndroid Build Coastguard Workerifneq ($(GDB_DEBUG),0) 18*b9411a12SAndroid Build Coastguard WorkerTEST_CFLAGS += -g -Og 19*b9411a12SAndroid Build Coastguard Workerendif 20*b9411a12SAndroid Build Coastguard Worker 21*b9411a12SAndroid Build Coastguard Worker# Enable code coverage if requested 22*b9411a12SAndroid Build Coastguard Workerifeq ($(COV),1) 23*b9411a12SAndroid Build Coastguard WorkerTEST_CFLAGS += --coverage 24*b9411a12SAndroid Build Coastguard WorkerTEST_LDFLAGS += --coverage 25*b9411a12SAndroid Build Coastguard Workerendif 26*b9411a12SAndroid Build Coastguard Worker 27*b9411a12SAndroid Build Coastguard Workerstages := decompressor bootblock romstage smm verstage 28*b9411a12SAndroid Build Coastguard Workerstages += ramstage rmodule postcar libagesa 29*b9411a12SAndroid Build Coastguard Worker 30*b9411a12SAndroid Build Coastguard Workeralltests := 31*b9411a12SAndroid Build Coastguard Workersubdirs := tests/arch tests/acpi tests/commonlib tests/console tests/cpu 32*b9411a12SAndroid Build Coastguard Workersubdirs += tests/device tests/drivers tests/ec tests/lib 33*b9411a12SAndroid Build Coastguard Workersubdirs += tests/mainboard tests/northbridge tests/security tests/soc 34*b9411a12SAndroid Build Coastguard Workersubdirs += tests/southbridge tests/superio tests/vendorcode 35*b9411a12SAndroid Build Coastguard Worker 36*b9411a12SAndroid Build Coastguard Workerdefine tests-handler 37*b9411a12SAndroid Build Coastguard Workeralltests += $(1)$(2) 38*b9411a12SAndroid Build Coastguard Worker$(foreach attribute,$(attributes), 39*b9411a12SAndroid Build Coastguard Worker $(eval $(1)$(2)-$(attribute) += $($(2)-$(attribute)))) 40*b9411a12SAndroid Build Coastguard Worker$(foreach attribute,$(attributes), 41*b9411a12SAndroid Build Coastguard Worker $(eval $(2)-$(attribute) := )) 42*b9411a12SAndroid Build Coastguard Worker 43*b9411a12SAndroid Build Coastguard Worker# Sanity check for stage attribute value 44*b9411a12SAndroid Build Coastguard Worker$(eval $(1)$(2)-stage := $(if $($(1)$(2)-stage),$($(1)$(2)-stage),ramstage)) 45*b9411a12SAndroid Build Coastguard Worker$(if $(findstring $($(1)$(2)-stage), $(stages)),, 46*b9411a12SAndroid Build Coastguard Worker $(error Wrong $(1)$(2)-stage value $($(1)$(2)-stage). \ 47*b9411a12SAndroid Build Coastguard Worker Check your $(dir $(1)$(2))Makefile.mk)) 48*b9411a12SAndroid Build Coastguard Workerendef 49*b9411a12SAndroid Build Coastguard Worker 50*b9411a12SAndroid Build Coastguard Worker$(call add-special-class, tests) 51*b9411a12SAndroid Build Coastguard Worker$(call evaluate_subdirs) 52*b9411a12SAndroid Build Coastguard Worker 53*b9411a12SAndroid Build Coastguard Worker$(foreach test, $(alltests), \ 54*b9411a12SAndroid Build Coastguard Worker $(eval $(test)-srcobjs := $(addprefix $(testobj)/$(test)/, \ 55*b9411a12SAndroid Build Coastguard Worker $(patsubst %.c,%.o,$(filter src/%,$($(test)-srcs))))) \ 56*b9411a12SAndroid Build Coastguard Worker $(eval $(test)-sysobjs := $(addprefix $(testobj)/$(test)/, \ 57*b9411a12SAndroid Build Coastguard Worker $(patsubst %.c,%.o,$($(test)-syssrcs)))) \ 58*b9411a12SAndroid Build Coastguard Worker $(eval $(test)-objs := $(addprefix $(testobj)/$(test)/, \ 59*b9411a12SAndroid Build Coastguard Worker $(patsubst %.c,%.o,$($(test)-srcs))))) 60*b9411a12SAndroid Build Coastguard Worker$(foreach test, $(alltests), \ 61*b9411a12SAndroid Build Coastguard Worker $(eval $(test)-bin := $(testobj)/$(test)/run)) 62*b9411a12SAndroid Build Coastguard Worker$(foreach test, $(alltests), \ 63*b9411a12SAndroid Build Coastguard Worker $(eval $(call TEST_CC_template,$(test)))) 64*b9411a12SAndroid Build Coastguard Worker 65*b9411a12SAndroid Build Coastguard Worker$(foreach test, $(alltests), \ 66*b9411a12SAndroid Build Coastguard Worker $(eval all-test-objs += $($(test)-objs))) 67*b9411a12SAndroid Build Coastguard Worker$(foreach test, $(alltests), \ 68*b9411a12SAndroid Build Coastguard Worker $(eval test-bins += $($(test)-bin))) 69*b9411a12SAndroid Build Coastguard Worker 70*b9411a12SAndroid Build Coastguard WorkerDEPENDENCIES += $(addsuffix .d,$(basename $(all-test-objs))) 71*b9411a12SAndroid Build Coastguard Worker-include $(DEPENDENCIES) 72*b9411a12SAndroid Build Coastguard Worker 73*b9411a12SAndroid Build Coastguard Worker.PHONY: $(alltests) $(addprefix clean-,$(alltests)) $(addprefix try-,$(alltests)) 74*b9411a12SAndroid Build Coastguard Worker.PHONY: $(addprefix build-,$(alltests)) $(addprefix run-,$(alltests)) 75*b9411a12SAndroid Build Coastguard Worker.PHONY: unit-tests build-unit-tests run-unit-tests clean-unit-tests 76*b9411a12SAndroid Build Coastguard Worker.PHONY: junit.xml-unit-tests clean-junit.xml-unit-tests 77*b9411a12SAndroid Build Coastguard Worker 78*b9411a12SAndroid Build Coastguard Worker# %g in CMOCKA_XML_FILE will be replaced with "__TEST_NAME__(<test-group-name>)" 79*b9411a12SAndroid Build Coastguard Worker# by macro cb_run_group_tests(), which should be used for running tests. 80*b9411a12SAndroid Build Coastguard Worker# __TEST_NAME__ contains test name including path e.g. tests_lib_rtc-test 81*b9411a12SAndroid Build Coastguard Workerifeq ($(JUNIT_OUTPUT),y) 82*b9411a12SAndroid Build Coastguard Worker$(addprefix run-,$(alltests)): export CMOCKA_MESSAGE_OUTPUT=xml 83*b9411a12SAndroid Build Coastguard Worker$(addprefix run-,$(alltests)): export CMOCKA_XML_FILE=$(testobj)/junit-%g.xml 84*b9411a12SAndroid Build Coastguard Workerendif 85*b9411a12SAndroid Build Coastguard Worker 86*b9411a12SAndroid Build Coastguard Worker$(addprefix run-,$(alltests)): run-%: $$(%-bin) 87*b9411a12SAndroid Build Coastguard Worker rm -f $(testobj)/junit-$(subst /,_,$(patsubst $(testobj)/%/,%,$(dir $^)))\(*\).xml 88*b9411a12SAndroid Build Coastguard Worker rm -f $(testobj)/$(subst /,_,$^).failed 89*b9411a12SAndroid Build Coastguard Worker -$^ || echo failed > $(testobj)/$(subst /,_,$^).failed 90*b9411a12SAndroid Build Coastguard Worker 91*b9411a12SAndroid Build Coastguard Worker$(addprefix build-,$(alltests)): build-%: $$(%-bin) 92*b9411a12SAndroid Build Coastguard Worker 93*b9411a12SAndroid Build Coastguard Worker$(alltests): run-$$(@) 94*b9411a12SAndroid Build Coastguard Worker 95*b9411a12SAndroid Build Coastguard Worker$(addprefix try-,$(alltests)): try-%: clean-% $(TEST_COMMON_DEPENDENCIES) 96*b9411a12SAndroid Build Coastguard Worker mkdir -p $(testobj)/$* 97*b9411a12SAndroid Build Coastguard Worker echo "<testcase classname='coreboot_build_unit_test' name='$*'>" >> $(testobj)/$*.tmp; \ 98*b9411a12SAndroid Build Coastguard Worker $(MAKE) V=$(V) Q=$(Q) COV=$(COV) JUNIT_OUTPUT=y "build-$*" >> $(testobj)/$*.tmp.2 2>&1 \ 99*b9411a12SAndroid Build Coastguard Worker && type="system-out" || type="failure"; \ 100*b9411a12SAndroid Build Coastguard Worker if [ $$type = "failure" ]; then \ 101*b9411a12SAndroid Build Coastguard Worker echo "<failure type='buildFailed'>" >> $(testobj)/$*.tmp; \ 102*b9411a12SAndroid Build Coastguard Worker else \ 103*b9411a12SAndroid Build Coastguard Worker echo "<$$type>" >> $(testobj)/$*.tmp; \ 104*b9411a12SAndroid Build Coastguard Worker fi; \ 105*b9411a12SAndroid Build Coastguard Worker echo '<![CDATA[' >> $(testobj)/$*.tmp; \ 106*b9411a12SAndroid Build Coastguard Worker cat $(testobj)/$*.tmp.2 >> $(testobj)/$*.tmp; \ 107*b9411a12SAndroid Build Coastguard Worker echo "]]></$$type>" >> $(testobj)/$*.tmp; \ 108*b9411a12SAndroid Build Coastguard Worker rm -f $(testobj)/$*.tmp.2; \ 109*b9411a12SAndroid Build Coastguard Worker echo "</testcase>" >> $(testobj)/$*.tmp; \ 110*b9411a12SAndroid Build Coastguard Worker if [ $$type != 'failure' ]; then \ 111*b9411a12SAndroid Build Coastguard Worker $(MAKE) V=$(V) Q=$(Q) COV=$(COV) JUNIT_OUTPUT=y "run-$*"; \ 112*b9411a12SAndroid Build Coastguard Worker fi 113*b9411a12SAndroid Build Coastguard Worker 114*b9411a12SAndroid Build Coastguard Worker 115*b9411a12SAndroid Build Coastguard WorkerTESTS_BUILD_XML_FILE := $(testobj)/junit-tests-build.xml 116*b9411a12SAndroid Build Coastguard Worker 117*b9411a12SAndroid Build Coastguard Worker$(TESTS_BUILD_XML_FILE): clean-junit.xml-unit-tests $(addprefix try-,$(alltests)) 118*b9411a12SAndroid Build Coastguard Worker mkdir -p $(dir $@) 119*b9411a12SAndroid Build Coastguard Worker echo '<?xml version="1.0" encoding="utf-8"?><testsuite>' > $@ 120*b9411a12SAndroid Build Coastguard Worker for tst in $(alltests); do \ 121*b9411a12SAndroid Build Coastguard Worker cat $(testobj)/$$tst.tmp >> $@; \ 122*b9411a12SAndroid Build Coastguard Worker done 123*b9411a12SAndroid Build Coastguard Worker echo "</testsuite>" >> $@ 124*b9411a12SAndroid Build Coastguard Worker 125*b9411a12SAndroid Build Coastguard Workerjunit.xml-unit-tests: $(TESTS_BUILD_XML_FILE) 126*b9411a12SAndroid Build Coastguard Worker 127*b9411a12SAndroid Build Coastguard Workerclean-junit.xml-unit-tests: 128*b9411a12SAndroid Build Coastguard Worker rm -f $(TESTS_BUILD_XML_FILE) 129*b9411a12SAndroid Build Coastguard Worker 130*b9411a12SAndroid Build Coastguard Worker 131*b9411a12SAndroid Build Coastguard Worker# Build a code coverage report by collecting all the gcov files into a single 132*b9411a12SAndroid Build Coastguard Worker# report. If COV is not set, this might be a user error, and they're trying 133*b9411a12SAndroid Build Coastguard Worker# to generate a coverage report without first having built and run the code 134*b9411a12SAndroid Build Coastguard Worker# with code coverage. So instead of silently correcting it by adding COV=1, 135*b9411a12SAndroid Build Coastguard Worker# let's flag it to the user so they can be sure they're doing the thing they 136*b9411a12SAndroid Build Coastguard Worker# want to do. 137*b9411a12SAndroid Build Coastguard Worker 138*b9411a12SAndroid Build Coastguard Worker.PHONY: coverage-report clean-coverage-report 139*b9411a12SAndroid Build Coastguard Worker 140*b9411a12SAndroid Build Coastguard Workerifeq ($(COV),1) 141*b9411a12SAndroid Build Coastguard Workercoverage-report: 142*b9411a12SAndroid Build Coastguard Worker lcov -o $(testobj)/tests.info -c -d $(testobj) --exclude '$(testsrc)/*' 143*b9411a12SAndroid Build Coastguard Worker genhtml -q -o $(testobj)/$(coverage_dir) -t "coreboot unit tests" \ 144*b9411a12SAndroid Build Coastguard Worker -s $(testobj)/tests.info 145*b9411a12SAndroid Build Coastguard Worker 146*b9411a12SAndroid Build Coastguard Workerclean-coverage-report: 147*b9411a12SAndroid Build Coastguard Worker rm -Rf $(testobj)/$(coverage_dir) 148*b9411a12SAndroid Build Coastguard Workerelse 149*b9411a12SAndroid Build Coastguard Workercoverage-report: 150*b9411a12SAndroid Build Coastguard Worker COV=1 V=$(V) $(MAKE) coverage-report 151*b9411a12SAndroid Build Coastguard Worker 152*b9411a12SAndroid Build Coastguard Workerclean-coverage-report: 153*b9411a12SAndroid Build Coastguard Worker COV=1 V=$(V) $(MAKE) clean-coverage-report 154*b9411a12SAndroid Build Coastguard Workerendif 155*b9411a12SAndroid Build Coastguard Worker 156*b9411a12SAndroid Build Coastguard Workerunit-tests: build-unit-tests run-unit-tests 157*b9411a12SAndroid Build Coastguard Worker 158*b9411a12SAndroid Build Coastguard Workerbuild-unit-tests: $(test-bins) 159*b9411a12SAndroid Build Coastguard Worker 160*b9411a12SAndroid Build Coastguard Workerrun-unit-tests: $(alltests) 161*b9411a12SAndroid Build Coastguard Worker if [ `find $(testobj) -name '*.failed' | wc -l` -gt 0 ]; then \ 162*b9411a12SAndroid Build Coastguard Worker echo "**********************"; \ 163*b9411a12SAndroid Build Coastguard Worker echo " TESTS FAILED"; \ 164*b9411a12SAndroid Build Coastguard Worker echo "**********************"; \ 165*b9411a12SAndroid Build Coastguard Worker exit 1; \ 166*b9411a12SAndroid Build Coastguard Worker else \ 167*b9411a12SAndroid Build Coastguard Worker echo "**********************"; \ 168*b9411a12SAndroid Build Coastguard Worker echo " ALL TESTS PASSED"; \ 169*b9411a12SAndroid Build Coastguard Worker echo "**********************"; \ 170*b9411a12SAndroid Build Coastguard Worker exit 0; \ 171*b9411a12SAndroid Build Coastguard Worker fi 172*b9411a12SAndroid Build Coastguard Worker 173*b9411a12SAndroid Build Coastguard Worker$(addprefix clean-,$(alltests)): clean-%: 174*b9411a12SAndroid Build Coastguard Worker rm -rf $(testobj)/$* 175*b9411a12SAndroid Build Coastguard Worker 176*b9411a12SAndroid Build Coastguard Workerclean-unit-tests: 177*b9411a12SAndroid Build Coastguard Worker rm -rf $(testobj) 178*b9411a12SAndroid Build Coastguard Worker 179*b9411a12SAndroid Build Coastguard Workerlist-unit-tests: 180*b9411a12SAndroid Build Coastguard Worker @echo "unit-tests:" 181*b9411a12SAndroid Build Coastguard Worker for t in $(sort $(alltests)); do \ 182*b9411a12SAndroid Build Coastguard Worker echo " $$t"; \ 183*b9411a12SAndroid Build Coastguard Worker done 184*b9411a12SAndroid Build Coastguard Worker 185*b9411a12SAndroid Build Coastguard Workerhelp-unit-tests help:: 186*b9411a12SAndroid Build Coastguard Worker @echo '*** coreboot unit-tests targets ***' 187*b9411a12SAndroid Build Coastguard Worker @echo ' Use "COV=1 make [target]" to enable code coverage for unit tests' 188*b9411a12SAndroid Build Coastguard Worker @echo ' Use "GDB_DEBUG=1 make [target]" to build with debug symbols' 189*b9411a12SAndroid Build Coastguard Worker @echo ' unit-tests - Run all unit-tests from tests/' 190*b9411a12SAndroid Build Coastguard Worker @echo ' clean-unit-tests - Remove unit-tests build artifacts' 191*b9411a12SAndroid Build Coastguard Worker @echo ' list-unit-tests - List all unit-tests' 192*b9411a12SAndroid Build Coastguard Worker @echo ' <unit-test> - Build and run single unit-test' 193*b9411a12SAndroid Build Coastguard Worker @echo ' clean-<unit-test> - Remove single unit-test build artifacts' 194*b9411a12SAndroid Build Coastguard Worker @echo ' coverage-report - Generate a code coverage report' 195*b9411a12SAndroid Build Coastguard Worker @echo ' clean-coverage-report - Remove the code coverage report' 196*b9411a12SAndroid Build Coastguard Worker @echo 197