From nobody Sun Nov 24 15:28:46 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1722359237; cv=none; d=zohomail.com; s=zohoarc; b=OUqFoPB0UBgU7suyxZ9JVtszMhTE4l/5OtLveLLa6SUswJxqZ7A3N8Y9J1iaS5fm4t5wSf+JTJX9yFEC+Kl+ggMoHVpiqVd7MA/m3v+2PywURPyg6r/d1/lw/dtj2Wb5FOaMe6tOQeC+sQjAirZkYq6c+D6ftf/sTvbBQx1pK84= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1722359237; h=Content-Transfer-Encoding:Cc:Cc:Date:Date:From:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:Subject:To:To:Message-Id:Reply-To; bh=baatl9Ij+cw20DOWFnFSzkCppa+8l9s0cnbLVqDrLBI=; b=JHecUrV6yxErpq+Ls4aXIKL8wAKeh57xAkIm91KKcRC05bGDJGyb0l8dHcFOz2HXgcSX8qd21o5gLQiGl9veyL6aRtW4kB3scF/7IZJdyra6xuRVRMttJA/rbb/nuru+uK5Z5PbBJTOsnZxltBr6DfCJFUTy79+96XwMVzmkjdY= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1722359237026783.7500201042561; Tue, 30 Jul 2024 10:07:17 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1sYqHH-0000cF-K4; Tue, 30 Jul 2024 13:04:47 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1sYqHG-0000Wd-7M for qemu-devel@nongnu.org; Tue, 30 Jul 2024 13:04:46 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.129.124]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1sYqHD-0002R0-A5 for qemu-devel@nongnu.org; Tue, 30 Jul 2024 13:04:45 -0400 Received: from mx-prod-mc-03.mail-002.prod.us-west-2.aws.redhat.com (ec2-54-186-198-63.us-west-2.compute.amazonaws.com [54.186.198.63]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-265-U9NAyyLIPPaup5kS7qSavw-1; Tue, 30 Jul 2024 13:04:35 -0400 Received: from mx-prod-int-01.mail-002.prod.us-west-2.aws.redhat.com (mx-prod-int-01.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.4]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mx-prod-mc-03.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id 178431955D58; Tue, 30 Jul 2024 17:04:34 +0000 (UTC) Received: from toolbox.redhat.com (unknown [10.42.28.108]) by mx-prod-int-01.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTP id 621E13000197; Tue, 30 Jul 2024 17:04:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1722359082; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=baatl9Ij+cw20DOWFnFSzkCppa+8l9s0cnbLVqDrLBI=; b=MUbuhWgOIqO5wlUtgN8JIU02vj5XcgCL52rHAS4ns+FDJUlYx2Gge4H4msaRZh4unXEdKb HI9LtXAB/NUoxgPUVR7mqAXBcZ48TUT4TqpC+iXn7xqRIRmBEBeUwkcv0QHrulLG1OzQub 75Dxcto3avSzdq8dzdGOhOac4GYLo/A= X-MC-Unique: U9NAyyLIPPaup5kS7qSavw-1 From: =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= To: qemu-devel@nongnu.org Cc: Fabiano Rosas , Paolo Bonzini , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= , John Snow , qemu-ppc@nongnu.org, Richard Henderson , Ani Sinha , =?UTF-8?q?Alex=20Benn=C3=A9e?= , Thomas Huth Subject: [PATCH v3 10/24] tests/functional: Convert some tests that download files via fetch_asset() Date: Tue, 30 Jul 2024 18:03:30 +0100 Message-ID: <20240730170347.4103919-11-berrange@redhat.com> In-Reply-To: <20240730170347.4103919-1-berrange@redhat.com> References: <20240730170347.4103919-1-berrange@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Scanned-By: MIMEDefang 3.4.1 on 10.30.177.4 Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.129.124; envelope-from=berrange@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -21 X-Spam_score: -2.2 X-Spam_bar: -- X-Spam_report: (-2.2 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.125, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZohoMail-DKIM: pass (identity @redhat.com) X-ZM-MESSAGEID: 1722359237491116600 Content-Type: text/plain; charset="utf-8" From: Thomas Huth Now that we've got the Asset class with pre-caching, we can convert some Avocado tests that use fetch_asset() for downloading their required files. Signed-off-by: Thomas Huth --- MAINTAINERS | 12 ++--- tests/avocado/machine_mips_loongson3v.py | 39 --------------- tests/functional/meson.build | 22 ++++++++ .../test_arm_n8x0.py} | 36 ++++++------- .../test_avr_mega2560.py} | 22 ++++---- .../test_loongarch64_virt.py} | 46 +++++++++-------- tests/functional/test_mips64el_loongson3v.py | 39 +++++++++++++++ .../test_netdev_ethtool.py} | 50 +++++++------------ .../ppc_405.py =3D> functional/test_ppc_405.py} | 28 +++++------ 9 files changed, 154 insertions(+), 140 deletions(-) delete mode 100644 tests/avocado/machine_mips_loongson3v.py rename tests/{avocado/machine_arm_n8x0.py =3D> functional/test_arm_n8x0.py= } (51%) mode change 100644 =3D> 100755 rename tests/{avocado/machine_avr6.py =3D> functional/test_avr_mega2560.py= } (73%) mode change 100644 =3D> 100755 rename tests/{avocado/machine_loongarch.py =3D> functional/test_loongarch6= 4_virt.py} (54%) mode change 100644 =3D> 100755 create mode 100755 tests/functional/test_mips64el_loongson3v.py rename tests/{avocado/netdev-ethtool.py =3D> functional/test_netdev_ethtoo= l.py} (66%) mode change 100644 =3D> 100755 rename tests/{avocado/ppc_405.py =3D> functional/test_ppc_405.py} (53%) mode change 100644 =3D> 100755 diff --git a/MAINTAINERS b/MAINTAINERS index 98eddf7ae1..c2b4352edd 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -222,7 +222,7 @@ S: Maintained F: docs/system/target-avr.rst F: gdb-xml/avr-cpu.xml F: target/avr/ -F: tests/avocado/machine_avr6.py +F: tests/functional/test_avr_mega2560.py =20 CRIS TCG CPUs M: Edgar E. Iglesias @@ -265,7 +265,7 @@ M: Song Gao S: Maintained F: target/loongarch/ F: tests/tcg/loongarch64/ -F: tests/avocado/machine_loongarch.py +F: tests/functional/test_loongarch64_virt.py =20 M68K TCG CPUs M: Laurent Vivier @@ -884,7 +884,7 @@ F: include/hw/display/blizzard.h F: include/hw/input/lm832x.h F: include/hw/input/tsc2xxx.h F: include/hw/misc/cbus.h -F: tests/avocado/machine_arm_n8x0.py +F: tests/functional/test_arm_n8x0.py F: docs/system/arm/nseries.rst =20 Palm @@ -1393,7 +1393,7 @@ F: hw/mips/loongson3_bootp.h F: hw/mips/loongson3_virt.c F: include/hw/intc/loongson_ipi.h F: include/hw/intc/loongson_liointc.h -F: tests/avocado/machine_mips_loongson3v.py +F: tests/functional/test_mips64el_loongson3v.py =20 Boston M: Paul Burton @@ -1419,7 +1419,7 @@ PowerPC Machines L: qemu-ppc@nongnu.org S: Orphan F: hw/ppc/ppc405* -F: tests/avocado/ppc_405.py +F: tests/functional/test_ppc_405.py =20 Bamboo L: qemu-ppc@nongnu.org @@ -2486,7 +2486,7 @@ R: Sriram Yagnaraman S: Maintained F: docs/system/devices/igb.rst F: hw/net/igb* -F: tests/avocado/netdev-ethtool.py +F: tests/functional/test_netdev_ethtool.py F: tests/qtest/igb-test.c F: tests/qtest/libqos/igb.c =20 diff --git a/tests/avocado/machine_mips_loongson3v.py b/tests/avocado/machi= ne_mips_loongson3v.py deleted file mode 100644 index 5194cf18c9..0000000000 --- a/tests/avocado/machine_mips_loongson3v.py +++ /dev/null @@ -1,39 +0,0 @@ -# Functional tests for the Generic Loongson-3 Platform. -# -# Copyright (c) 2021 Jiaxun Yang -# -# This work is licensed under the terms of the GNU GPL, version 2 or later. -# See the COPYING file in the top-level directory. -# -# SPDX-License-Identifier: GPL-2.0-or-later - -import os -import time - -from avocado import skipUnless -from avocado_qemu import QemuSystemTest -from avocado_qemu import wait_for_console_pattern - -class MipsLoongson3v(QemuSystemTest): - timeout =3D 60 - - @skipUnless(os.getenv('AVOCADO_ALLOW_UNTRUSTED_CODE'), 'untrusted code= ') - def test_pmon_serial_console(self): - """ - :avocado: tags=3Darch:mips64el - :avocado: tags=3Dendian:little - :avocado: tags=3Dmachine:loongson3-virt - :avocado: tags=3Dcpu:Loongson-3A1000 - :avocado: tags=3Ddevice:liointc - :avocado: tags=3Ddevice:goldfish_rtc - """ - - pmon_hash =3D '7c8b45dd81ccfc55ff28f5aa267a41c3' - pmon_path =3D self.fetch_asset('https://github.com/loongson-commun= ity/pmon/' - 'releases/download/20210112/pmon-3avir= t.bin', - asset_hash=3Dpmon_hash, algorithm=3D'= md5') - - self.vm.set_console() - self.vm.add_args('-bios', pmon_path) - self.vm.launch() - wait_for_console_pattern(self, 'CPU GODSON3 BogoMIPS:') diff --git a/tests/functional/meson.build b/tests/functional/meson.build index cef74b82a9..32c7cc2d3c 100644 --- a/tests/functional/meson.build +++ b/tests/functional/meson.build @@ -11,6 +11,7 @@ endif =20 # Timeouts for individual tests that can be slow e.g. with debugging enabl= ed test_timeouts =3D { + 'netdev_ethtool' : 180, } =20 tests_generic =3D [ @@ -19,10 +20,30 @@ tests_generic =3D [ 'version', ] =20 +tests_arm_thorough =3D [ + 'arm_n8x0', +] + +tests_avr_thorough =3D [ + 'avr_mega2560', +] + +tests_loongarch64_thorough =3D [ + 'loongarch64_virt', +] + +tests_mips64el_thorough =3D [ + 'mips64el_loongson3v', +] + tests_ppc_quick =3D [ 'ppc_74xx', ] =20 +tests_ppc_thorough =3D [ + 'ppc_405', +] + tests_x86_64_quick =3D [ 'cpu_queries', 'mem_addr_space', @@ -31,6 +52,7 @@ tests_x86_64_quick =3D [ ] =20 tests_x86_64_thorough =3D [ + 'netdev_ethtool', ] =20 precache_all =3D [] diff --git a/tests/avocado/machine_arm_n8x0.py b/tests/functional/test_arm_= n8x0.py old mode 100644 new mode 100755 similarity index 51% rename from tests/avocado/machine_arm_n8x0.py rename to tests/functional/test_arm_n8x0.py index 12e9a6803b..5dc473f66f --- a/tests/avocado/machine_arm_n8x0.py +++ b/tests/functional/test_arm_n8x0.py @@ -1,3 +1,5 @@ +#!/usr/bin/env python3 +# # Functional test that boots a Linux kernel and checks the console # # Copyright (c) 2020 Red Hat, Inc. @@ -10,21 +12,22 @@ =20 import os =20 -from avocado import skipUnless -from avocado_qemu import QemuSystemTest -from avocado_qemu import wait_for_console_pattern +from unittest import skipUnless +from qemu_test import QemuSystemTest, Asset +from qemu_test import wait_for_console_pattern =20 class N8x0Machine(QemuSystemTest): """Boots the Linux kernel and checks that the console is operational""" =20 timeout =3D 90 =20 + ASSET_KERNEL =3D Asset(('http://stskeeps.subnetmask.net/meego-n8x0/' + 'meego-arm-n8x0-1.0.80.20100712.1431-' + 'vmlinuz-2.6.35~rc4-129.1-n8x0'), + 'e9d5ab8d7548923a0061b6fbf601465e479ed269') + def __do_test_n8x0(self): - kernel_url =3D ('http://stskeeps.subnetmask.net/meego-n8x0/' - 'meego-arm-n8x0-1.0.80.20100712.1431-' - 'vmlinuz-2.6.35~rc4-129.1-n8x0') - kernel_hash =3D 'e9d5ab8d7548923a0061b6fbf601465e479ed269' - kernel_path =3D self.fetch_asset(kernel_url, asset_hash=3Dkernel_h= ash) + kernel_path =3D self.ASSET_KERNEL.fetch() =20 self.vm.set_console(console_index=3D1) self.vm.add_args('-kernel', kernel_path, @@ -32,18 +35,15 @@ def __do_test_n8x0(self): self.vm.launch() wait_for_console_pattern(self, 'TSC2005 driver initializing') =20 - @skipUnless(os.getenv('AVOCADO_ALLOW_UNTRUSTED_CODE'), 'untrusted code= ') + @skipUnless(os.getenv('QEMU_TEST_ALLOW_UNTRUSTED_CODE'), 'untrusted co= de') def test_n800(self): - """ - :avocado: tags=3Darch:arm - :avocado: tags=3Dmachine:n800 - """ + self.set_machine('n800') self.__do_test_n8x0() =20 - @skipUnless(os.getenv('AVOCADO_ALLOW_UNTRUSTED_CODE'), 'untrusted code= ') + @skipUnless(os.getenv('QEMU_TEST_ALLOW_UNTRUSTED_CODE'), 'untrusted co= de') def test_n810(self): - """ - :avocado: tags=3Darch:arm - :avocado: tags=3Dmachine:n810 - """ + self.set_machine('n810') self.__do_test_n8x0() + +if __name__ =3D=3D '__main__': + QemuSystemTest.main() diff --git a/tests/avocado/machine_avr6.py b/tests/functional/test_avr_mega= 2560.py old mode 100644 new mode 100755 similarity index 73% rename from tests/avocado/machine_avr6.py rename to tests/functional/test_avr_mega2560.py index 5485db79c6..a2d026e03a --- a/tests/avocado/machine_avr6.py +++ b/tests/functional/test_avr_mega2560.py @@ -1,3 +1,4 @@ +#!/usr/bin/env python3 # # QEMU AVR integration tests # @@ -19,26 +20,24 @@ =20 import time =20 -from avocado_qemu import QemuSystemTest +from qemu_test import QemuSystemTest, Asset =20 class AVR6Machine(QemuSystemTest): timeout =3D 5 =20 + ASSET_ROM =3D Asset(('https://github.com/seharris/qemu-avr-tests' + '/raw/36c3e67b8755dcf/free-rtos/Demo' + '/AVR_ATMega2560_GCC/demo.elf'), + '7eb521f511ca8f2622e0a3c5e8dd686efbb911d4') + def test_freertos(self): - """ - :avocado: tags=3Darch:avr - :avocado: tags=3Dmachine:arduino-mega-2560-v3 - """ """ https://github.com/seharris/qemu-avr-tests/raw/master/free-rtos/De= mo/AVR_ATMega2560_GCC/demo.elf constantly prints out 'ABCDEFGHIJKLMNOPQRSTUVWXABCDEFGHIJKLMNOPQRS= TUVWX' """ - rom_url =3D ('https://github.com/seharris/qemu-avr-tests' - '/raw/36c3e67b8755dcf/free-rtos/Demo' - '/AVR_ATMega2560_GCC/demo.elf') - rom_hash =3D '7eb521f511ca8f2622e0a3c5e8dd686efbb911d4' - rom_path =3D self.fetch_asset(rom_url, asset_hash=3Drom_hash) + rom_path =3D self.ASSET_ROM.fetch() =20 + self.set_machine('arduino-mega-2560-v3') self.vm.add_args('-bios', rom_path) self.vm.add_args('-nographic') self.vm.launch() @@ -48,3 +47,6 @@ def test_freertos(self): =20 self.assertIn('ABCDEFGHIJKLMNOPQRSTUVWXABCDEFGHIJKLMNOPQRSTUVWX', self.vm.get_log()) + +if __name__ =3D=3D '__main__': + QemuSystemTest.main() diff --git a/tests/avocado/machine_loongarch.py b/tests/functional/test_loo= ngarch64_virt.py old mode 100644 new mode 100755 similarity index 54% rename from tests/avocado/machine_loongarch.py rename to tests/functional/test_loongarch64_virt.py index 8de308f2d6..fb9329e486 --- a/tests/avocado/machine_loongarch.py +++ b/tests/functional/test_loongarch64_virt.py @@ -1,3 +1,5 @@ +#!/usr/bin/env python3 +# # SPDX-License-Identifier: GPL-2.0-or-later # # LoongArch virt test. @@ -5,15 +7,28 @@ # Copyright (c) 2023 Loongson Technology Corporation Limited # =20 -from avocado_qemu import QemuSystemTest -from avocado_qemu import exec_command_and_wait_for_pattern -from avocado_qemu import wait_for_console_pattern +from qemu_test import QemuSystemTest, Asset +from qemu_test import exec_command_and_wait_for_pattern +from qemu_test import wait_for_console_pattern =20 class LoongArchMachine(QemuSystemTest): KERNEL_COMMON_COMMAND_LINE =3D 'printk.time=3D0 ' =20 timeout =3D 120 =20 + ASSET_KERNEL =3D Asset( + ('https://github.com/yangxiaojuan-loongson/qemu-binary/' + 'releases/download/2024-05-30/vmlinuz.efi'), + '951b485b16e3788b6db03a3e1793c067009e31a2') + ASSET_INITRD =3D Asset( + ('https://github.com/yangxiaojuan-loongson/qemu-binary/' + 'releases/download/2024-05-30/ramdisk'), + 'c67658d9b2a447ce7db2f73ba3d373c9b2b90ab2') + ASSET_BIOS =3D Asset( + ('https://github.com/yangxiaojuan-loongson/qemu-binary/' + 'releases/download/2024-05-30/QEMU_EFI.fd'), + 'f4d0966b5117d4cd82327c050dd668741046be69') + def wait_for_console_pattern(self, success_message, vm=3DNone): wait_for_console_pattern(self, success_message, failure_message=3D'Kernel panic - not syn= cing', @@ -21,25 +36,11 @@ def wait_for_console_pattern(self, success_message, vm= =3DNone): =20 def test_loongarch64_devices(self): =20 - """ - :avocado: tags=3Darch:loongarch64 - :avocado: tags=3Dmachine:virt - """ - - kernel_url =3D ('https://github.com/yangxiaojuan-loongson/qemu-bin= ary/' - 'releases/download/2024-05-30/vmlinuz.efi') - kernel_hash =3D '951b485b16e3788b6db03a3e1793c067009e31a2' - kernel_path =3D self.fetch_asset(kernel_url, asset_hash=3Dkernel_h= ash) + self.set_machine('virt') =20 - initrd_url =3D ('https://github.com/yangxiaojuan-loongson/qemu-bin= ary/' - 'releases/download/2024-05-30/ramdisk') - initrd_hash =3D 'c67658d9b2a447ce7db2f73ba3d373c9b2b90ab2' - initrd_path =3D self.fetch_asset(initrd_url, asset_hash=3Dinitrd_h= ash) - - bios_url =3D ('https://github.com/yangxiaojuan-loongson/qemu-binar= y/' - 'releases/download/2024-05-30/QEMU_EFI.fd') - bios_hash =3D ('f4d0966b5117d4cd82327c050dd668741046be69') - bios_path =3D self.fetch_asset(bios_url, asset_hash=3Dbios_hash) + kernel_path =3D self.ASSET_KERNEL.fetch() + initrd_path =3D self.ASSET_INITRD.fetch() + bios_path =3D self.ASSET_BIOS.fetch() =20 self.vm.set_console() kernel_command_line =3D (self.KERNEL_COMMON_COMMAND_LINE + @@ -56,3 +57,6 @@ def test_loongarch64_devices(self): self.wait_for_console_pattern('Run /sbin/init as init process') exec_command_and_wait_for_pattern(self, 'cat /proc/cpuinfo', 'processor : 3') + +if __name__ =3D=3D '__main__': + QemuSystemTest.main() diff --git a/tests/functional/test_mips64el_loongson3v.py b/tests/functiona= l/test_mips64el_loongson3v.py new file mode 100755 index 0000000000..55d62928c7 --- /dev/null +++ b/tests/functional/test_mips64el_loongson3v.py @@ -0,0 +1,39 @@ +#!/usr/bin/env python3 +# +# Functional tests for the Generic Loongson-3 Platform. +# +# Copyright (c) 2021 Jiaxun Yang +# +# This work is licensed under the terms of the GNU GPL, version 2 or later. +# See the COPYING file in the top-level directory. +# +# SPDX-License-Identifier: GPL-2.0-or-later + +import os +import time + +from unittest import skipUnless +from qemu_test import QemuSystemTest, Asset +from qemu_test import wait_for_console_pattern + +class MipsLoongson3v(QemuSystemTest): + timeout =3D 60 + + ASSET_PMON =3D Asset( + ('https://github.com/loongson-community/pmon/' + 'releases/download/20210112/pmon-3avirt.bin'), + 'fcdf6bb2cb7885a4a62f31fcb0d5e368bac7b6cea28f40c6dfa678af22fea20a') + + @skipUnless(os.getenv('QEMU_TEST_ALLOW_UNTRUSTED_CODE'), 'untrusted co= de') + def test_pmon_serial_console(self): + self.set_machine('loongson3-virt') + + pmon_path =3D self.ASSET_PMON.fetch() + + self.vm.set_console() + self.vm.add_args('-bios', pmon_path) + self.vm.launch() + wait_for_console_pattern(self, 'CPU GODSON3 BogoMIPS:') + +if __name__ =3D=3D '__main__': + QemuSystemTest.main() diff --git a/tests/avocado/netdev-ethtool.py b/tests/functional/test_netdev= _ethtool.py old mode 100644 new mode 100755 similarity index 66% rename from tests/avocado/netdev-ethtool.py rename to tests/functional/test_netdev_ethtool.py index 5f33288f81..b159a43c4f --- a/tests/avocado/netdev-ethtool.py +++ b/tests/functional/test_netdev_ethtool.py @@ -1,3 +1,5 @@ +#!/usr/bin/env python3 +# # ethtool tests for emulated network devices # # This test leverages ethtool's --test sequence to validate network @@ -5,39 +7,32 @@ # # SPDX-License-Identifier: GPL-2.0-or-late =20 -from avocado import skip -from avocado_qemu import QemuSystemTest -from avocado_qemu import wait_for_console_pattern +from unittest import skip +from qemu_test import QemuSystemTest, Asset +from qemu_test import wait_for_console_pattern =20 class NetDevEthtool(QemuSystemTest): - """ - :avocado: tags=3Darch:x86_64 - :avocado: tags=3Dmachine:q35 - """ =20 # Runs in about 17s under KVM, 19s under TCG, 25s under GCOV timeout =3D 45 =20 # Fetch assets from the netdev-ethtool subdir of my shared test # images directory on fileserver.linaro.org. - def get_asset(self, name, sha1): - base_url =3D ('https://fileserver.linaro.org/s/' - 'kE4nCFLdQcoBF9t/download?' - 'path=3D%2Fnetdev-ethtool&files=3D' ) - url =3D base_url + name - # use explicit name rather than failing to neatly parse the - # URL into a unique one - return self.fetch_asset(name=3Dname, locations=3D(url), asset_hash= =3Dsha1) + ASSET_BASEURL =3D ('https://fileserver.linaro.org/s/' + 'kE4nCFLdQcoBF9t/download?' + 'path=3D%2Fnetdev-ethtool&files=3D') + ASSET_BZIMAGE =3D Asset(ASSET_BASEURL + "bzImage", + "33469d7802732d5815226166581442395cb289e2") + ASSET_ROOTFS =3D Asset(ASSET_BASEURL + "rootfs.squashfs", + "9793cea7021414ae844bda51f558bd6565b50cdc") =20 def common_test_code(self, netdev, extra_args=3DNone): + self.set_machine('q35') =20 # This custom kernel has drivers for all the supported network # devices we can emulate in QEMU - kernel =3D self.get_asset("bzImage", - "33469d7802732d5815226166581442395cb289e2") - - rootfs =3D self.get_asset("rootfs.squashfs", - "9793cea7021414ae844bda51f558bd6565b50cdc") + kernel =3D self.ASSET_BZIMAGE.fetch() + rootfs =3D self.ASSET_ROOTFS.fetch() =20 append =3D 'printk.time=3D0 console=3DttyS0 ' append +=3D 'root=3D/dev/sr0 rootfstype=3Dsquashfs ' @@ -68,15 +63,9 @@ def common_test_code(self, netdev, extra_args=3DNone): self.vm.kill() =20 def test_igb(self): - """ - :avocado: tags=3Ddevice:igb - """ self.common_test_code("igb") =20 def test_igb_nomsi(self): - """ - :avocado: tags=3Ddevice:igb - """ self.common_test_code("igb", "pci=3Dnomsi") =20 # It seems the other popular cards we model in QEMU currently fail @@ -88,14 +77,11 @@ def test_igb_nomsi(self): =20 @skip("Incomplete reg 0x00178 support") def test_e1000(self): - """ - :avocado: tags=3Ddevice:e1000 - """ self.common_test_code("e1000") =20 @skip("Incomplete reg 0x00178 support") def test_i82550(self): - """ - :avocado: tags=3Ddevice:i82550 - """ self.common_test_code("i82550") + +if __name__ =3D=3D '__main__': + QemuSystemTest.main() diff --git a/tests/avocado/ppc_405.py b/tests/functional/test_ppc_405.py old mode 100644 new mode 100755 similarity index 53% rename from tests/avocado/ppc_405.py rename to tests/functional/test_ppc_405.py index 4e7e01aa76..5e200eab95 --- a/tests/avocado/ppc_405.py +++ b/tests/functional/test_ppc_405.py @@ -1,3 +1,5 @@ +#!/usr/bin/env python3 +# # Test that the U-Boot firmware boots on ppc 405 machines and check the co= nsole # # Copyright (c) 2021 Red Hat, Inc. @@ -5,20 +7,20 @@ # This work is licensed under the terms of the GNU GPL, version 2 or # later. See the COPYING file in the top-level directory. =20 -from avocado.utils import archive -from avocado_qemu import QemuSystemTest -from avocado_qemu import wait_for_console_pattern -from avocado_qemu import exec_command_and_wait_for_pattern +from qemu_test import QemuSystemTest, Asset +from qemu_test import wait_for_console_pattern +from qemu_test import exec_command_and_wait_for_pattern =20 class Ppc405Machine(QemuSystemTest): =20 timeout =3D 90 =20 + ASSET_UBOOT =3D Asset(('https://gitlab.com/huth/u-boot/-/raw/' + 'taihu-2021-10-09/u-boot-taihu.bin'), + '3208940e908a5edc7c03eab072c60f0dcfadc2ab') + def do_test_ppc405(self): - uboot_url =3D ('https://gitlab.com/huth/u-boot/-/raw/' - 'taihu-2021-10-09/u-boot-taihu.bin') - uboot_hash =3D ('3208940e908a5edc7c03eab072c60f0dcfadc2ab'); - file_path =3D self.fetch_asset(uboot_url, asset_hash=3Duboot_hash) + file_path =3D self.ASSET_UBOOT.fetch() self.vm.set_console(console_index=3D1) self.vm.add_args('-bios', file_path) self.vm.launch() @@ -26,11 +28,9 @@ def do_test_ppc405(self): exec_command_and_wait_for_pattern(self, 'reset', 'AMCC PowerPC 405= EP') =20 def test_ppc_ref405ep(self): - """ - :avocado: tags=3Darch:ppc - :avocado: tags=3Dmachine:ref405ep - :avocado: tags=3Dcpu:405ep - :avocado: tags=3Daccel:tcg - """ self.require_accelerator("tcg") + self.set_machine('ref405ep') self.do_test_ppc405() + +if __name__ =3D=3D '__main__': + QemuSystemTest.main() --=20 2.45.2