summaryrefslogtreecommitdiff
path: root/dev-python/python-jose
diff options
context:
space:
mode:
Diffstat (limited to 'dev-python/python-jose')
-rw-r--r--dev-python/python-jose/Manifest1
-rw-r--r--dev-python/python-jose/files/python-jose-3.3.0-test.patch119
-rw-r--r--dev-python/python-jose/python-jose-3.3.0-r1.ebuild48
-rw-r--r--dev-python/python-jose/python-jose-3.4.0-r1.ebuild (renamed from dev-python/python-jose/python-jose-3.4.0.ebuild)9
4 files changed, 8 insertions, 169 deletions
diff --git a/dev-python/python-jose/Manifest b/dev-python/python-jose/Manifest
index 48a43f3f8fd8..136c04aac0b3 100644
--- a/dev-python/python-jose/Manifest
+++ b/dev-python/python-jose/Manifest
@@ -1,2 +1 @@
-DIST python-jose-3.3.0.gh.tar.gz 126578 BLAKE2B d1279d2a0788b4d395e760ee3a1b2ce8c9340ad12ebe103cb1ba98aea33566cf0134d5af75be9727fff96adab4fc88f1b471ba9ea7d36c16de10587a9efd1304 SHA512 de7147cc6e12406d6e459c32829acae46395acba727c53e65bc05f4794ee3050eecd355e3ae2e87f4ebdbd871f53822eea08a10f25d7ca6088fc6128dc7d9637
DIST python-jose-3.4.0.gh.tar.gz 88084 BLAKE2B 9cec36d634019248508164a246c6debc3778321f75aec1d9870611df4b162ee87722137983124b5a5afb7525bb8dfb845e3a302068d7c1d295a326f635016ca5 SHA512 61988e07a2251b475346ac56d7845e1c573e1c4b7bdccec13937c31c325c0731c6679047451a08be79044e5a57a5470e90b43bb94b0a249c84c11675779f3dcf
diff --git a/dev-python/python-jose/files/python-jose-3.3.0-test.patch b/dev-python/python-jose/files/python-jose-3.3.0-test.patch
deleted file mode 100644
index 7f87069853d7..000000000000
--- a/dev-python/python-jose/files/python-jose-3.3.0-test.patch
+++ /dev/null
@@ -1,119 +0,0 @@
-From 19677540e74eba4392be53ae434b561cf74ad9a6 Mon Sep 17 00:00:00 2001
-From: Todd Wildey <twwildey@amazon.com>
-Date: Thu, 30 May 2024 16:02:09 -0700
-Subject: [PATCH] Adding `get_pem_for_key` and `normalize_pem` methods to
- normalize PEM formatting of keys in `tests/algorithms/test_EC.py` and
- updating `tests/algorithms/test_EC_compat.py` to use these methods
-
-Test failures were occurring due to differences of line lengths generated by the `cryptography` vs `ecdsa` PIP libraries for PEM formatting of cryptographic keys. This method removes newlines from the bodies of PEM-formated keys so that test comparisons will not fail on differentiated line lengths between PEM formattings.
----
- tests/algorithms/test_EC.py | 28 +++++++++++++++++++++++++++-
- tests/algorithms/test_EC_compat.py | 14 +++++++-------
- 2 files changed, 34 insertions(+), 8 deletions(-)
-
-diff --git a/tests/algorithms/test_EC.py b/tests/algorithms/test_EC.py
-index 6c167d29..b9028a77 100644
---- a/tests/algorithms/test_EC.py
-+++ b/tests/algorithms/test_EC.py
-@@ -1,4 +1,5 @@
- import json
-+import re
-
- from jose.backends import ECKey
- from jose.constants import ALGORITHMS
-@@ -48,6 +49,31 @@
- b"\xfeMO\x04\xb2[\x86A\xbd\xc6hu\x953X\x1e"
- )
-
-+# Define the regex pattern to capture the header, body, and footer of the PEM file
-+PEM_REGEX = re.compile(r"(-----BEGIN [A-Z ]+-----)(.*?)(-----END [A-Z ]+-----)", re.DOTALL)
-+WHITE_SPACE_REGEX = re.compile(r"\s+")
-+
-+
-+def get_pem_for_key(key):
-+ return key.to_pem().strip().decode("utf-8")
-+
-+
-+def normalize_pem(key_pem_str):
-+ # Search for the PEM sections
-+ pem_match = PEM_REGEX.search(key_pem_str)
-+ if not pem_match:
-+ raise ValueError("The provided string does not contain a valid PEM formatted data.")
-+
-+ header = pem_match.group(1)
-+ body = pem_match.group(2)
-+ footer = pem_match.group(3)
-+
-+ # Remove all newlines and spaces from the body
-+ clean_body = WHITE_SPACE_REGEX.sub("", body)
-+
-+ # Reassemble the PEM string
-+ return f"{header}\n{clean_body}\n{footer}"
-+
-
- def _backend_exception_types():
- """Build the backend exception types based on available backends."""
-@@ -104,7 +130,7 @@ def test_key_from_pem(self):
- def test_to_pem(self):
- key = ECKey(private_key, ALGORITHMS.ES256)
- assert not key.is_public()
-- assert key.to_pem().strip() == private_key.strip().encode("utf-8")
-+ assert normalize_pem(get_pem_for_key(key)) == normalize_pem(private_key.strip())
-
- public_pem = key.public_key().to_pem()
- assert ECKey(public_pem, ALGORITHMS.ES256).is_public()
-diff --git a/tests/algorithms/test_EC_compat.py b/tests/algorithms/test_EC_compat.py
-index 05d033cc..1bb7373a 100644
---- a/tests/algorithms/test_EC_compat.py
-+++ b/tests/algorithms/test_EC_compat.py
-@@ -7,7 +7,7 @@
- ECDSAECKey = CryptographyECKey = None
- from jose.constants import ALGORITHMS
-
--from .test_EC import private_key
-+from .test_EC import get_pem_for_key, normalize_pem, private_key
-
-
- @pytest.mark.backend_compatibility
-@@ -37,7 +37,7 @@ def test_public_key_to_pem(self, BackendFrom, BackendTo):
- key = BackendFrom(private_key, ALGORITHMS.ES256)
- key2 = BackendTo(private_key, ALGORITHMS.ES256)
-
-- assert key.public_key().to_pem().strip() == key2.public_key().to_pem().strip()
-+ assert normalize_pem(get_pem_for_key(key.public_key())) == normalize_pem(get_pem_for_key(key2.public_key()))
-
- @pytest.mark.parametrize("BackendFrom", [ECDSAECKey, CryptographyECKey])
- @pytest.mark.parametrize("BackendTo", [ECDSAECKey, CryptographyECKey])
-@@ -45,7 +45,7 @@ def test_private_key_to_pem(self, BackendFrom, BackendTo):
- key = BackendFrom(private_key, ALGORITHMS.ES256)
- key2 = BackendTo(private_key, ALGORITHMS.ES256)
-
-- assert key.to_pem().strip() == key2.to_pem().strip()
-+ assert normalize_pem(get_pem_for_key(key)) == normalize_pem(get_pem_for_key(key2))
-
- @pytest.mark.parametrize("BackendFrom", [ECDSAECKey, CryptographyECKey])
- @pytest.mark.parametrize("BackendTo", [ECDSAECKey, CryptographyECKey])
-@@ -53,19 +53,19 @@ def test_public_key_load_cycle(self, BackendFrom, BackendTo):
- key = BackendFrom(private_key, ALGORITHMS.ES256)
- pubkey = key.public_key()
-
-- pub_pem_source = pubkey.to_pem().strip()
-+ pub_pem_source = normalize_pem(get_pem_for_key(pubkey))
-
- pub_target = BackendTo(pub_pem_source, ALGORITHMS.ES256)
-
-- assert pub_pem_source == pub_target.to_pem().strip()
-+ assert pub_pem_source == normalize_pem(get_pem_for_key(pub_target))
-
- @pytest.mark.parametrize("BackendFrom", [ECDSAECKey, CryptographyECKey])
- @pytest.mark.parametrize("BackendTo", [ECDSAECKey, CryptographyECKey])
- def test_private_key_load_cycle(self, BackendFrom, BackendTo):
- key = BackendFrom(private_key, ALGORITHMS.ES256)
-
-- pem_source = key.to_pem().strip()
-+ pem_source = normalize_pem(get_pem_for_key(key))
-
- target = BackendTo(pem_source, ALGORITHMS.ES256)
-
-- assert pem_source == target.to_pem().strip()
-+ assert pem_source == normalize_pem(get_pem_for_key(target))
diff --git a/dev-python/python-jose/python-jose-3.3.0-r1.ebuild b/dev-python/python-jose/python-jose-3.3.0-r1.ebuild
deleted file mode 100644
index 6e741fef7628..000000000000
--- a/dev-python/python-jose/python-jose-3.3.0-r1.ebuild
+++ /dev/null
@@ -1,48 +0,0 @@
-# Copyright 1999-2024 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=8
-
-DISTUTILS_USE_PEP517=setuptools
-PYTHON_COMPAT=( python3_{9,10,11,12,13} )
-
-inherit distutils-r1
-
-DESCRIPTION="A JavaScript Object Signing and Encryption (JOSE) implementation in Python"
-HOMEPAGE="
- https://github.com/mpdavis/python-jose/
- https://pypi.org/project/python-jose/
-"
-# pypi tarball lacks unit tests
-SRC_URI="
- https://github.com/mpdavis/python-jose/archive/${PV}.tar.gz
- -> ${P}.gh.tar.gz
-"
-
-LICENSE="MIT"
-SLOT="0"
-KEYWORDS="amd64 ~arm arm64 ~ppc64 ~riscv x86 ~amd64-linux ~x86-linux"
-
-# TODO: require only one crypto backend?
-RDEPEND="
- dev-python/cryptography[${PYTHON_USEDEP}]
- dev-python/ecdsa[${PYTHON_USEDEP}]
- dev-python/pyasn1[${PYTHON_USEDEP}]
- >=dev-python/pycryptodome-3.3.1[${PYTHON_USEDEP}]
- dev-python/rsa[${PYTHON_USEDEP}]
- dev-python/six[${PYTHON_USEDEP}]
-"
-
-distutils_enable_tests pytest
-distutils_enable_sphinx docs
-
-python_prepare_all() {
- local PATCHES=(
- # https://github.com/mpdavis/python-jose/commit/19677540e74eba4392be53ae434b561cf74ad9a6
- "${FILESDIR}/${P}-test.patch"
- )
-
- distutils-r1_python_prepare_all
- sed -e '/pytest-runner/d' -i setup.py || die
- sed -e '/addopts/d' -i setup.cfg || die
-}
diff --git a/dev-python/python-jose/python-jose-3.4.0.ebuild b/dev-python/python-jose/python-jose-3.4.0-r1.ebuild
index 7deda786e451..70b6458110ca 100644
--- a/dev-python/python-jose/python-jose-3.4.0.ebuild
+++ b/dev-python/python-jose/python-jose-3.4.0-r1.ebuild
@@ -38,5 +38,12 @@ distutils_enable_sphinx docs
python_prepare_all() {
distutils-r1_python_prepare_all
- sed -e '/addopts/d' -i setup.cfg || die
+
+ # unpin dependencies
+ sed -i -e 's:, <[0-9.]*::' setup.cfg || die
+}
+
+python_test() {
+ local -x PYTEST_DISABLE_PLUGIN_AUTOLOAD=1
+ epytest -o addopts=
}