Gentoo Archives: gentoo-commits

From: Maxim Koltsov <maksbotan@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-python/pip/
Date: Sun, 28 Apr 2019 08:15:45
Message-Id: 1556439300.d372a61dbfb7185fa84b53a027935e727a13d4de.maksbotan@gentoo
1 commit: d372a61dbfb7185fa84b53a027935e727a13d4de
2 Author: Maxim Koltsov <maksbotan <AT> gentoo <DOT> org>
3 AuthorDate: Sun Apr 28 08:15:00 2019 +0000
4 Commit: Maxim Koltsov <maksbotan <AT> gentoo <DOT> org>
5 CommitDate: Sun Apr 28 08:15:00 2019 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d372a61d
7
8 dev-python/pip: add tests for pip-19
9
10 Package-Manager: Portage-2.3.63, Repoman-2.3.12
11 Signed-off-by: Maxim Koltsov <maksbotan <AT> gentoo.org>
12
13 dev-python/pip/Manifest | 4 ++-
14 dev-python/pip/pip-19.1.ebuild | 60 ++++++++++++++++++++++++++++++++++++------
15 2 files changed, 55 insertions(+), 9 deletions(-)
16
17 diff --git a/dev-python/pip/Manifest b/dev-python/pip/Manifest
18 index ff87ff67b04..2b01c043541 100644
19 --- a/dev-python/pip/Manifest
20 +++ b/dev-python/pip/Manifest
21 @@ -1,3 +1,5 @@
22 DIST pip-10.0.1.tar.gz 1246072 BLAKE2B e08607be43e1d7b9c7bbc12dff73bc3170953f48f8f7439a0b27b9d540f23eb3bca7873211a5f1448b5cedd6e8e12983af6fa4666bba3ac4700059d170036733 SHA512 983cce8375ff0304263209c69be16e5be7a58af340b8c3ffddd64fcea130b2f8f8a98305ab31e9c3eed9a0d039c73777c88bde3bf2ea1e184fa3e0a2faa97fd4
23 -DIST pip-19.1.tar.gz 1334822 BLAKE2B afc2163c65a5ae181ffcf06f5fd8f321cff7c480d7cfac913b2f883c36840e79232f2a139f05659fc5bb583b8a35bdda583d22db152c8b8290c9e8c66e89dfaf SHA512 b10f6a8e0cc71b4987657acb90e677217a485f3605cca3ac9fe946102a8b6e07346d69952469db264e9aa7753015695818f107e361beab8a9fd0fbd5410900df
24 +DIST pip-19.1.tar.gz 6320747 BLAKE2B 9b69fcdef751d6938a7c67f44692afa7088f660ab1e0ae113d21d0f48b4e29f43e0f0bcc137cf16ac0324ea3b500bd2a84234823f8d82556d6727f68139aab4b SHA512 0d2442c22c41133118353ba98f45260f0615a891725b2a069d8fbf26ec4033cc7297bb671944c3dcc1f68800b91e92e58fb407ca5a333382e20ac4bb5c9e0cb6
25 DIST pip-9.0.1.tar.gz 1197370 BLAKE2B 3618161690d5e0a38d141f9b51baea4aaa3fdc225664ef180bbeecf6e2df95e9ea4f97c63fe3a68f84f4fb5ebcc74e316827253c7e07b03565e58113bbaa918a SHA512 ee59efb4b009ff6543b7afdea99b9cbbee1981ecc03af586acda76674024d3b66dab23049e68f3da9448734984619fc1eaba6e965c9dd3d731973376c8a42e25
26 +DIST setuptools-41.0.1-py2.py3-none-any.whl 575966 BLAKE2B 332986453a35e4ec36ab2bdb80a8b0a70ffe4fec1bb874f481b0d8e31016a26d53070f90d0eea9030b8c48a1f9bc21a54d8a5a2b70096e1f8db84d42449903e4 SHA512 c84ddf1d1ea90216b2c475f3e4879f4e6792a859adf61db70d67f49a35f2cb4df6fd6d93049881e6d2a8d914768edfcd091475206bb5da3ac66c41c4b9147102
27 +DIST wheel-0.33.1-py2.py3-none-any.whl 21496 BLAKE2B 41bb9ed91d43f94209a010c286d541da9d68b9e727ec8a339fe3c24fb806746b1de5b62c6cd26d2c2841be17406e1f99353b6d172f5258540faeba014945e9e8 SHA512 761ad8cb96557b146642871e1f8ce75849a9828193d992a19d072236b9f8452ab54907a3b82bc7441f75f036155ae21b7450120e0c4c19aa5100b58337945ac0
28
29 diff --git a/dev-python/pip/pip-19.1.ebuild b/dev-python/pip/pip-19.1.ebuild
30 index f549d358e60..643cf0978c1 100644
31 --- a/dev-python/pip/pip-19.1.ebuild
32 +++ b/dev-python/pip/pip-19.1.ebuild
33 @@ -6,22 +6,50 @@ EAPI=7
34 PYTHON_COMPAT=( python2_7 python3_{5,6,7} pypy{,3} )
35 PYTHON_REQ_USE="ssl(+),threads(+)"
36
37 -inherit eutils bash-completion-r1 distutils-r1
38 +inherit bash-completion-r1 distutils-r1 multiprocessing
39 +
40 +SETUPTOOLS_PV="41.0.1"
41 +WHEEL_PV="0.33.1"
42
43 DESCRIPTION="Installs python packages -- replacement for easy_install"
44 HOMEPAGE="https://pip.pypa.io/ https://pypi.org/project/pip/ https://github.com/pypa/pip/"
45 -SRC_URI="mirror://pypi/${PN:0:1}/${PN}/${P}.tar.gz"
46 +SRC_URI="
47 + https://github.com/pypa/${PN}/archive/${PV}.tar.gz -> ${P}.tar.gz
48 + test? (
49 + https://files.pythonhosted.org/packages/py2.py3/s/setuptools/setuptools-${SETUPTOOLS_PV}-py2.py3-none-any.whl
50 + https://files.pythonhosted.org/packages/py2.py3/w/wheel/wheel-${WHEEL_PV}-py2.py3-none-any.whl
51 + )
52 +"
53 +# PyPI archive does not have tests, so we need to download from GitHub.
54 +# setuptools & wheel .whl files are required for testing, exact version is not very important.
55
56 LICENSE="MIT"
57 -KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~amd64-fbsd ~amd64-linux ~x86-linux"
58 +KEYWORDS="~amd64 ~x86"
59 SLOT="0"
60 -IUSE="-vanilla"
61 +IUSE="test -vanilla"
62
63 -# required test data isn't bundled with the tarball
64 -RESTRICT="test"
65 +# disable-system-install patch breaks tests
66 +RESTRICT="!vanilla? ( test )"
67
68 -DEPEND="dev-python/setuptools[${PYTHON_USEDEP}]"
69 -RDEPEND="${DEPEND}"
70 +RDEPEND="
71 + >=dev-python/setuptools-39.2.0[${PYTHON_USEDEP}]
72 +"
73 +DEPEND="
74 + ${DEPEND}
75 + test? (
76 + dev-python/freezegun[${PYTHON_USEDEP}]
77 + dev-python/mock[${PYTHON_USEDEP}]
78 + dev-python/pretend[${PYTHON_USEDEP}]
79 + <dev-python/pytest-4[${PYTHON_USEDEP}]
80 + dev-python/pytest-cov[${PYTHON_USEDEP}]
81 + <dev-python/pytest-rerunfailures-7.0[${PYTHON_USEDEP}]
82 + dev-python/pytest-timeout[${PYTHON_USEDEP}]
83 + <dev-python/pytest-xdist-1.28.0[${PYTHON_USEDEP}]
84 + dev-python/pyyaml[${PYTHON_USEDEP}]
85 + dev-python/scripttest[${PYTHON_USEDEP}]
86 + dev-python/wheel[${PYTHON_USEDEP}]
87 + )
88 +"
89
90 python_prepare_all() {
91 local PATCHES=(
92 @@ -31,6 +59,22 @@ python_prepare_all() {
93 PATCHES+=( "${FILESDIR}/pip-19.1-disable-system-install.patch" )
94 fi
95 distutils-r1_python_prepare_all
96 +
97 + if use test; then
98 + mkdir tests/data/common_wheels/
99 + cp "${DISTDIR}"/setuptools-${SETUPTOOLS_PV}-py2.py3-none-any.whl tests/data/common_wheels/ || die
100 + cp "${DISTDIR}"/wheel-${WHEEL_PV}-py2.py3-none-any.whl tests/data/common_wheels/ || die
101 + fi
102 +}
103 +
104 +python_test () {
105 + # Exclude tests that fail for some reason. Some of these failures may be Gentoo-specific.
106 + python -m pytest \
107 + -n $(makeopts_jobs) \
108 + --timeout 300 \
109 + -k "not (svn or git or bazaar or mercurial or test_pep518_uses_build_env or test_install_package_with_root or test_install_editable_with_prefix or install_from_user or install_user_conflict or upgrade_user_conflict or build_env_isolation or config_file_venv_option or get_legacy_build_wheel or install_user_wheel or uninstall_non_local_distutils or install_from_current_directory_into_usersite or uninstall_editable_from_usersite)" \
110 + -m "not network" \
111 + || die
112 }
113
114 python_install_all() {