Compare commits
14 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 7020984115 | |||
| aa466cd2d6 | |||
| cbb1e4c150 | |||
| 119eb1eba0 | |||
| 745bdd1bfb | |||
| 224c79a35f | |||
| 80602e339d | |||
| 4e85c05c34 | |||
| cb1dcfef37 | |||
| 1380a99f6e | |||
| c1c8c91355 | |||
| 130c199691 | |||
| 138cc6b75e | |||
| 4f5a2fef3e |
@@ -8,3 +8,7 @@
|
|||||||
/tox-2.9.1.tar.gz
|
/tox-2.9.1.tar.gz
|
||||||
/tox-3.0.0.tar.gz
|
/tox-3.0.0.tar.gz
|
||||||
/tox-3.4.0.tar.gz
|
/tox-3.4.0.tar.gz
|
||||||
|
/tox-3.5.3.tar.gz
|
||||||
|
/tox-3.9.0.tar.gz
|
||||||
|
/tox-3.13.1.tar.gz
|
||||||
|
/tox-3.13.2.tar.gz
|
||||||
|
|||||||
+112
@@ -0,0 +1,112 @@
|
|||||||
|
From dab74691cd1cd55621c943fc869f8ee821746ff6 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= <miro@hroncok.cz>
|
||||||
|
Date: Mon, 8 Jul 2019 19:08:17 +0200
|
||||||
|
Subject: [PATCH] Use importlib.metadata from the standard library on Python
|
||||||
|
3.8+
|
||||||
|
|
||||||
|
Fixes https://github.com/tox-dev/tox/issues/1367
|
||||||
|
---
|
||||||
|
CONTRIBUTORS | 1 +
|
||||||
|
setup.cfg | 2 +-
|
||||||
|
src/tox/config/__init__.py | 2 +-
|
||||||
|
src/tox/session/commands/show_config.py | 2 +-
|
||||||
|
src/tox/util/stdlib.py | 5 +++++
|
||||||
|
tox.ini | 2 +-
|
||||||
|
6 files changed, 10 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/CONTRIBUTORS b/CONTRIBUTORS
|
||||||
|
index 39d848b..ad0168f 100644
|
||||||
|
--- a/CONTRIBUTORS
|
||||||
|
+++ b/CONTRIBUTORS
|
||||||
|
@@ -58,6 +58,7 @@ Mattieu Agopian
|
||||||
|
Michael Manganiello
|
||||||
|
Mickaël Schoentgen
|
||||||
|
Mikhail Kyshtymov
|
||||||
|
+Miro Hrončok
|
||||||
|
Monty Taylor
|
||||||
|
Morgan Fainberg
|
||||||
|
Nick Douma
|
||||||
|
diff --git a/setup.cfg b/setup.cfg
|
||||||
|
index 3950ea3..c2bb1c2 100644
|
||||||
|
--- a/setup.cfg
|
||||||
|
+++ b/setup.cfg
|
||||||
|
@@ -37,7 +37,7 @@ classifiers =
|
||||||
|
packages = find:
|
||||||
|
python_requires = >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*
|
||||||
|
install_requires =
|
||||||
|
- importlib-metadata >= 0.12, <1
|
||||||
|
+ importlib-metadata >= 0.12, <1;python_version<"3.8"
|
||||||
|
packaging >= 14
|
||||||
|
pluggy >= 0.12.0, <1
|
||||||
|
py >= 1.4.17, <2
|
||||||
|
diff --git a/src/tox/config/__init__.py b/src/tox/config/__init__.py
|
||||||
|
index c1a3239..849b31f 100644
|
||||||
|
--- a/src/tox/config/__init__.py
|
||||||
|
+++ b/src/tox/config/__init__.py
|
||||||
|
@@ -15,7 +15,6 @@ from fnmatch import fnmatchcase
|
||||||
|
from subprocess import list2cmdline
|
||||||
|
from threading import Thread
|
||||||
|
|
||||||
|
-import importlib_metadata
|
||||||
|
import pluggy
|
||||||
|
import py
|
||||||
|
import toml
|
||||||
|
@@ -34,6 +33,7 @@ from tox.reporter import (
|
||||||
|
verbosity1,
|
||||||
|
)
|
||||||
|
from tox.util.path import ensure_empty_dir
|
||||||
|
+from tox.util.stdlib import importlib_metadata
|
||||||
|
|
||||||
|
from .parallel import ENV_VAR_KEY as PARALLEL_ENV_VAR_KEY
|
||||||
|
from .parallel import add_parallel_config, add_parallel_flags
|
||||||
|
diff --git a/src/tox/session/commands/show_config.py b/src/tox/session/commands/show_config.py
|
||||||
|
index 11c5cf2..efb713a 100644
|
||||||
|
--- a/src/tox/session/commands/show_config.py
|
||||||
|
+++ b/src/tox/session/commands/show_config.py
|
||||||
|
@@ -1,13 +1,13 @@
|
||||||
|
import sys
|
||||||
|
from collections import OrderedDict
|
||||||
|
|
||||||
|
-import importlib_metadata
|
||||||
|
from packaging.requirements import Requirement
|
||||||
|
from packaging.utils import canonicalize_name
|
||||||
|
from six import StringIO
|
||||||
|
from six.moves import configparser
|
||||||
|
|
||||||
|
from tox import reporter
|
||||||
|
+from tox.util.stdlib import importlib_metadata
|
||||||
|
|
||||||
|
DO_NOT_SHOW_CONFIG_ATTRIBUTES = (
|
||||||
|
"interpreters",
|
||||||
|
diff --git a/src/tox/util/stdlib.py b/src/tox/util/stdlib.py
|
||||||
|
index 0b25859..5f687b7 100644
|
||||||
|
--- a/src/tox/util/stdlib.py
|
||||||
|
+++ b/src/tox/util/stdlib.py
|
||||||
|
@@ -3,6 +3,11 @@ import threading
|
||||||
|
from contextlib import contextmanager
|
||||||
|
from tempfile import TemporaryFile
|
||||||
|
|
||||||
|
+if sys.version_info >= (3, 8):
|
||||||
|
+ from importlib import metadata as importlib_metadata # noqa
|
||||||
|
+else:
|
||||||
|
+ import importlib_metadata # noqa
|
||||||
|
+
|
||||||
|
|
||||||
|
def is_main_thread():
|
||||||
|
"""returns true if we are within the main thread"""
|
||||||
|
diff --git a/tox.ini b/tox.ini
|
||||||
|
index fa5b321..fcb1418 100644
|
||||||
|
--- a/tox.ini
|
||||||
|
+++ b/tox.ini
|
||||||
|
@@ -139,7 +139,7 @@ include_trailing_comma = True
|
||||||
|
force_grid_wrap = 0
|
||||||
|
line_length = 99
|
||||||
|
known_first_party = tox,tests
|
||||||
|
-known_third_party = apiclient,docutils,filelock,flaky,freezegun,git,httplib2,importlib_metadata,oauth2client,packaging,pathlib2,pluggy,py,pytest,setuptools,six,sphinx,toml
|
||||||
|
+known_third_party = apiclient,docutils,filelock,flaky,freezegun,git,httplib2,oauth2client,packaging,pathlib2,pluggy,py,pytest,setuptools,six,sphinx,toml
|
||||||
|
|
||||||
|
[testenv:release]
|
||||||
|
description = do a release, required posarg of the version number
|
||||||
|
--
|
||||||
|
2.21.0
|
||||||
|
|
||||||
+13
@@ -0,0 +1,13 @@
|
|||||||
|
diff --git a/src/tox/constants.py b/src/tox/constants.py
|
||||||
|
index 8dcc86b..1c90e47 100644
|
||||||
|
--- a/src/tox/constants.py
|
||||||
|
+++ b/src/tox/constants.py
|
||||||
|
@@ -30,7 +30,7 @@ def _construct_default_factors(cpython_versions, pypy_versions, other_interprete
|
||||||
|
|
||||||
|
class PYTHON:
|
||||||
|
PY_FACTORS_RE = re.compile("^(?!py$)(py|pypy|jython)([2-9][0-9]?)?$")
|
||||||
|
- CPYTHON_VERSION_TUPLES = [(2, 7), (3, 4), (3, 5), (3, 6), (3, 7), (3, 8)]
|
||||||
|
+ CPYTHON_VERSION_TUPLES = [(2, 7), (3, 4), (3, 5), (3, 6), (3, 7), (3, 8), (3, 9)]
|
||||||
|
PYPY_VERSION_TUPLES = [(2, 7), (3, 5)]
|
||||||
|
OTHER_PYTHON_INTERPRETERS = ["jython"]
|
||||||
|
DEFAULT_FACTORS = _construct_default_factors(
|
||||||
+94
-22
@@ -1,19 +1,28 @@
|
|||||||
# Tests requiring Internet connections are disabled by default
|
# Tests requiring Internet connections are disabled by default
|
||||||
# pass --with internet to run them (e.g. when doing a local rebuild
|
# pass --with internet to run them (e.g. when doing a local rebuild
|
||||||
# for sanity checks before committing)
|
# for sanity checks before committing). Example:
|
||||||
|
# $ mock --enable-network --with internet <SRPM>
|
||||||
%bcond_with internet
|
%bcond_with internet
|
||||||
|
|
||||||
|
|
||||||
%global pypiname tox
|
%global pypi_name tox
|
||||||
Name: python-%{pypiname}
|
Name: python-%{pypi_name}
|
||||||
Version: 3.4.0
|
Version: 3.13.2
|
||||||
Release: 1%{?dist}
|
Release: 3%{?dist}
|
||||||
Summary: Virtualenv-based automation of test activities
|
Summary: Virtualenv-based automation of test activities
|
||||||
|
|
||||||
# file toxbootstrap.py is licensed under MIT License
|
License: MIT
|
||||||
License: GPLv2+ and MIT
|
URL: https://tox.readthedocs.io/
|
||||||
URL: http://tox.testrun.org/
|
Source0: %{pypi_source}
|
||||||
Source0: https://files.pythonhosted.org/packages/source/t/%{pypiname}/%{pypiname}-%{version}.tar.gz
|
|
||||||
|
# Use importlib.metadata from stdlib on Python 3.8
|
||||||
|
# Rebased from https://github.com/tox-dev/tox/pull/1368
|
||||||
|
Patch0: 1368.patch
|
||||||
|
|
||||||
|
# Run py39 env with Python 3.9
|
||||||
|
# https://bugzilla.redhat.com/show_bug.cgi?id=1798929
|
||||||
|
Patch1: py39.patch
|
||||||
|
|
||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
|
|
||||||
%description
|
%description
|
||||||
@@ -28,10 +37,10 @@ can use for:
|
|||||||
boilerplate and merging CI and shell-based testing.
|
boilerplate and merging CI and shell-based testing.
|
||||||
|
|
||||||
|
|
||||||
%package -n python3-%{pypiname}
|
%package -n python3-%{pypi_name}
|
||||||
Summary: %{summary}
|
Summary: %{summary}
|
||||||
%{?python_provide:%python_provide python3-%{pypiname}}
|
%{?python_provide:%python_provide python3-%{pypi_name}}
|
||||||
Provides: %{pypiname} = %{version}-%{release}
|
Provides: %{pypi_name} = %{version}-%{release}
|
||||||
BuildRequires: python3-devel
|
BuildRequires: python3-devel
|
||||||
BuildRequires: python3-setuptools
|
BuildRequires: python3-setuptools
|
||||||
BuildRequires: python3-setuptools_scm
|
BuildRequires: python3-setuptools_scm
|
||||||
@@ -49,7 +58,9 @@ Recommends: python34
|
|||||||
Recommends: python35
|
Recommends: python35
|
||||||
Recommends: python36
|
Recommends: python36
|
||||||
Recommends: python37
|
Recommends: python37
|
||||||
Recommends: pypy-devel
|
Recommends: python38
|
||||||
|
Recommends: python39
|
||||||
|
Recommends: pypy2-devel
|
||||||
Recommends: pypy3-devel
|
Recommends: pypy3-devel
|
||||||
Recommends: python2-devel
|
Recommends: python2-devel
|
||||||
Recommends: python3-devel
|
Recommends: python3-devel
|
||||||
@@ -57,16 +68,34 @@ Recommends: python3-devel
|
|||||||
# Replace the python2 version
|
# Replace the python2 version
|
||||||
Obsoletes: python2-tox < 2.9.1-4
|
Obsoletes: python2-tox < 2.9.1-4
|
||||||
|
|
||||||
|
# Replace detox (no longer supported, functionality is now in tox)
|
||||||
|
Obsoletes: python3-detox < 0.19-5
|
||||||
|
|
||||||
%if %{with internet}
|
%if %{with internet}
|
||||||
# for tests
|
# for tests
|
||||||
|
BuildRequires: python3-filelock
|
||||||
|
BuildRequires: python3-flaky
|
||||||
|
BuildRequires: python3-freezegun
|
||||||
|
BuildRequires: python3-packaging
|
||||||
|
BuildRequires: python3-pathlib2
|
||||||
|
BuildRequires: python3-pip
|
||||||
|
BuildRequires: python3-pluggy >= 0.12
|
||||||
|
BuildRequires: python3-psutil
|
||||||
BuildRequires: python3-py
|
BuildRequires: python3-py
|
||||||
BuildRequires: python3-pytest
|
BuildRequires: python3-pytest
|
||||||
|
BuildRequires: python3-pytest-mock
|
||||||
|
#BuildRequires: python3-pytest-randomly -- not packaged
|
||||||
|
BuildRequires: python3-pytest-xdist
|
||||||
|
BuildRequires: python3-toml
|
||||||
BuildRequires: python3-virtualenv
|
BuildRequires: python3-virtualenv
|
||||||
|
BuildRequires: python3-wheel
|
||||||
|
BuildRequires: (python3-importlib-metadata if python3 < 3.8)
|
||||||
|
BuildRequires: /usr/bin/git
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
%?python_enable_dependency_generator
|
%?python_enable_dependency_generator
|
||||||
|
|
||||||
%description -n python3-%{pypiname}
|
%description -n python3-%{pypi_name}
|
||||||
Tox as is a generic virtualenv management and test command line tool you
|
Tox as is a generic virtualenv management and test command line tool you
|
||||||
can use for:
|
can use for:
|
||||||
|
|
||||||
@@ -78,10 +107,10 @@ can use for:
|
|||||||
boilerplate and merging CI and shell-based testing.
|
boilerplate and merging CI and shell-based testing.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q -n %{pypiname}-%{version}
|
%autosetup -p1 -n %{pypi_name}-%{version}
|
||||||
|
|
||||||
# remove bundled egg-info
|
# remove bundled egg-info
|
||||||
rm -rf %{pypiname}.egg-info
|
rm -rf %{pypi_name}.egg-info
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%py3_build
|
%py3_build
|
||||||
@@ -93,16 +122,59 @@ rm -rf %{pypiname}.egg-info
|
|||||||
# if internet connection available, run tests
|
# if internet connection available, run tests
|
||||||
%if %{with internet}
|
%if %{with internet}
|
||||||
%check
|
%check
|
||||||
TOXENV=py%{python3_version_nodots} %{__python3} setup.py test
|
# there will be failures like
|
||||||
|
# ModuleNotFoundError: tox
|
||||||
|
# or InterpreterNotFound: python
|
||||||
|
# We juggle the environment variables as much as we can, but it's not perfect.
|
||||||
|
# To workaround this:
|
||||||
|
# 1. build --without internet
|
||||||
|
# 2. install the new python3-tox
|
||||||
|
# 3. build --with internet
|
||||||
|
mkdir .path
|
||||||
|
ln -s %{__python3} .path/python
|
||||||
|
ln -s /usr/bin/easy_install-%{python3_version} .path/easy_install
|
||||||
|
ln -s /usr/bin/pytest-%{python3_version} .path/pytest
|
||||||
|
ln -s /usr/bin/pip3 .path/pip
|
||||||
|
export PATH=$(pwd)/.path:%{buildroot}%{_bindir}:$PATH
|
||||||
|
export PYTHONPATH=%{buildroot}%{python3_sitelib}
|
||||||
|
export TOXENV=py%{python3_version_nodots}
|
||||||
|
export TOX_TESTENV_PASSENV="PATH TOX_TESTENV_PASSENV"
|
||||||
|
# TODO figure out why PEP517/518 tests and test_provision_cli_args_ignore won't pass
|
||||||
|
pytest-3 -n auto -k "not test_verbose_isolated_build and not test_dist_exists_version_change and not test_provision_cli_args_ignore"
|
||||||
|
rm -rf .path
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
%files -n python3-%{pypiname}
|
%files -n python3-%{pypi_name}
|
||||||
%{_bindir}/%{pypiname}
|
%{_bindir}/%{pypi_name}
|
||||||
%{_bindir}/%{pypiname}-quickstart
|
%{_bindir}/%{pypi_name}-quickstart
|
||||||
%{python3_sitelib}/%{pypiname}
|
%{python3_sitelib}/%{pypi_name}/
|
||||||
%{python3_sitelib}/%{pypiname}-%{version}-py%{python3_version}.egg-info
|
%{python3_sitelib}/%{pypi_name}-%{version}-py%{python3_version}.egg-info/
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 06 2020 Miro Hrončok <mhroncok@redhat.com> - 3.13.2-3
|
||||||
|
- Fix invocation with Python 3.9 (#1798929)
|
||||||
|
- Recommend Python 3.9
|
||||||
|
|
||||||
|
* Fri Jul 26 2019 Fedora Release Engineering <releng@fedoraproject.org> - 3.13.2-2
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
|
||||||
|
|
||||||
|
* Mon Jul 08 2019 Miro Hrončok <mhroncok@redhat.com> - 3.13.2-1
|
||||||
|
- Update to 3.13.2 (#1699032)
|
||||||
|
|
||||||
|
* Tue Apr 30 2019 Miro Hrončok <mhroncok@redhat.com> - 3.9.0-1
|
||||||
|
- Update to 3.9.0
|
||||||
|
- Obsolete detox
|
||||||
|
- License is MIT
|
||||||
|
|
||||||
|
* Fri Feb 15 2019 Lumír Balhar <lbalhar@redhat.com> - 3.5.3-3
|
||||||
|
- Recommend Python 3.8
|
||||||
|
|
||||||
|
* Sat Feb 02 2019 Fedora Release Engineering <releng@fedoraproject.org> - 3.5.3-2
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
|
||||||
|
|
||||||
|
* Thu Nov 22 2018 Artem Goncharov <artem.goncharov@gmail.com> - 3.5.3-1
|
||||||
|
- Upgrade to 3.5.3 version
|
||||||
|
|
||||||
* Mon Nov 19 2018 Artem Goncharov <artem.goncharov@gmail.com> - 3.4.0-1
|
* Mon Nov 19 2018 Artem Goncharov <artem.goncharov@gmail.com> - 3.4.0-1
|
||||||
- Upgrade to 3.4.0 version (#1652657)
|
- Upgrade to 3.4.0 version (#1652657)
|
||||||
|
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
SHA512 (tox-3.4.0.tar.gz) = c14364dffac50bece66f15545325d7912459e49979b37b48ff399610517a43a10a4c005f4ca5ec9481fb4140803a18be64f94838610e07d1e7a4b3e5df2a7d87
|
SHA512 (tox-3.13.2.tar.gz) = 06c92c803bef7c2dd3796ecc869d78dc4d3044e62688bcf529b7c6b8330532aab30dcc44425fc226886a35d8227225db5e3f2435a469e90af7ad440231abbc35
|
||||||
|
|||||||
+17
-1
@@ -1,4 +1,12 @@
|
|||||||
---
|
---
|
||||||
|
- hosts: localhost
|
||||||
|
tags:
|
||||||
|
- classic
|
||||||
|
tasks:
|
||||||
|
- dnf:
|
||||||
|
name: "*"
|
||||||
|
state: latest
|
||||||
|
|
||||||
- hosts: localhost
|
- hosts: localhost
|
||||||
roles:
|
roles:
|
||||||
- role: standard-test-basic
|
- role: standard-test-basic
|
||||||
@@ -23,14 +31,22 @@
|
|||||||
- smoke37:
|
- smoke37:
|
||||||
dir: python/smoke
|
dir: python/smoke
|
||||||
run: VERSION=3.7 ./venv.sh
|
run: VERSION=3.7 ./venv.sh
|
||||||
|
- smoke38:
|
||||||
|
dir: python/smoke
|
||||||
|
run: VERSION=3.8 ./venv.sh
|
||||||
|
- smoke39:
|
||||||
|
dir: python/smoke
|
||||||
|
run: VERSION=3.9 ./venv.sh
|
||||||
required_packages:
|
required_packages:
|
||||||
- gcc
|
- gcc
|
||||||
- /usr/bin/virtualenv
|
- virtualenv
|
||||||
- python27
|
- python27
|
||||||
- python34
|
- python34
|
||||||
- python35
|
- python35
|
||||||
- python36
|
- python36
|
||||||
- python37
|
- python37
|
||||||
|
- python38
|
||||||
|
- python39
|
||||||
- python2-devel
|
- python2-devel
|
||||||
- python3-devel
|
- python3-devel
|
||||||
- python3-tox
|
- python3-tox
|
||||||
|
|||||||
Reference in New Issue
Block a user