From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 11163FD45E2 for ; Wed, 25 Feb 2026 19:29:14 +0000 (UTC) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1vvKYb-0003zX-85; Wed, 25 Feb 2026 14:28:25 -0500 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 1vvKYZ-0003wk-Gq for qemu-devel@nongnu.org; Wed, 25 Feb 2026 14:28:23 -0500 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 1vvKYX-0008Fw-SN for qemu-devel@nongnu.org; Wed, 25 Feb 2026 14:28:23 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1772047700; 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=IuGfykvuaPWnW+5hdWJzME16NjhM0NzpRBIzZgi4ek4=; b=TapkJb2Tvteckifbaf3jd6TkyLhHDcO2/2A4LMhmKOjLLNe4aFc+/kzdoYHp4LVHiOGHWE zPyazmGWnd7329ORwedY4aGPYoJ0anahNeNvh1aPGte28lY5S+/T/v0/yCIf5x6bhQH1W1 sVQluSHvcpEgKZiTyfShspMzp0kyD/Y= Received: from mx-prod-mc-06.mail-002.prod.us-west-2.aws.redhat.com (ec2-35-165-154-97.us-west-2.compute.amazonaws.com [35.165.154.97]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-695-buoY27mvPiWhK6oW02O_Wg-1; Wed, 25 Feb 2026 14:28:17 -0500 X-MC-Unique: buoY27mvPiWhK6oW02O_Wg-1 X-Mimecast-MFC-AGG-ID: buoY27mvPiWhK6oW02O_Wg_1772047696 Received: from mx-prod-int-06.mail-002.prod.us-west-2.aws.redhat.com (mx-prod-int-06.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.93]) (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-06.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id 416801800349; Wed, 25 Feb 2026 19:28:16 +0000 (UTC) Received: from jsnow-thinkpadp16vgen1.westford.csb (unknown [10.22.89.212]) by mx-prod-int-06.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTP id 62ADC1800349; Wed, 25 Feb 2026 19:28:14 +0000 (UTC) From: John Snow To: qemu-devel@nongnu.org Cc: =?UTF-8?q?Alex=20Benn=C3=A9e?= , Cleber Rosa , Paolo Bonzini , John Snow , Thomas Huth Subject: [PATCH v2 2/4] python: replace avocado tests with pytest Date: Wed, 25 Feb 2026 14:28:06 -0500 Message-ID: <20260225192808.957477-3-jsnow@redhat.com> In-Reply-To: <20260225192808.957477-1-jsnow@redhat.com> References: <20260225192808.957477-1-jsnow@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.4.1 on 10.30.177.93 Received-SPF: pass client-ip=170.10.129.124; envelope-from=jsnow@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -5 X-Spam_score: -0.6 X-Spam_bar: / X-Spam_report: (-0.6 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, 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_H4=0.001, RCVD_IN_MSPIKE_WL=0.001, RCVD_IN_VALIDITY_RPBL_BLOCKED=0.734, RCVD_IN_VALIDITY_SAFE_BLOCKED=0.78, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001 autolearn=no autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: qemu development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Sender: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Following suit with the rest of this repository, drop avocado and replace it with the Python standard "pytest" package. In this case, we do not truly need pytest as all we are using it for is running other python processes formerly launched by shell scripts, but this matches how the standalone python-qemu-qmp package does things, which keeps things simple on my end. (pytest version chosen based off of Debian 11's package version as queried by repology; under the assumption that this is the likely the oldest version we currently leverage in testing.) Signed-off-by: John Snow --- python/Makefile | 4 +- python/setup.cfg | 1 + python/tests/linters.py | 89 ++++++++++++++++++++++++++++++++++++++++ python/tests/minreqs.txt | 1 + 4 files changed, 93 insertions(+), 2 deletions(-) create mode 100644 python/tests/linters.py diff --git a/python/Makefile b/python/Makefile index b6c9cd1bce2..42994d39618 100644 --- a/python/Makefile +++ b/python/Makefile @@ -105,7 +105,7 @@ develop: .PHONY: check check: - @avocado --config avocado.cfg run tests/ + @pytest -v tests/*.py .PHONY: check-tox check-tox: @@ -113,7 +113,7 @@ check-tox: .PHONY: check-coverage check-coverage: - @coverage run -m avocado --config avocado.cfg run tests/*.py + @coverage run -m pytest -v tests/*.py @coverage combine @coverage html @coverage report diff --git a/python/setup.cfg b/python/setup.cfg index c46a95f8d41..03344526730 100644 --- a/python/setup.cfg +++ b/python/setup.cfg @@ -43,6 +43,7 @@ devel = mypy >= 1.4.0 pylint >= 2.17.3 pylint != 3.2.4; python_version<"3.9" + pytest >= 6.0.2 tox >= 3.18.0 sphinx >= 3.4.3 diff --git a/python/tests/linters.py b/python/tests/linters.py new file mode 100644 index 00000000000..28556c09910 --- /dev/null +++ b/python/tests/linters.py @@ -0,0 +1,89 @@ +# SPDX-License-Identifier: GPL-2.0-or-later + +import os +import subprocess +import sys + + +def pyrun(*args): + subprocess.run((sys.executable, *args), check=True) + + +class TestLinters: + + def test_flake8_pkg(self): + pyrun("-m", "flake8", "qemu/") + + def test_flake8_scripts(self): + pyrun("-m", "flake8", "scripts/") + + def test_flake8_qapi(self): + pyrun("-m", "flake8", + "../scripts/qapi/", + "../docs/sphinx/qapidoc.py", + "../docs/sphinx/qapi_domain.py") + + def test_isort_pkg(self): + pyrun("-m", "isort", "-c", "qemu/") + + def test_isort_scripts(self): + pyrun("-m", "isort", "-c", "scripts/") + + def test_isort_qapi(self): + pyrun("-m", "isort", "--sp", ".", "-c", "../scripts/qapi/") + + def test_isort_qapi_sphinx(self): + # Force isort to recognize 'compat' as a local module and not + # third-party + pyrun("-m", "isort", "--sp", ".", "-c", "-p", "compat", + "../docs/sphinx/qapi_domain.py", + "../docs/sphinx/qapidoc.py") + + def test_mypy_pkg(self): + pyrun("-m", "mypy", "-p", "qemu") + + def test_mypy_scripts(self): + pyrun("-m", "mypy", "scripts/") + + def test_mypy_qapi(self): + pyrun("-m", "mypy", "../scripts/qapi") + + def test_mypy_iotests(self): + cwd = os.getcwd() + try: + os.chdir("../tests/qemu-iotests/") + pyrun("-m", "linters", "--mypy") + finally: + os.chdir(cwd) + + # Setuptools v60 introduced the SETUPTOOLS_USE_DISTUTILS=stdlib + # workaround; stdlib distutils was fully removed in Python + # 3.12+. Once we are on >=3.12+ exclusively, this workaround can be + # dropped safely. Until then, it is needed for some versions on + # Fedora/Debian distributions which relied upon distro-patched + # setuptools present in CPython, but not within setuptools itself. + + def test_pylint_pkg(self): + os.environ['SETUPTOOLS_USE_DISTUTILS'] = 'stdlib' + pyrun("-m", "pylint", "qemu/") + + def test_pylint_scripts(self): + os.environ['SETUPTOOLS_USE_DISTUTILS'] = 'stdlib' + pyrun("-m", "pylint", "qemu/") + + def test_pylint_qapi(self): + os.environ['SETUPTOOLS_USE_DISTUTILS'] = 'stdlib' + pyrun("-m", "pylint", + "--rcfile=../scripts/qapi/pylintrc", + "../scripts/qapi/", + "../docs/sphinx/qapidoc.py", + "../docs/sphinx/qapi_domain.py") + + def test_pylint_iotests(self): + os.environ['SETUPTOOLS_USE_DISTUTILS'] = 'stdlib' + cwd = os.getcwd() + try: + os.chdir("../tests/qemu-iotests/") + pyrun("-m", "linters", "--pylint") + finally: + os.chdir(cwd) diff --git a/python/tests/minreqs.txt b/python/tests/minreqs.txt index 38b17d17e14..19912027076 100644 --- a/python/tests/minreqs.txt +++ b/python/tests/minreqs.txt @@ -32,6 +32,7 @@ fusepy==2.0.4 # Test-runners, utilities, etc. avocado-framework==90.0 +pytest==6.0.2 # Linters flake8==5.0.4 -- 2.53.0