13b8593eeSMarkus Armbruster# -*- Mode: makefile -*- 2e45eaef9SFam Zheng 3e45eaef9SFam Zheng.PHONY: check-help 4e45eaef9SFam Zhengcheck-help: 5e45eaef9SFam Zheng @echo "Regression testing targets:" 6e45eaef9SFam Zheng @echo 79865f39dSHuacai Chen @echo " $(MAKE) check Run block, qapi-schema, unit, softfloat, qtest and decodetree tests" 854f96b45SCleber Rosa @echo 9b98a3baeSPhilippe Mathieu-Daudé @echo " $(MAKE) check-qtest-TARGET Run qtest tests for given target" 10b98a3baeSPhilippe Mathieu-Daudé @echo " $(MAKE) check-qtest Run qtest tests" 11b98a3baeSPhilippe Mathieu-Daudé @echo " $(MAKE) check-unit Run qobject tests" 12b98a3baeSPhilippe Mathieu-Daudé @echo " $(MAKE) check-speed Run qobject speed tests" 13b98a3baeSPhilippe Mathieu-Daudé @echo " $(MAKE) check-qapi-schema Run QAPI schema tests" 14b98a3baeSPhilippe Mathieu-Daudé @echo " $(MAKE) check-block Run block tests" 15ca6db469SPhilippe Mathieu-Daudéifeq ($(CONFIG_TCG),y) 168ba0a820SAlex Bennée @echo " $(MAKE) check-tcg Run TCG tests" 1776170102SAlex Bennée @echo " $(MAKE) check-softfloat Run FPU emulation tests" 18ca6db469SPhilippe Mathieu-Daudéendif 19a56931eeSCleber Rosa @echo " $(MAKE) check-acceptance Run all acceptance (functional) tests" 2054f96b45SCleber Rosa @echo 21c3088cd3SWainer dos Santos Moschetta @echo " $(MAKE) check-report.tap Generates an aggregated TAP test report" 2221313721SCleber Rosa @echo " $(MAKE) check-venv Creates a Python venv for tests" 2354f96b45SCleber Rosa @echo " $(MAKE) check-clean Clean the tests and related data" 24e45eaef9SFam Zheng @echo 25a6eeac3bSAlex Bennée @echo "The following are useful for CI builds" 26a6eeac3bSAlex Bennée @echo " $(MAKE) check-build Build most test binaris" 274ec49f0fSCleber Rosa @echo " $(MAKE) get-vm-images Downloads all images used by acceptance tests, according to configured targets (~350 MB each, 1.5 GB max)" 284ec49f0fSCleber Rosa @echo 29e45eaef9SFam Zheng @echo 30e45eaef9SFam Zheng @echo "The variable SPEED can be set to control the gtester speed setting." 31b98a3baeSPhilippe Mathieu-Daudé @echo "Default options are -k and (for $(MAKE) V=1) --verbose; they can be" 32e45eaef9SFam Zheng @echo "changed with variable GTESTER_OPTIONS." 33e45eaef9SFam Zheng 34e45eaef9SFam Zhengifneq ($(wildcard config-host.mak),) 3546e7b706SFam Zhengexport SRC_PATH 3646e7b706SFam Zheng 3746e7b706SFam Zheng# Get the list of all supported sysemu targets 3846e7b706SFam ZhengSYSEMU_TARGET_LIST := $(subst -softmmu.mak,,$(notdir \ 3946e7b706SFam Zheng $(wildcard $(SRC_PATH)/default-configs/*-softmmu.mak))) 4046e7b706SFam Zheng 4129de2804SLaurent Viviercheck-speed-$(CONFIG_BLOCK) += tests/benchmark-crypto-hash$(EXESUF) 4229de2804SLaurent Viviercheck-speed-$(CONFIG_BLOCK) += tests/benchmark-crypto-hmac$(EXESUF) 4329de2804SLaurent Viviercheck-speed-$(CONFIG_BLOCK) += tests/benchmark-crypto-cipher$(EXESUF) 4446e7b706SFam Zheng 451e8a1faeSThomas HuthQEMU_CFLAGS += -I$(SRC_PATH)/tests -I$(SRC_PATH)/tests/qtest 4646e7b706SFam Zheng 4746e7b706SFam Zheng# Deps that are common to various different sets of tests below 48ebedb37cSPaolo Bonzinitest-util-obj-y = libqemuutil.a 49070e3edcSEmilio G. Cotatests/atomic_add-bench$(EXESUF): tests/atomic_add-bench.o $(test-util-obj-y) 5082fdfcbeSEmilio G. Cotatests/atomic64-bench$(EXESUF): tests/atomic64-bench.o $(test-util-obj-y) 5146e7b706SFam Zheng 520128cd29SLongpeng(Mike)tests/benchmark-crypto-hash$(EXESUF): tests/benchmark-crypto-hash.o $(test-crypto-obj-y) 53c7a9af4bSLongpeng(Mike)tests/benchmark-crypto-hmac$(EXESUF): tests/benchmark-crypto-hmac.o $(test-crypto-obj-y) 541efd9d5eSLongpeng(Mike)tests/benchmark-crypto-cipher$(EXESUF): tests/benchmark-crypto-cipher.o $(test-crypto-obj-y) 5546e7b706SFam Zheng 56409437e1SDaniel P. Berrangetests/migration/stress$(EXESUF): tests/migration/stress.o 570bdb12c7SPeter Maydell $(call quiet-command, $(LINKPROG) -static -O3 $(PTHREAD_LIB) -o $@ $< ,"LINK","$(TARGET_DIR)$@") 58409437e1SDaniel P. Berrange 59409437e1SDaniel P. BerrangeINITRD_WORK_DIR=tests/migration/initrd 60409437e1SDaniel P. Berrange 61409437e1SDaniel P. Berrangetests/migration/initrd-stress.img: tests/migration/stress$(EXESUF) 62409437e1SDaniel P. Berrange mkdir -p $(INITRD_WORK_DIR) 63409437e1SDaniel P. Berrange cp $< $(INITRD_WORK_DIR)/init 64409437e1SDaniel P. Berrange (cd $(INITRD_WORK_DIR) && (find | cpio --quiet -o -H newc | gzip -9)) > $@ 65409437e1SDaniel P. Berrange rm $(INITRD_WORK_DIR)/init 66409437e1SDaniel P. Berrange rmdir $(INITRD_WORK_DIR) 67409437e1SDaniel P. Berrange 684eb38726SDr. David Alan Gilberttests/vhost-user-bridge$(EXESUF): tests/vhost-user-bridge.o $(test-util-obj-y) libvhost-user.a 696e1da96bSPhilippe Mathieu-Daudétests/qemu-iotests/socket_scm_helper$(EXESUF): tests/qemu-iotests/socket_scm_helper.o 7046e7b706SFam Zheng 7146e7b706SFam ZhengSPEED = quick 7246e7b706SFam Zheng 7346e7b706SFam Zheng# gtester tests, possibly with verbose output 749df43317SPaolo Bonzini# do_test_tap runs all tests, even if some of them fail, while do_test_human 759df43317SPaolo Bonzini# stops at the first failure unless -k is given on the command line 769df43317SPaolo Bonzini 779df43317SPaolo Bonzinidefine do_test_human_k 789df43317SPaolo Bonzini $(quiet-@)rc=0; $(foreach COMMAND, $1, \ 799df43317SPaolo Bonzini $(call quiet-command-run, \ 809df43317SPaolo Bonzini export MALLOC_PERTURB_=$${MALLOC_PERTURB_:-$$(( $${RANDOM:-0} % 255 + 1))} $2; \ 819df43317SPaolo Bonzini $(COMMAND) -m=$(SPEED) -k --tap < /dev/null \ 829df43317SPaolo Bonzini | ./scripts/tap-driver.pl --test-name="$(notdir $(COMMAND))" $(if $(V),, --show-failures-only) \ 839df43317SPaolo Bonzini || rc=$$?;, "TEST", "$@: $(COMMAND)")) exit $$rc 849df43317SPaolo Bonziniendef 859df43317SPaolo Bonzinidefine do_test_human_no_k 869df43317SPaolo Bonzini $(foreach COMMAND, $1, \ 879df43317SPaolo Bonzini $(call quiet-command, \ 889df43317SPaolo Bonzini MALLOC_PERTURB_=$${MALLOC_PERTURB_:-$$(( $${RANDOM:-0} % 255 + 1))} $2 \ 899df43317SPaolo Bonzini $(COMMAND) -m=$(SPEED) -k --tap < /dev/null \ 909df43317SPaolo Bonzini | ./scripts/tap-driver.pl --test-name="$(notdir $(COMMAND))" $(if $(V),, --show-failures-only), \ 919df43317SPaolo Bonzini "TEST", "$@: $(COMMAND)") 929df43317SPaolo Bonzini) 939df43317SPaolo Bonziniendef 949df43317SPaolo Bonzinido_test_human = \ 959df43317SPaolo Bonzini $(if $(findstring k, $(MAKEFLAGS)), $(do_test_human_k), $(do_test_human_no_k)) 969df43317SPaolo Bonzini 979df43317SPaolo Bonzinidefine do_test_tap 989df43317SPaolo Bonzini $(call quiet-command, \ 999df43317SPaolo Bonzini { export MALLOC_PERTURB_=$${MALLOC_PERTURB_:-$$(( $${RANDOM:-0} % 255 + 1))} $2; \ 1009df43317SPaolo Bonzini $(foreach COMMAND, $1, \ 1019df43317SPaolo Bonzini $(COMMAND) -m=$(SPEED) -k --tap < /dev/null \ 1023bcb5840SHavard Skinnemoen | sed "s/^\(not \)\?ok [0-9]* /&$(notdir $(COMMAND)) /" || true; ) } \ 1039df43317SPaolo Bonzini | ./scripts/tap-merge.pl | tee "$@" \ 1049df43317SPaolo Bonzini | ./scripts/tap-driver.pl $(if $(V),, --show-failures-only), \ 1059df43317SPaolo Bonzini "TAP","$@") 1069df43317SPaolo Bonziniendef 10746e7b706SFam Zheng 1089df43317SPaolo Bonzinicheck-speed: $(check-speed-y) 1099df43317SPaolo Bonzini $(call do_test_human, $^) 11046e7b706SFam Zheng 1118ba0a820SAlex Bennée# Per guest TCG tests 1128ba0a820SAlex Bennée 113e24e66f0SAlex BennéeBUILD_TCG_TARGET_RULES=$(patsubst %,build-tcg-tests-%, $(TARGET_DIRS)) 114e24e66f0SAlex BennéeCLEAN_TCG_TARGET_RULES=$(patsubst %,clean-tcg-tests-%, $(TARGET_DIRS)) 115e24e66f0SAlex BennéeRUN_TCG_TARGET_RULES=$(patsubst %,run-tcg-tests-%, $(TARGET_DIRS)) 1168ba0a820SAlex Bennée 1171a7fab92SAlex Bennée# Probe for the Docker Builds needed for each build 1182b1f35b9SAlex Bennée$(foreach PROBE_TARGET,$(TARGET_DIRS), \ 119fc76c56dSPaolo Bonzini $(eval -include $(SRC_PATH)/tests/tcg/Makefile.prereqs)) 1201a7fab92SAlex Bennée 1213089e74eSAlex Bennéebuild-tcg-tests-%: $(if $(CONFIG_PLUGIN),plugins) 122fc76c56dSPaolo Bonzini $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \ 123fc76c56dSPaolo Bonzini -f $(SRC_PATH)/tests/tcg/Makefile.qemu \ 124fc76c56dSPaolo Bonzini SRC_PATH=$(SRC_PATH) \ 1252038f8c8SPaolo Bonzini V="$(V)" TARGET="$*" guest-tests, \ 126cff54773SAlex Bennée "BUILD", "TCG tests for $*") 1278ba0a820SAlex Bennée 12864ed6f92SPaolo Bonzinirun-tcg-tests-%: build-tcg-tests-% all 129fc76c56dSPaolo Bonzini $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \ 130fc76c56dSPaolo Bonzini -f $(SRC_PATH)/tests/tcg/Makefile.qemu \ 131fc76c56dSPaolo Bonzini SRC_PATH=$(SRC_PATH) SPEED="$(SPEED)" \ 1322038f8c8SPaolo Bonzini V="$(V)" TARGET="$*" run-guest-tests, \ 133cff54773SAlex Bennée "RUN", "TCG tests for $*") 1348ba0a820SAlex Bennée 1358ba0a820SAlex Bennéeclean-tcg-tests-%: 136fc76c56dSPaolo Bonzini $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \ 137fc76c56dSPaolo Bonzini -f $(SRC_PATH)/tests/tcg/Makefile.qemu \ 1382038f8c8SPaolo Bonzini SRC_PATH=$(SRC_PATH) TARGET="$*" clean-guest-tests, \ 139dda60da3SAlex Bennée "CLEAN", "TCG tests for $*") 1408ba0a820SAlex Bennée 1418ba0a820SAlex Bennée.PHONY: build-tcg 1428ba0a820SAlex Bennéebuild-tcg: $(BUILD_TCG_TARGET_RULES) 1438ba0a820SAlex Bennée 1448ba0a820SAlex Bennée.PHONY: check-tcg 145df2bb38eSAlex Bennéecheck-tcg: $(RUN_TCG_TARGET_RULES) 1468ba0a820SAlex Bennée 1478ba0a820SAlex Bennée.PHONY: clean-tcg 1488ba0a820SAlex Bennéeclean-tcg: $(CLEAN_TCG_TARGET_RULES) 14946e7b706SFam Zheng 15021313721SCleber Rosa# Python venv for running tests 15121313721SCleber Rosa 152a56931eeSCleber Rosa.PHONY: check-venv check-acceptance 15321313721SCleber Rosa 15421313721SCleber RosaTESTS_VENV_DIR=$(BUILD_DIR)/tests/venv 15521313721SCleber RosaTESTS_VENV_REQ=$(SRC_PATH)/tests/requirements.txt 156a56931eeSCleber RosaTESTS_RESULTS_DIR=$(BUILD_DIR)/tests/results 157a56931eeSCleber Rosa# Controls the output generated by Avocado when running tests. 158a56931eeSCleber Rosa# Any number of command separated loggers are accepted. For more 159a56931eeSCleber Rosa# information please refer to "avocado --help". 16059692a12SCleber RosaAVOCADO_SHOW=app 161b194713fSCleber RosaAVOCADO_TAGS=$(patsubst %-softmmu,-t arch:%, $(filter %-softmmu,$(TARGET_DIRS))) 16221313721SCleber Rosa 16321313721SCleber Rosa$(TESTS_VENV_DIR): $(TESTS_VENV_REQ) 16421313721SCleber Rosa $(call quiet-command, \ 16521313721SCleber Rosa $(PYTHON) -m venv --system-site-packages $@, \ 16621313721SCleber Rosa VENV, $@) 16721313721SCleber Rosa $(call quiet-command, \ 16821313721SCleber Rosa $(TESTS_VENV_DIR)/bin/python -m pip -q install -r $(TESTS_VENV_REQ), \ 16921313721SCleber Rosa PIP, $(TESTS_VENV_REQ)) 17021313721SCleber Rosa $(call quiet-command, touch $@) 17121313721SCleber Rosa 172a56931eeSCleber Rosa$(TESTS_RESULTS_DIR): 173a56931eeSCleber Rosa $(call quiet-command, mkdir -p $@, \ 174a56931eeSCleber Rosa MKDIR, $@) 175a56931eeSCleber Rosa 17621313721SCleber Rosacheck-venv: $(TESTS_VENV_DIR) 17721313721SCleber Rosa 1784ec49f0fSCleber RosaFEDORA_31_ARCHES_CANDIDATES=$(patsubst ppc64,ppc64le,$(TARGETS)) 1794ec49f0fSCleber RosaFEDORA_31_ARCHES := x86_64 aarch64 ppc64le s390x 1804ec49f0fSCleber RosaFEDORA_31_DOWNLOAD=$(filter $(FEDORA_31_ARCHES),$(FEDORA_31_ARCHES_CANDIDATES)) 1814ec49f0fSCleber Rosa 1824ec49f0fSCleber Rosa# download one specific Fedora 31 image 1834ec49f0fSCleber Rosaget-vm-image-fedora-31-%: check-venv 1844ec49f0fSCleber Rosa $(call quiet-command, \ 1854ec49f0fSCleber Rosa $(TESTS_VENV_DIR)/bin/python -m avocado vmimage get \ 1864ec49f0fSCleber Rosa --distro=fedora --distro-version=31 --arch=$*, \ 1874ec49f0fSCleber Rosa "AVOCADO", "Downloading acceptance tests VM image for $*") 1884ec49f0fSCleber Rosa 1894ec49f0fSCleber Rosa# download all vm images, according to defined targets 1904ec49f0fSCleber Rosaget-vm-images: check-venv $(patsubst %,get-vm-image-fedora-31-%, $(FEDORA_31_DOWNLOAD)) 1914ec49f0fSCleber Rosa 1924ec49f0fSCleber Rosacheck-acceptance: check-venv $(TESTS_RESULTS_DIR) get-vm-images 193a56931eeSCleber Rosa $(call quiet-command, \ 194a56931eeSCleber Rosa $(TESTS_VENV_DIR)/bin/python -m avocado \ 195a56931eeSCleber Rosa --show=$(AVOCADO_SHOW) run --job-results-dir=$(TESTS_RESULTS_DIR) \ 196b194713fSCleber Rosa --filter-by-tags-include-empty --filter-by-tags-include-empty-key \ 197b194713fSCleber Rosa $(AVOCADO_TAGS) \ 198c5008c76SAlex Bennée $(if $(GITLAB_CI),,--failfast=on) tests/acceptance, \ 199a56931eeSCleber Rosa "AVOCADO", "tests/acceptance") 200a56931eeSCleber Rosa 20146e7b706SFam Zheng# Consolidated targets 20246e7b706SFam Zheng 203*279588d4SMarc-André Lureau.PHONY: check-block check check-clean get-vm-images 204e781190cSPaolo Bonzinicheck: 205e781190cSPaolo Bonzini 206e781190cSPaolo Bonziniifeq ($(CONFIG_TOOLS)$(CONFIG_POSIX),yy) 207e781190cSPaolo BonziniQEMU_IOTESTS_HELPERS-$(CONFIG_LINUX) = tests/qemu-iotests/socket_scm_helper$(EXESUF) 208e781190cSPaolo Bonzinicheck: check-block 209e781190cSPaolo Bonzinicheck-block: $(SRC_PATH)/tests/check-block.sh qemu-img$(EXESUF) \ 210e781190cSPaolo Bonzini qemu-io$(EXESUF) qemu-nbd$(EXESUF) $(QEMU_IOTESTS_HELPERS-y) \ 211e781190cSPaolo Bonzini $(patsubst %-softmmu,qemu-system-%,$(filter %-softmmu,$(TARGET_DIRS))) 212e781190cSPaolo Bonzini @$< 213e781190cSPaolo Bonziniendif 214e781190cSPaolo Bonzini 215*279588d4SMarc-André Lureaucheck-build: $(QEMU_IOTESTS_HELPERS-y) 216a6eeac3bSAlex Bennée 21746e7b706SFam Zhengcheck-clean: 218*279588d4SMarc-André Lureau rm -rf tests/*.o tests/*/*.o $(QEMU_IOTESTS_HELPERS-y) 219a56931eeSCleber Rosa rm -rf $(TESTS_VENV_DIR) $(TESTS_RESULTS_DIR) 22046e7b706SFam Zheng 22146e7b706SFam Zhengclean: check-clean 22246e7b706SFam Zheng 22346e7b706SFam Zheng# Build the help program automatically 22446e7b706SFam Zheng 22546e7b706SFam Zheng-include $(wildcard tests/*.d) 226e45eaef9SFam Zheng 227e45eaef9SFam Zhengendif 228