diff --git a/.fmf/version b/.fmf/version deleted file mode 100644 index d00491f..0000000 --- a/.fmf/version +++ /dev/null @@ -1 +0,0 @@ -1 diff --git a/fix-tests.patch b/fix-tests.patch index 83da6ad..e8767da 100644 --- a/fix-tests.patch +++ b/fix-tests.patch @@ -1,47 +1,49 @@ -From 42a461b71597e85e7902571348786aa4ab848cf8 Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Tom=C3=A1=C5=A1=20Hrn=C4=8Diar?= -Date: Fri, 28 Mar 2025 09:44:24 +0100 -Subject: [PATCH] Fix tests -MIME-Version: 1.0 -Content-Type: text/plain; charset=UTF-8 -Content-Transfer-Encoding: 8bit +From 9e70838d0fe10576c8e991a2ac8cff09eab8a4b8 Mon Sep 17 00:00:00 2001 +From: Lumir Balhar +Date: Tue, 10 Jan 2023 08:34:25 +0100 +Subject: [PATCH] fix tests -Co-Authored-By: Lumir Balhar -Co-Authored-By: Miro HronĨok --- - pyproject.toml | 4 +--- - src/tox/pytest.py | 14 ++------------ - tests/test_provision.py | 11 ++++------- - .../package/test_python_package_util.py | 10 ++++++++-- - 4 files changed, 15 insertions(+), 30 deletions(-) + pyproject.toml | 5 ----- + src/tox/pytest.py | 16 +++------------- + tests/test_provision.py | 17 ++--------------- + 3 files changed, 5 insertions(+), 33 deletions(-) diff --git a/pyproject.toml b/pyproject.toml -index 6920d19..53326bc 100644 +index c34eed8..4604c52 100644 --- a/pyproject.toml +++ b/pyproject.toml -@@ -201,6 +195,7 @@ filterwarnings = [ - "error", - "ignore:unclosed database in =1.0.3", +- "covdefaults>=2.3", +- "detect-test-pollution>=1.2", +- "devpi-process>=1", + "diff-cover>=8.0.2", + "distlib>=0.3.8", + "flaky>=3.7", +@@ -82,7 +79,6 @@ optional-dependencies.testing = [ + "hatchling>=1.21", + "psutil>=5.9.7", + "pytest>=7.4.4", +- "pytest-cov>=4.1", + "pytest-mock>=3.12", + "pytest-xdist>=3.5", + "re-assert>=1.1", +@@ -162,7 +158,6 @@ paths.source = [ + report.fail_under = 88 + report.omit = ["src/tox/config/cli/for_docs.py", "tests/execute/local_subprocess/bad_process.py", "tests/type_check/*"] run.parallel = true --run.plugins = [ -- "covdefaults", --] +-run.plugins = ["covdefaults"] [tool.towncrier] name = "tox" diff --git a/src/tox/pytest.py b/src/tox/pytest.py -index 31b3e6f..c358313 100644 +index d734def..5e6df35 100644 --- a/src/tox/pytest.py +++ b/src/tox/pytest.py -@@ -17,7 +17,6 @@ from typing import TYPE_CHECKING, Any, Protocol, cast +@@ -17,7 +17,6 @@ from typing import TYPE_CHECKING, Any, Callable, Iterator, Protocol, Sequence, c import pytest from _pytest.fixtures import SubRequest # noqa: PLC2701 @@ -49,18 +51,20 @@ index 31b3e6f..c358313 100644 from virtualenv.info import fs_supports_symlink import tox.run -@@ -285,8 +284,8 @@ class ToxProject: +@@ -277,9 +276,9 @@ class ToxProject: m.setattr(sys, "argv", [sys.executable, "-m", "tox", *list(args)]) m.setenv("VIRTUALENV_SYMLINK_APP_DATA", "1") m.setenv("VIRTUALENV_SYMLINKS", "1") - m.setenv("VIRTUALENV_PIP", "embed") +- m.setenv("VIRTUALENV_WHEEL", "embed") - m.setenv("VIRTUALENV_SETUPTOOLS", "embed") + m.setenv("VIRTUALENV_PIP", "bundle") ++ m.setenv("VIRTUALENV_WHEEL", "bundle") + m.setenv("VIRTUALENV_SETUPTOOLS", "bundle") try: tox_run(args) except SystemExit as exception: -@@ -479,15 +478,6 @@ def enable_pypi_server(monkeypatch: pytest.MonkeyPatch, url: str | None) -> None +@@ -472,15 +471,6 @@ def enable_pypi_server(monkeypatch: pytest.MonkeyPatch, url: str | None) -> None monkeypatch.setenv("PIP_TIMEOUT", str(2)) @@ -74,70 +78,44 @@ index 31b3e6f..c358313 100644 - - @pytest.fixture(scope="session") - def _invalid_index_fake_port() -> int: + def _invalid_index_fake_port() -> int: # noqa: PT005 with closing(socket.socket(socket.AF_INET, socket.SOCK_STREAM)) as socket_handler: diff --git a/tests/test_provision.py b/tests/test_provision.py -index d1b6b2d..022e340 100644 +index 41eb630..1df7e76 100644 --- a/tests/test_provision.py +++ b/tests/test_provision.py -@@ -126,15 +126,13 @@ def _use_pypi_index(pypi_index: Index, monkeypatch: MonkeyPatch) -> None: +@@ -92,21 +92,9 @@ def tox_wheels(tox_wheel: Path, tmp_path_factory: TempPathFactory) -> list[Path] + return result - @pytest.fixture --def _pypi_index_mirrored(local_pypi_indexes: tuple[Index, Index], monkeypatch: MonkeyPatch) -> None: -- pypi_index_mirrored, _ = local_pypi_indexes -- _use_pypi_index(pypi_index_mirrored, monkeypatch) -+def _pypi_index_mirrored() -> None: -+ pytest.skip("needs devpi-process") - - - @pytest.fixture --def _pypi_index_self(local_pypi_indexes: tuple[Index, Index], monkeypatch: MonkeyPatch) -> None: -- _, pypi_index_self = local_pypi_indexes -- _use_pypi_index(pypi_index_self, monkeypatch) -+def _pypi_index_self() -> None: +-@pytest.fixture(scope="session") +-def pypi_index_self(pypi_server: IndexServer, tox_wheels: list[Path], demo_pkg_inline_wheel: Path) -> Index: +- with elapsed("start devpi and create index"): # takes around 1s +- self_index = pypi_server.create_index("self", "volatile=False") +- with elapsed("upload tox and its wheels to devpi"): # takes around 3.2s on build +- self_index.upload(*tox_wheels, demo_pkg_inline_wheel) +- return self_index +- +- + @pytest.fixture() +-def _pypi_index_self(pypi_index_self: Index, monkeypatch: MonkeyPatch) -> None: +- pypi_index_self.use() +- monkeypatch.setenv("PIP_INDEX_URL", pypi_index_self.url) +- monkeypatch.setenv("PIP_RETRIES", str(2)) +- monkeypatch.setenv("PIP_TIMEOUT", str(5)) ++def _pypi_index_self(): + pytest.skip("needs devpi-process") def test_provision_requires_nok(tox_project: ToxProjectCreator) -> None: -@@ -183,7 +181,6 @@ def test_provision_requires_ok(tox_project: ToxProjectCreator, tmp_path: Path) - +@@ -155,7 +143,6 @@ def test_provision_requires_ok(tox_project: ToxProjectCreator, tmp_path: Path) - - @pytest.mark.integration + @pytest.mark.integration() -@pytest.mark.usefixtures("_pypi_index_self") def test_provision_platform_check(tox_project: ToxProjectCreator) -> None: ini = "[tox]\nrequires=demo-pkg-inline\n[testenv]\npackage=skip\n[testenv:.tox]\nplatform=wrong_platform" proj = tox_project({"tox.ini": ini}) -diff --git a/tests/tox_env/python/virtual_env/package/test_python_package_util.py b/tests/tox_env/python/virtual_env/package/test_python_package_util.py -index 3802147..7f64d90 100644 ---- a/tests/tox_env/python/virtual_env/package/test_python_package_util.py -+++ b/tests/tox_env/python/virtual_env/package/test_python_package_util.py -@@ -15,6 +15,12 @@ if TYPE_CHECKING: - - from importlib.metadata import Distribution, PathDistribution - -+from importlib.metadata import version -+from packaging.version import Version -+ -+SETUPTOOLS_VERSION = Version(version("setuptools")) -+SETUPTOOLS_75_6 = SETUPTOOLS_VERSION >= Version("75.6") -+ - - @pytest.fixture(scope="session") - def pkg_with_extras(pkg_with_extras_project: Path) -> PathDistribution: -@@ -43,10 +49,10 @@ def test_load_dependency_many_extra(pkg_with_extras: PathDistribution) -> None: - exp = [ - Requirement("platformdirs>=4.3.8"), - Requirement("colorama>=0.4.6"), -- *(sphinx if sys.version_info[0:2] <= (3, 8) else []), -+ *(sphinx if not SETUPTOOLS_75_6 else []), - Requirement(f'covdefaults>=1.2; python_version == "2.7" or python_version == "{py_ver}"'), - Requirement(f'pytest>=5.4.1; python_version == "{py_ver}"'), -- *(sphinx if sys.version_info[0:2] > (3, 8) else []), -+ *(sphinx if SETUPTOOLS_75_6 else []), - ] - for left, right in zip_longest(result, exp): - assert isinstance(right, Requirement) -- -2.51.1 +2.44.0 diff --git a/plan.fmf b/plan.fmf deleted file mode 100644 index c10b63e..0000000 --- a/plan.fmf +++ /dev/null @@ -1,102 +0,0 @@ -execute: - how: tmt - -discover: - - name: rpms_pyproject-rpm-macros - how: shell - url: https://src.fedoraproject.org/rpms/pyproject-rpm-macros.git - tests: - - name: pyproject_pytest - path: /tests - test: ./mocktest.sh python-pytest - - name: pyproject_pluggy - path: /tests - test: ./mocktest.sh python-pluggy - - name: pyproject_openqa_client - path: /tests - test: ./mocktest.sh python-openqa_client - - name: same_repo - how: shell - dist-git-source: true - dist-git-download-only: true - tests: - - name: all_supplementing_pythons - test: ./tests/all_supplementing_pythons.py - - name: mock_with_tests - # Needs cwd to contain downloaded sources, path to mocktes.sh depends on tmt tree structure - test: | - cd $TMT_SOURCE_DIR && - $TMT_TREE/../discover/rpms_pyproject-rpm-macros/tests/tests/mocktest.sh python-tox --enable-network --with ci_tests - - name: tests_python - how: shell - url: https://src.fedoraproject.org/tests/python.git - tests: - - name: smoke27 - path: /smoke - test: VERSION=2.7 INSTALL_OR_SKIP=true METHOD=virtualenv TOX_REQUIRES="virtualenv<20.22.0" ./venv.sh - - name: smoke36 - path: /smoke - test: VERSION=3.6 INSTALL_OR_SKIP=true TOX_REQUIRES="virtualenv<20.22.0" ./venv.sh - - name: smoke39 - path: /smoke - test: VERSION=3.9 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke310 - path: /smoke - test: VERSION=3.10 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke311 - path: /smoke - test: VERSION=3.11 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke312 - path: /smoke - test: VERSION=3.12 ./venv.sh - - name: smoke313 - path: /smoke - test: VERSION=3.13 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke313t - path: /smoke - test: VERSION=3.13t INSTALL_OR_SKIP=true ./venv.sh - - name: smoke314 - path: /smoke - test: VERSION=3.14 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke314t - path: /smoke - test: VERSION=3.14t INSTALL_OR_SKIP=true ./venv.sh - - name: smoke315 - path: /smoke - test: VERSION=3.15 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke315t - path: /smoke - test: VERSION=3.15t INSTALL_OR_SKIP=true ./venv.sh - - name: smoke_pypy39 - path: /smoke - test: PYTHON=pypy3.9 VERSION=3.9 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke_pypy310 - path: /smoke - test: PYTHON=pypy3.10 VERSION=3.10 INSTALL_OR_SKIP=true ./venv.sh - - name: smoke_pypy311 - path: /smoke - test: PYTHON=pypy3.11 VERSION=3.11 INSTALL_OR_SKIP=true ./venv.sh - -prepare: - - name: Install dependencies - how: install - package: - - gcc - - virtualenv - - python3-devel - - python3.12-devel - - python3-tox - - python3-dnf - - mock - - rpmdevtools - - rpm-build - - python3-pyyaml - - rpm - - dnf - - name: Update packages - how: shell - script: dnf upgrade -y - - name: rpm_qa - order: 100 - how: shell - script: rpm -qa | sort | tee $TMT_PLAN_DATA/rpmqa.txt diff --git a/python-tox.spec b/python-tox.spec index a5f044f..1d8623f 100644 --- a/python-tox.spec +++ b/python-tox.spec @@ -1,6 +1,5 @@ -%bcond bootstrap 0 -# Many tests are enabled by default, unless bootstrapping -%bcond tests %{without bootstrap} +# Many tests are enabled by default +%bcond tests 1 # However, some tests are disabled by default, becasue they require: # a) tested tox to be installed and/or # b) internet connection @@ -20,7 +19,7 @@ %undefine _py3_shebang_s Name: python-tox -Version: 4.33.0 +Version: 4.14.2 Release: %autorelease Summary: Virtualenv-based automation of test activities @@ -28,18 +27,16 @@ License: MIT URL: https://tox.readthedocs.io/ Source: %{pypi_source tox} -# Remove usage of devpi-process. -# Remove coverage options. +# Remove dependency on devpi-process. +# Remove dependency on detect-test-pollution. +# Remove coverage-related dependencies. # Adjust virtualenv environment variables to make it work with our patched virtualenv. -# Adjust setuptools-version specific ifs to check for setuptools version rather than Python version. -# Ignore ResourceWarning: subprocess ... is still running (happens arbitrarily, possibly due to pytest-xdist usage) Patch: fix-tests.patch BuildArch: noarch BuildRequires: python3-devel -# for dependency-groups support: -BuildRequires: pyproject-rpm-macros >= 1.16 +BuildRequires: pyproject-rpm-macros %if %{with tests} BuildRequires: /usr/bin/gcc @@ -50,10 +47,12 @@ BuildRequires: /usr/bin/python BuildRequires: libffi-devel # xdist is not used upstream, but we use it to speed up the %%check BuildRequires: python3-pytest-xdist +# for test_allowed_implicit_cli_envs[py310] +# TODO remove this once https://github.com/tox-dev/tox/pull/3108 is released +BuildRequires: python3.10 %if %{with ci_tests} # The CI tests only work if the tested tox is installed :( -# This should technically be the same V-R, but the CI does not handle %%autorelease well -BuildRequires: tox = %{version} +BuildRequires: tox = %{version}-%{release} %endif %endif @@ -82,11 +81,15 @@ Summary: %{summary} # however it launches other Python versions as subprocesses. # It recommends all Python versions it supports. (This is an exception to # the rule that Fedora packages may not require the alternative interpreters.) -%if 0%{?fedora} +Recommends: python2.7 +Recommends: python3.6 +Recommends: python3.7 +Recommends: python3.8 Recommends: python3.9 Recommends: python3.10 +Recommends: pypy2-devel Recommends: pypy3-devel -%endif +Recommends: python2-devel Recommends: python3-devel # Instead of adding new Pythons here, add `Supplements: tox` to them, see: # https://lists.fedoraproject.org/archives/list/python-devel@lists.fedoraproject.org/thread/NVVUXSVSPFQOWIGBE2JNI67HEO7R63ZQ/ @@ -101,20 +104,15 @@ Recommends: python3-devel # Upstream updates dependencies too aggressively # see https://github.com/tox-dev/tox/pull/2843#discussion_r1065028356 -# First, carefully adjust the pins of build and runtime dependencies, -# then remove all the >= specifiers from tests deps, whatever they are, -# finally, remove undesired test dependencies. -sed -ri -e 's/"(packaging|filelock|platformdirs|pyproject-api|cachetools|hatch-vcs)>=.*/"\1",/g' \ - -e 's/"(virtualenv)>=.*/"\1>=20.29",/g' \ +sed -ri -e 's/"(packaging|filelock|platformdirs|psutil|diff-cover|pyproject-api|pytest|pytest-mock|pytest-xdist|wheel|pluggy|distlib|cachetools|build\[virtualenv\])>=.*/"\1",/g' \ + -e "s/'(time-machine)>=[^;']+/'\1/" \ + -e 's/"(virtualenv)>=.*/"\1>=20",/g' \ -e 's/"(hatchling)>=.*/"\1>=1.13",/g' \ - -e 's/"(pluggy)>=.*/"\1>=1.5",/g' \ - -e '/^test = \[/,/^\]/ { s/>=[^;"]+// }' \ - -e '/^test = \[/,/^\]/ { /"(covdefaults|coverage|detect-test-pollution|devpi-process|diff-cover|pytest-cov)[;"]/d }' \ pyproject.toml %generate_buildrequires export SETUPTOOLS_SCM_PRETEND_VERSION="%{version}" -%pyproject_buildrequires -r %{?with_tests:-g test} +%pyproject_buildrequires -r %{?with_tests:-x testing} %build @@ -129,12 +127,6 @@ export SETUPTOOLS_SCM_PRETEND_VERSION="%{version}" %if %{with tests} %check -# Upstream requires virtualenv >= 20.31 for tests, and no longer sets VIRTUALENV_WHEEL. -# To support environments with older virtualenv, we set it manually: -%if v"%(%{python3} -c 'import importlib.metadata as im; print(im.version("virtualenv"))' 2>/dev/null || echo 0)" < v"20.31" -export VIRTUALENV_WHEEL=bundle -%endif - # Skipped tests use internal virtualenv functionality to # download wheels which does not work with "bundled" version of wheel in # the Fedora's virtualenv patch. @@ -142,33 +134,21 @@ k="${k-}${k+ and }not test_virtualenv_flipped_settings" k="${k-}${k+ and }not test_virtualenv_env_ignored_if_set" k="${k-}${k+ and }not test_virtualenv_env_used_if_not_set" -# https://github.com/tox-dev/tox/issues/3290 -%if v"0%{?python3_version}" >= v"3.13" -k="${k-}${k+ and }not test_str_convert_ok_py39" -%endif - -# https://github.com/tox-dev/tox/commit/698f1dd663 -# The tests fail with setuptools < 70.1 -%if v"%(%{python3} -c 'import importlib.metadata as im; print(im.version("setuptools"))' 2>/dev/null || echo 0)" < v"70.1" -k="${k-}${k+ and }not test_result_json_sequential" -k="${k-}${k+ and }not test_setuptools_package" -k="${k-}${k+ and }not test_skip_develop_mode" -k="${k-}${k+ and }not test_tox_install_pkg_sdist" -%else -# this test fails with virtualenv < 20.31 with bundled wheel -test -z $VIRTUALENV_WHEEL || k="${k-}${k+ and }not test_result_json_sequential" -%endif - # The following tests either need internet connection or installed tox # so we only run them on the CI. %if %{without ci_tests} +k="${k-}${k+ and }not test_virtualenv_flipped_settings" +k="${k-}${k+ and }not test_virtualenv_env_ignored_if_set" +k="${k-}${k+ and }not test_virtualenv_env_used_if_not_set" k="${k-}${k+ and }not test_build_wheel_external" k="${k-}${k+ and }not keyboard_interrupt" k="${k-}${k+ and }not test_call_as_module" k="${k-}${k+ and }not test_call_as_exe" +# test_local_execute_* have "\r\n" in outputs for some +# unknown reason, reported: https://github.com/tox-dev/tox/issues/2841 +k="${k-}${k+ and }not test_local_execute_basic_pass_show_on_standard_newline_flush" +k="${k-}${k+ and }not test_local_execute_write_a_lot" k="${k-}${k+ and }not test_run_installpkg_targz" -k="${k-}${k+ and }not test_pyproject_installpkg_pep517_envs" -test -z $VIRTUALENV_WHEEL && k="${k-}${k+ and }not test_result_json_sequential" %endif %pytest -v -n auto -k "${k-}" --run-integration diff --git a/rpmlint.toml b/rpmlint.toml deleted file mode 100644 index 7b84503..0000000 --- a/rpmlint.toml +++ /dev/null @@ -1,3 +0,0 @@ -Filters = [ - 'spelling-error .* en_US [Vv]irtualenv ', -] diff --git a/sources b/sources index 88f12ab..32d95b2 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (tox-4.33.0.tar.gz) = e46a19ea92a556dc45a592a8d9567b863e072bd2ca8bc7866a3e4992f737fb29ff263a88cfd3cfaa9edaf4d097dd232d710ff9ac072bb16a98adcffea8fe3b70 +SHA512 (tox-4.14.2.tar.gz) = 45bbd3f8d00eee05158452295230321947ec16a8bfff43e84ea9825d514976526f3889709255ed042cfb7a7ebfed020707cfc2d25b69ce90c148f4472092350d diff --git a/tests/all_supplementing_pythons.py b/tests/all_supplementing_pythons.py index 6c2dadd..223bdf1 100755 --- a/tests/all_supplementing_pythons.py +++ b/tests/all_supplementing_pythons.py @@ -8,7 +8,7 @@ See https://lists.fedoraproject.org/archives/list/python-devel@lists.fedoraproje This script: 1) figures out all packages in the enabled repositories supplementing tox - 2) ensures there is a venv.sh test for each of them in plan.fmf + 2) ensures there is a venv.sh test for each of them in tests.yml That way, when we change tox (update, patch, etc.), we will always test it with all Pythons that supplement it. @@ -34,18 +34,16 @@ def parse_python_test_arg(command): # First, construct a set of various Pythons we test, e.g. {python3.10, python3.7, pypy3.6, ...} tested_pythons = set() -with open('plan.fmf') as f: - plan_fmf = yaml.safe_load(f) +with open('tests.yml') as f: + tests_yml = yaml.safe_load(f) # this nested structure access is quite fragile, # but at least it should fail the test if we reach to a wrong place -for discover_section in plan_fmf['discover']: - if discover_section['name'] != 'tests_python': - continue - for test in discover_section['tests']: - test_cmd = test['test'] - if test_cmd.endswith('./venv.sh'): - tested_pythons.add(parse_python_test_arg(test_cmd)) -print('Tested Pythons found in plan.fmf:', file=sys.stderr) +for test in tests_yml[-1]['roles'][0]['tests']: + for value in test.values(): + run = value['run'] + if run.endswith('./venv.sh'): + tested_pythons.add(parse_python_test_arg(run)) +print('Tested Pythons found in tests.yml:', file=sys.stderr) for python in sorted(tested_pythons): print(' ', python, file=sys.stderr) @@ -66,13 +64,10 @@ for nvra in supplementing_pkgs: # We use this hack to treat -devel and -libs packages as if they were not such -# We also convert the freethreading packages to the exectuable name def normalize_name(pkgname): for suffix in '-devel', '-libs': if pkgname.endswith(suffix): - pkgname = pkgname.removesuffix(suffix) - if pkgname.endswith('-freethreading'): - pkgname = pkgname.removesuffix('-freethreading') + 't' + return pkgname.removesuffix(suffix) return pkgname diff --git a/tests/tests.yml b/tests/tests.yml new file mode 100644 index 0000000..ef3a95b --- /dev/null +++ b/tests/tests.yml @@ -0,0 +1,100 @@ +--- +- hosts: localhost + tags: + - classic + tasks: + - dnf: + name: "*" + state: latest + +- hosts: localhost + tags: + - classic + pre_tasks: + - import_role: + name: standard-test-source + vars: + fetch_only: True + + roles: + - role: standard-test-basic + repositories: + - repo: "https://src.fedoraproject.org/tests/python.git" + dest: "python" + - repo: "https://src.fedoraproject.org/rpms/pyproject-rpm-macros.git" + dest: "pyproject-rpm-macros" + tests: + - mock_with_tests: + dir: . + run: pyproject-rpm-macros/tests/mocktest.sh python-tox --enable-network --with ci_tests + - all_supplementing_pythons: + dir: tests + run: ./all_supplementing_pythons.py + - smoke27: + dir: python/smoke + run: VERSION=2.7 METHOD=virtualenv ./venv.sh + - smoke36: + dir: python/smoke + run: VERSION=3.6 ./venv.sh + - smoke37_optional: + dir: python/smoke + run: VERSION=3.7 INSTALL_OR_SKIP=true ./venv.sh + - smoke38: + dir: python/smoke + run: VERSION=3.8 ./venv.sh + - smoke39: + dir: python/smoke + run: VERSION=3.9 ./venv.sh + - smoke310: + dir: python/smoke + run: VERSION=3.10 ./venv.sh + - smoke311: + dir: python/smoke + run: VERSION=3.11 ./venv.sh + - smoke312: + dir: python/smoke + run: VERSION=3.12 ./venv.sh + - smoke313: + dir: python/smoke + run: VERSION=3.13 ./venv.sh + - smoke_pypy37_optional: + dir: python/smoke + run: PYTHON=pypy3.7 VERSION=3.7 INSTALL_OR_SKIP=true ./venv.sh + - smoke_pypy38_optional: + dir: python/smoke + run: PYTHON=pypy3.8 VERSION=3.8 INSTALL_OR_SKIP=true ./venv.sh + - smoke_pypy39: + dir: python/smoke + run: PYTHON=pypy3.9 VERSION=3.9 ./venv.sh + - smoke_pypy310: + dir: python/smoke + run: PYTHON=pypy3.10 VERSION=3.10 ./venv.sh + - pyproject_pytest: + dir: pyproject-rpm-macros/tests + run: ./mocktest.sh python-pytest + - pyproject_pluggy: + dir: pyproject-rpm-macros/tests + run: ./mocktest.sh python-pluggy + - pyproject_openqa_client: + dir: pyproject-rpm-macros/tests + run: ./mocktest.sh python-openqa_client + required_packages: + - gcc + - virtualenv + - python2.7 + - python3.6 + - python3.8 + - python3.9 + - python3.10-devel + - python3.11-devel + - python3.12-devel + - python3.13-devel + - python2-devel + - pypy3.9-devel + - pypy3.10-devel + - python3-tox + - python3-dnf + - mock + - rpmdevtools + - rpm-build + - python3-pyyaml