mirror of
https://github.com/Motorhead1991/qemu.git
synced 2026-01-03 05:00:31 -07:00
This test was using cloudinit and a "dnf install" command in the guest to exercise the NIC with SMMU enabled. Since we don't have the cloudinit stuff in the functional framework and we should not rely on having access to external networks (once our ASSETs have been cached), we rather boot into the initrd first, manually mount the root disk and then use the check_http_download() function from the functional framework here instead for testing whether the network works as expected. Unfortunately, there seems to be a small race when using the files from Fedora 33: To enter the initrd shell, we have to send a "return" once. But it does not seem to work if we send it too early. Using a sleep(0.2) makes it work reliably for me, but to make it even more unlikely to trigger this situation, let's better limit the Fedora 33 tests to only run with KVM. Finally, while we're at it, we also add some lines for testing writes to the hard disk, as we already do it in the test_intel_iommu test. Reviewed-by: Eric Auger <eric.auger@redhat.com> Tested-by: Eric Auger <eric.auger@redhat.com> Message-ID: <20250414113031.151105-14-thuth@redhat.com> Signed-off-by: Thomas Huth <thuth@redhat.com>
412 lines
9 KiB
Meson
412 lines
9 KiB
Meson
# QEMU functional tests:
|
|
# Tests that are put in the 'quick' category are run by default during
|
|
# 'make check'. Everything that should not be run during 'make check'
|
|
# (e.g. tests that fetch assets from the internet) should be put into
|
|
# the 'thorough' category instead.
|
|
|
|
# Most tests run too slow with TCI enabled, so skip the functional tests there
|
|
if get_option('tcg_interpreter')
|
|
subdir_done()
|
|
endif
|
|
|
|
# Timeouts for individual tests that can be slow e.g. with debugging enabled
|
|
test_timeouts = {
|
|
'aarch64_aspeed' : 600,
|
|
'aarch64_raspi4' : 480,
|
|
'aarch64_reverse_debug' : 180,
|
|
'aarch64_rme_virt' : 1200,
|
|
'aarch64_rme_sbsaref' : 1200,
|
|
'aarch64_sbsaref_alpine' : 1200,
|
|
'aarch64_sbsaref_freebsd' : 720,
|
|
'aarch64_smmu' : 720,
|
|
'aarch64_tuxrun' : 240,
|
|
'aarch64_virt' : 360,
|
|
'aarch64_virt_gpu' : 480,
|
|
'acpi_bits' : 420,
|
|
'arm_aspeed_palmetto' : 120,
|
|
'arm_aspeed_romulus' : 120,
|
|
'arm_aspeed_witherspoon' : 120,
|
|
'arm_aspeed_ast2500' : 720,
|
|
'arm_aspeed_ast2600' : 1200,
|
|
'arm_aspeed_bletchley' : 480,
|
|
'arm_aspeed_rainier' : 480,
|
|
'arm_bpim2u' : 500,
|
|
'arm_collie' : 180,
|
|
'arm_cubieboard' : 360,
|
|
'arm_orangepi' : 540,
|
|
'arm_quanta_gsj' : 240,
|
|
'arm_raspi2' : 120,
|
|
'arm_replay' : 240,
|
|
'arm_tuxrun' : 240,
|
|
'arm_sx1' : 360,
|
|
'intel_iommu': 300,
|
|
'mips_malta' : 480,
|
|
'mipsel_malta' : 420,
|
|
'mipsel_replay' : 480,
|
|
'mips64_malta' : 240,
|
|
'mips64el_malta' : 420,
|
|
'mips64el_replay' : 180,
|
|
'netdev_ethtool' : 180,
|
|
'ppc_40p' : 240,
|
|
'ppc64_hv' : 1000,
|
|
'ppc64_powernv' : 480,
|
|
'ppc64_pseries' : 480,
|
|
'ppc64_replay' : 210,
|
|
'ppc64_tuxrun' : 420,
|
|
'ppc64_mac99' : 120,
|
|
'riscv64_tuxrun' : 120,
|
|
's390x_ccw_virtio' : 420,
|
|
'sh4_tuxrun' : 240,
|
|
'virtio_balloon': 120,
|
|
'x86_64_kvm_xen' : 180,
|
|
'x86_64_replay' : 480,
|
|
}
|
|
|
|
tests_generic_system = [
|
|
'empty_cpu_model',
|
|
'info_usernet',
|
|
'version',
|
|
]
|
|
|
|
tests_generic_linuxuser = [
|
|
]
|
|
|
|
tests_generic_bsduser = [
|
|
]
|
|
|
|
tests_aarch64_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_aarch64_system_thorough = [
|
|
'aarch64_aspeed',
|
|
'aarch64_raspi3',
|
|
'aarch64_raspi4',
|
|
'aarch64_replay',
|
|
'aarch64_reverse_debug',
|
|
'aarch64_rme_virt',
|
|
'aarch64_rme_sbsaref',
|
|
'aarch64_sbsaref',
|
|
'aarch64_sbsaref_alpine',
|
|
'aarch64_sbsaref_freebsd',
|
|
'aarch64_smmu',
|
|
'aarch64_tcg_plugins',
|
|
'aarch64_tuxrun',
|
|
'aarch64_virt',
|
|
'aarch64_virt_gpu',
|
|
'aarch64_xen',
|
|
'aarch64_xlnx_versal',
|
|
'multiprocess',
|
|
]
|
|
|
|
tests_alpha_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_alpha_system_thorough = [
|
|
'alpha_clipper',
|
|
'alpha_replay',
|
|
]
|
|
|
|
tests_arm_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_arm_system_thorough = [
|
|
'arm_aspeed_ast1030',
|
|
'arm_aspeed_palmetto',
|
|
'arm_aspeed_romulus',
|
|
'arm_aspeed_witherspoon',
|
|
'arm_aspeed_ast2500',
|
|
'arm_aspeed_ast2600',
|
|
'arm_aspeed_bletchley',
|
|
'arm_aspeed_rainier',
|
|
'arm_bpim2u',
|
|
'arm_canona1100',
|
|
'arm_collie',
|
|
'arm_cubieboard',
|
|
'arm_emcraft_sf2',
|
|
'arm_integratorcp',
|
|
'arm_microbit',
|
|
'arm_orangepi',
|
|
'arm_quanta_gsj',
|
|
'arm_raspi2',
|
|
'arm_replay',
|
|
'arm_smdkc210',
|
|
'arm_sx1',
|
|
'arm_vexpress',
|
|
'arm_virt',
|
|
'arm_tuxrun',
|
|
]
|
|
|
|
tests_arm_linuxuser_thorough = [
|
|
'arm_bflt',
|
|
]
|
|
|
|
tests_avr_system_thorough = [
|
|
'avr_mega2560',
|
|
]
|
|
|
|
tests_hppa_system_quick = [
|
|
'hppa_seabios',
|
|
]
|
|
|
|
tests_i386_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_i386_system_thorough = [
|
|
'i386_replay',
|
|
'i386_tuxrun',
|
|
]
|
|
|
|
tests_loongarch64_system_thorough = [
|
|
'loongarch64_virt',
|
|
]
|
|
|
|
tests_m68k_system_thorough = [
|
|
'm68k_mcf5208evb',
|
|
'm68k_nextcube',
|
|
'm68k_replay',
|
|
'm68k_q800',
|
|
'm68k_tuxrun',
|
|
]
|
|
|
|
tests_microblaze_system_thorough = [
|
|
'microblaze_replay',
|
|
'microblaze_s3adsp1800'
|
|
]
|
|
|
|
tests_microblazeel_system_thorough = [
|
|
'microblazeel_s3adsp1800'
|
|
]
|
|
|
|
tests_mips_system_thorough = [
|
|
'mips_malta',
|
|
'mips_replay',
|
|
'mips_tuxrun',
|
|
]
|
|
|
|
tests_mipsel_system_thorough = [
|
|
'mipsel_malta',
|
|
'mipsel_replay',
|
|
'mipsel_tuxrun',
|
|
]
|
|
|
|
tests_mips64_system_thorough = [
|
|
'mips64_malta',
|
|
'mips64_tuxrun',
|
|
]
|
|
|
|
tests_mips64el_system_thorough = [
|
|
'mips64el_fuloong2e',
|
|
'mips64el_loongson3v',
|
|
'mips64el_malta',
|
|
'mips64el_replay',
|
|
'mips64el_tuxrun',
|
|
]
|
|
|
|
tests_or1k_system_thorough = [
|
|
'or1k_replay',
|
|
'or1k_sim',
|
|
]
|
|
|
|
tests_ppc_system_quick = [
|
|
'migration',
|
|
'ppc_74xx',
|
|
]
|
|
|
|
tests_ppc_system_thorough = [
|
|
'ppc_40p',
|
|
'ppc_amiga',
|
|
'ppc_bamboo',
|
|
'ppc_mac',
|
|
'ppc_mpc8544ds',
|
|
'ppc_replay',
|
|
'ppc_sam460ex',
|
|
'ppc_tuxrun',
|
|
'ppc_virtex_ml507',
|
|
]
|
|
|
|
tests_ppc64_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_ppc64_system_thorough = [
|
|
'ppc64_e500',
|
|
'ppc64_hv',
|
|
'ppc64_powernv',
|
|
'ppc64_pseries',
|
|
'ppc64_replay',
|
|
'ppc64_reverse_debug',
|
|
'ppc64_tuxrun',
|
|
'ppc64_mac99',
|
|
]
|
|
|
|
tests_riscv32_system_quick = [
|
|
'migration',
|
|
'riscv_opensbi',
|
|
]
|
|
|
|
tests_riscv32_system_thorough = [
|
|
'riscv32_tuxrun',
|
|
]
|
|
|
|
tests_riscv64_system_quick = [
|
|
'migration',
|
|
'riscv_opensbi',
|
|
]
|
|
|
|
tests_riscv64_system_thorough = [
|
|
'riscv64_tuxrun',
|
|
]
|
|
|
|
tests_rx_system_thorough = [
|
|
'rx_gdbsim',
|
|
]
|
|
|
|
tests_s390x_system_thorough = [
|
|
's390x_ccw_virtio',
|
|
's390x_replay',
|
|
's390x_topology',
|
|
's390x_tuxrun',
|
|
]
|
|
|
|
tests_sh4_system_thorough = [
|
|
'sh4_r2d',
|
|
'sh4_tuxrun',
|
|
]
|
|
|
|
tests_sh4eb_system_thorough = [
|
|
'sh4eb_r2d',
|
|
]
|
|
|
|
tests_sparc_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_sparc_system_thorough = [
|
|
'sparc_replay',
|
|
'sparc_sun4m',
|
|
]
|
|
|
|
tests_sparc64_system_quick = [
|
|
'migration',
|
|
]
|
|
|
|
tests_sparc64_system_thorough = [
|
|
'sparc64_sun4u',
|
|
'sparc64_tuxrun',
|
|
]
|
|
|
|
tests_x86_64_system_quick = [
|
|
'cpu_queries',
|
|
'mem_addr_space',
|
|
'migration',
|
|
'pc_cpu_hotplug_props',
|
|
'virtio_version',
|
|
'x86_cpu_model_versions',
|
|
'vnc',
|
|
]
|
|
|
|
tests_x86_64_system_thorough = [
|
|
'acpi_bits',
|
|
'intel_iommu',
|
|
'linux_initrd',
|
|
'multiprocess',
|
|
'netdev_ethtool',
|
|
'virtio_balloon',
|
|
'virtio_gpu',
|
|
'x86_64_hotplug_blk',
|
|
'x86_64_hotplug_cpu',
|
|
'x86_64_kvm_xen',
|
|
'x86_64_replay',
|
|
'x86_64_reverse_debug',
|
|
'x86_64_tuxrun',
|
|
]
|
|
|
|
tests_xtensa_system_thorough = [
|
|
'xtensa_lx60',
|
|
'xtensa_replay',
|
|
]
|
|
|
|
precache_all = []
|
|
foreach speed : ['quick', 'thorough']
|
|
foreach dir : target_dirs
|
|
|
|
target_base = dir.split('-')[0]
|
|
|
|
if dir.endswith('-softmmu')
|
|
sysmode = 'system'
|
|
test_emulator = emulators['qemu-system-' + target_base]
|
|
elif dir.endswith('-linux-user')
|
|
sysmode = 'linuxuser'
|
|
test_emulator = emulators['qemu-' + target_base]
|
|
elif dir.endswith('-bsd-user')
|
|
sysmode = 'bsduser'
|
|
test_emulator = emulators['qemu-' + target_base]
|
|
else
|
|
continue
|
|
endif
|
|
|
|
if speed == 'quick'
|
|
suites = ['func-quick', 'func-' + target_base]
|
|
target_tests = get_variable('tests_' + target_base + '_' + sysmode + '_quick', []) \
|
|
+ get_variable('tests_generic_' + sysmode)
|
|
else
|
|
suites = ['func-' + speed, 'func-' + target_base + '-' + speed, speed]
|
|
target_tests = get_variable('tests_' + target_base + '_' + sysmode + '_' + speed, [])
|
|
endif
|
|
|
|
test_deps = roms
|
|
test_env = environment()
|
|
if have_tools
|
|
test_env.set('QEMU_TEST_QEMU_IMG', meson.global_build_root() / 'qemu-img')
|
|
test_deps += [qemu_img]
|
|
endif
|
|
test_env.set('QEMU_TEST_QEMU_BINARY', test_emulator.full_path())
|
|
test_env.set('QEMU_BUILD_ROOT', meson.project_build_root())
|
|
test_env.set('PYTHONPATH', meson.project_source_root() / 'python:' +
|
|
meson.current_source_dir())
|
|
|
|
foreach test : target_tests
|
|
testname = '@0@-@1@'.format(target_base, test)
|
|
testfile = 'test_' + test + '.py'
|
|
testpath = meson.current_source_dir() / testfile
|
|
teststamp = testname + '.tstamp'
|
|
test_precache_env = environment()
|
|
test_precache_env.set('QEMU_TEST_PRECACHE', meson.current_build_dir() / teststamp)
|
|
test_precache_env.set('PYTHONPATH', meson.project_source_root() / 'python:' +
|
|
meson.current_source_dir())
|
|
precache = custom_target('func-precache-' + testname,
|
|
output: teststamp,
|
|
command: [python, testpath],
|
|
depend_files: files(testpath),
|
|
build_by_default: false,
|
|
env: test_precache_env)
|
|
precache_all += precache
|
|
|
|
# Ideally we would add 'precache' to 'depends' here, such that
|
|
# 'build_by_default: false' lets the pre-caching automatically
|
|
# run immediately before the test runs. In practice this is
|
|
# broken in meson, with it running the pre-caching in the normal
|
|
# compile phase https://github.com/mesonbuild/meson/issues/2518
|
|
# If the above bug ever gets fixed, when QEMU changes the min
|
|
# meson version, add the 'depends' and remove the custom
|
|
# 'run_target' logic below & in Makefile.include
|
|
test('func-' + testname,
|
|
python,
|
|
depends: [test_deps, test_emulator, emulator_modules, plugin_modules],
|
|
env: test_env,
|
|
args: [testpath],
|
|
protocol: 'tap',
|
|
timeout: test_timeouts.get(test, 90),
|
|
priority: test_timeouts.get(test, 90),
|
|
suite: suites)
|
|
endforeach
|
|
endforeach
|
|
endforeach
|
|
|
|
run_target('precache-functional',
|
|
depends: precache_all,
|
|
command: ['true'])
|