blob: 3a0524ce740b2437af0e27743de6373b6788d246 [file] [log] [blame]
Markus Armbruster3b8593e2019-05-28 10:23:07 +02001# -*- Mode: makefile -*-
Fam Zhenge45eaef2017-08-10 16:50:25 +08002
3.PHONY: check-help
4check-help:
5 @echo "Regression testing targets:"
6 @echo
Huacai Chen9865f392020-05-05 18:24:51 +08007 @echo " $(MAKE) check Run block, qapi-schema, unit, softfloat, qtest and decodetree tests"
Cleber Rosa54f96b42018-11-09 10:07:10 -05008 @echo
Philippe Mathieu-Daudéb98a3ba2017-11-21 06:55:10 -03009 @echo " $(MAKE) check-qtest-TARGET Run qtest tests for given target"
10 @echo " $(MAKE) check-qtest Run qtest tests"
11 @echo " $(MAKE) check-unit Run qobject tests"
12 @echo " $(MAKE) check-speed Run qobject speed tests"
13 @echo " $(MAKE) check-qapi-schema Run QAPI schema tests"
14 @echo " $(MAKE) check-block Run block tests"
Philippe Mathieu-Daudéca6db462020-05-22 19:25:00 +020015ifeq ($(CONFIG_TCG),y)
Alex Bennée8ba0a822018-04-06 22:08:36 +010016 @echo " $(MAKE) check-tcg Run TCG tests"
Alex Bennée76170102019-01-07 17:25:44 +000017 @echo " $(MAKE) check-softfloat Run FPU emulation tests"
Philippe Mathieu-Daudéca6db462020-05-22 19:25:00 +020018endif
Cleber Rosaa56931e2018-10-18 11:31:33 -040019 @echo " $(MAKE) check-acceptance Run all acceptance (functional) tests"
Cleber Rosa54f96b42018-11-09 10:07:10 -050020 @echo
Wainer dos Santos Moschettac3088cd2019-12-11 15:44:27 -050021 @echo " $(MAKE) check-report.tap Generates an aggregated TAP test report"
Cleber Rosa21313722018-10-18 11:31:32 -040022 @echo " $(MAKE) check-venv Creates a Python venv for tests"
Cleber Rosa54f96b42018-11-09 10:07:10 -050023 @echo " $(MAKE) check-clean Clean the tests and related data"
Fam Zhenge45eaef2017-08-10 16:50:25 +080024 @echo
Alex Bennéea6eeac32020-07-01 14:56:51 +010025 @echo "The following are useful for CI builds"
26 @echo " $(MAKE) check-build Build most test binaris"
Cleber Rosa4ec49f02020-03-17 10:16:54 -040027 @echo " $(MAKE) get-vm-images Downloads all images used by acceptance tests, according to configured targets (~350 MB each, 1.5 GB max)"
28 @echo
Fam Zhenge45eaef2017-08-10 16:50:25 +080029 @echo
30 @echo "The variable SPEED can be set to control the gtester speed setting."
Philippe Mathieu-Daudéb98a3ba2017-11-21 06:55:10 -030031 @echo "Default options are -k and (for $(MAKE) V=1) --verbose; they can be"
Fam Zhenge45eaef2017-08-10 16:50:25 +080032 @echo "changed with variable GTESTER_OPTIONS."
33
34ifneq ($(wildcard config-host.mak),)
Kevin Wolf89594492012-03-08 12:29:00 +010035export SRC_PATH
36
Peter Maydell3687d532014-01-23 16:22:59 +000037# Get the list of all supported sysemu targets
38SYSEMU_TARGET_LIST := $(subst -softmmu.mak,,$(notdir \
39 $(wildcard $(SRC_PATH)/default-configs/*-softmmu.mak)))
40
Paolo Bonzinib93b63f2012-03-28 15:42:01 +020041SPEED = quick
Anthony Liguoridbfe06c2012-01-10 13:10:43 -060042
Alex Bennée8ba0a822018-04-06 22:08:36 +010043# Per guest TCG tests
44
Alex Bennéee24e66f2018-11-29 22:21:50 +000045BUILD_TCG_TARGET_RULES=$(patsubst %,build-tcg-tests-%, $(TARGET_DIRS))
46CLEAN_TCG_TARGET_RULES=$(patsubst %,clean-tcg-tests-%, $(TARGET_DIRS))
47RUN_TCG_TARGET_RULES=$(patsubst %,run-tcg-tests-%, $(TARGET_DIRS))
Alex Bennée8ba0a822018-04-06 22:08:36 +010048
Alex Bennée1a7fab92018-06-08 12:12:46 +010049# Probe for the Docker Builds needed for each build
Alex Bennée2b1f35b2018-07-04 07:30:11 +010050$(foreach PROBE_TARGET,$(TARGET_DIRS), \
Paolo Bonzinifc76c562019-08-07 16:35:22 +020051 $(eval -include $(SRC_PATH)/tests/tcg/Makefile.prereqs))
Alex Bennée1a7fab92018-06-08 12:12:46 +010052
Paolo Bonzini8c17b842020-10-03 03:00:46 -040053$(BUILD_TCG_TARGET_RULES): build-tcg-tests-%: $(if $(CONFIG_PLUGIN),test-plugins)
Paolo Bonzinifc76c562019-08-07 16:35:22 +020054 $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \
55 -f $(SRC_PATH)/tests/tcg/Makefile.qemu \
56 SRC_PATH=$(SRC_PATH) \
Paolo Bonzini2038f8c2019-08-07 16:35:23 +020057 V="$(V)" TARGET="$*" guest-tests, \
Alex Bennéecff54772018-06-15 19:20:55 +010058 "BUILD", "TCG tests for $*")
Alex Bennée8ba0a822018-04-06 22:08:36 +010059
Paolo Bonzini8c17b842020-10-03 03:00:46 -040060$(RUN_TCG_TARGET_RULES): run-tcg-tests-%: build-tcg-tests-% all
Paolo Bonzinifc76c562019-08-07 16:35:22 +020061 $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \
62 -f $(SRC_PATH)/tests/tcg/Makefile.qemu \
63 SRC_PATH=$(SRC_PATH) SPEED="$(SPEED)" \
Paolo Bonzini2038f8c2019-08-07 16:35:23 +020064 V="$(V)" TARGET="$*" run-guest-tests, \
Alex Bennéecff54772018-06-15 19:20:55 +010065 "RUN", "TCG tests for $*")
Alex Bennée8ba0a822018-04-06 22:08:36 +010066
Paolo Bonzini8c17b842020-10-03 03:00:46 -040067$(CLEAN_TCG_TARGET_RULES): clean-tcg-tests-%:
Paolo Bonzinifc76c562019-08-07 16:35:22 +020068 $(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \
69 -f $(SRC_PATH)/tests/tcg/Makefile.qemu \
Paolo Bonzini2038f8c2019-08-07 16:35:23 +020070 SRC_PATH=$(SRC_PATH) TARGET="$*" clean-guest-tests, \
Alex Bennéedda60da2019-09-10 13:09:31 +010071 "CLEAN", "TCG tests for $*")
Alex Bennée8ba0a822018-04-06 22:08:36 +010072
73.PHONY: build-tcg
74build-tcg: $(BUILD_TCG_TARGET_RULES)
75
76.PHONY: check-tcg
Alex Bennéedf2bb382019-02-28 10:15:29 +000077check-tcg: $(RUN_TCG_TARGET_RULES)
Alex Bennée8ba0a822018-04-06 22:08:36 +010078
79.PHONY: clean-tcg
80clean-tcg: $(CLEAN_TCG_TARGET_RULES)
Kevin Wolfb8c6f292012-03-09 13:37:40 +010081
Cleber Rosa21313722018-10-18 11:31:32 -040082# Python venv for running tests
83
Cleber Rosaa56931e2018-10-18 11:31:33 -040084.PHONY: check-venv check-acceptance
Cleber Rosa21313722018-10-18 11:31:32 -040085
86TESTS_VENV_DIR=$(BUILD_DIR)/tests/venv
87TESTS_VENV_REQ=$(SRC_PATH)/tests/requirements.txt
Cleber Rosaa56931e2018-10-18 11:31:33 -040088TESTS_RESULTS_DIR=$(BUILD_DIR)/tests/results
89# Controls the output generated by Avocado when running tests.
90# Any number of command separated loggers are accepted. For more
91# information please refer to "avocado --help".
Cleber Rosa59692a12019-03-12 13:18:05 -040092AVOCADO_SHOW=app
Cleber Rosab1947132019-03-12 13:18:09 -040093AVOCADO_TAGS=$(patsubst %-softmmu,-t arch:%, $(filter %-softmmu,$(TARGET_DIRS)))
Cleber Rosa21313722018-10-18 11:31:32 -040094
Cleber Rosa21313722018-10-18 11:31:32 -040095$(TESTS_VENV_DIR): $(TESTS_VENV_REQ)
96 $(call quiet-command, \
97 $(PYTHON) -m venv --system-site-packages $@, \
98 VENV, $@)
99 $(call quiet-command, \
100 $(TESTS_VENV_DIR)/bin/python -m pip -q install -r $(TESTS_VENV_REQ), \
101 PIP, $(TESTS_VENV_REQ))
102 $(call quiet-command, touch $@)
Cleber Rosa21313722018-10-18 11:31:32 -0400103
Cleber Rosaa56931e2018-10-18 11:31:33 -0400104$(TESTS_RESULTS_DIR):
105 $(call quiet-command, mkdir -p $@, \
106 MKDIR, $@)
107
Cleber Rosa21313722018-10-18 11:31:32 -0400108check-venv: $(TESTS_VENV_DIR)
109
Cleber Rosa4ec49f02020-03-17 10:16:54 -0400110FEDORA_31_ARCHES_CANDIDATES=$(patsubst ppc64,ppc64le,$(TARGETS))
111FEDORA_31_ARCHES := x86_64 aarch64 ppc64le s390x
112FEDORA_31_DOWNLOAD=$(filter $(FEDORA_31_ARCHES),$(FEDORA_31_ARCHES_CANDIDATES))
113
114# download one specific Fedora 31 image
115get-vm-image-fedora-31-%: check-venv
116 $(call quiet-command, \
117 $(TESTS_VENV_DIR)/bin/python -m avocado vmimage get \
118 --distro=fedora --distro-version=31 --arch=$*, \
119 "AVOCADO", "Downloading acceptance tests VM image for $*")
120
121# download all vm images, according to defined targets
122get-vm-images: check-venv $(patsubst %,get-vm-image-fedora-31-%, $(FEDORA_31_DOWNLOAD))
123
124check-acceptance: check-venv $(TESTS_RESULTS_DIR) get-vm-images
Cleber Rosaa56931e2018-10-18 11:31:33 -0400125 $(call quiet-command, \
126 $(TESTS_VENV_DIR)/bin/python -m avocado \
127 --show=$(AVOCADO_SHOW) run --job-results-dir=$(TESTS_RESULTS_DIR) \
Cleber Rosab1947132019-03-12 13:18:09 -0400128 --filter-by-tags-include-empty --filter-by-tags-include-empty-key \
129 $(AVOCADO_TAGS) \
Pavel Dovgalyuk94b4ec22020-09-09 12:27:39 +0100130 $(if $(GITLAB_CI),,--failfast) tests/acceptance, \
Cleber Rosaa56931e2018-10-18 11:31:33 -0400131 "AVOCADO", "tests/acceptance")
132
Paolo Bonzinib93b63f2012-03-28 15:42:01 +0200133# Consolidated targets
134
Marc-André Lureau279588d2020-08-03 09:05:54 +0200135.PHONY: check-block check check-clean get-vm-images
Paolo Bonzinie7811902020-09-01 09:31:56 -0400136check:
137
138ifeq ($(CONFIG_TOOLS)$(CONFIG_POSIX),yy)
139QEMU_IOTESTS_HELPERS-$(CONFIG_LINUX) = tests/qemu-iotests/socket_scm_helper$(EXESUF)
140check: check-block
141check-block: $(SRC_PATH)/tests/check-block.sh qemu-img$(EXESUF) \
142 qemu-io$(EXESUF) qemu-nbd$(EXESUF) $(QEMU_IOTESTS_HELPERS-y) \
Paolo Bonzini09e93322020-08-13 09:28:11 -0400143 $(filter qemu-system-%, $(ninja-targets))
Paolo Bonzinie7811902020-09-01 09:31:56 -0400144 @$<
145endif
146
Marc-André Lureau279588d2020-08-03 09:05:54 +0200147check-build: $(QEMU_IOTESTS_HELPERS-y)
Alex Bennéea6eeac32020-07-01 14:56:51 +0100148
Wenchao Xia2cdfb122013-09-26 08:42:56 +0800149check-clean:
Cleber Rosaa56931e2018-10-18 11:31:33 -0400150 rm -rf $(TESTS_VENV_DIR) $(TESTS_RESULTS_DIR)
Wenchao Xia2cdfb122013-09-26 08:42:56 +0800151
152clean: check-clean
Eduardo Habkost14117c72012-07-18 14:22:27 -0300153
Paolo Bonzini9ed72472020-09-02 07:25:19 -0400154# For backwards compatibility
155
156check-speed: bench-speed
157
Fam Zhenge45eaef2017-08-10 16:50:25 +0800158endif