xref: /aosp_15_r20/external/coreboot/tests/Makefile.mk (revision b9411a12aaaa7e1e6a6fb7c5e057f44ee179a49c)
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