From 5256ef5b9c9a53373f7d84aa46266fac6e5f47e2 Mon Sep 17 00:00:00 2001 From: Hynek Schlawack Date: Wed, 26 Jun 2024 10:41:25 +0200 Subject: [PATCH] Drop deprecated packaging metadata Keeping __version__ around since it's still widely used, unfortunately. Fixes #68 --- src/service_identity/__init__.py | 31 +++------------------------ tests/test_packaging.py | 36 ++++---------------------------- 2 files changed, 7 insertions(+), 60 deletions(-) diff --git a/src/service_identity/__init__.py b/src/service_identity/__init__.py index 9c0c244..f018a37 100644 --- a/src/service_identity/__init__.py +++ b/src/service_identity/__init__.py @@ -29,35 +29,10 @@ def __getattr__(name: str) -> str: - dunder_to_metadata = { - "__version__": "version", - "__description__": "summary", - "__uri__": "", - "__url__": "", - "__email__": "", - } - if name not in dunder_to_metadata: + if name != "__version__": msg = f"module {__name__} has no attribute {name}" raise AttributeError(msg) - import warnings + from importlib.metadata import version - from importlib.metadata import metadata - - warnings.warn( - f"Accessing service_identity.{name} is deprecated and will be " - "removed in a future release. Use importlib.metadata directly " - "to query packaging metadata.", - DeprecationWarning, - stacklevel=2, - ) - - meta = metadata("service-identity") - - if name in ("__uri__", "__url__"): - return meta["Project-URL"].split(" ", 1)[1] - - if name == "__email__": - return meta["Author-email"].split("<", 1)[1].rstrip(">") - - return meta[dunder_to_metadata[name]] + return version("service-identity") diff --git a/tests/test_packaging.py b/tests/test_packaging.py index 712f3d0..c63a294 100644 --- a/tests/test_packaging.py +++ b/tests/test_packaging.py @@ -10,38 +10,10 @@ def test_version(self): """ service_identity.__version__ returns the correct version. """ - with pytest.deprecated_call(): - assert ( - metadata.version("service-identity") - == service_identity.__version__ - ) - - def test_description(self): - """ - service_identity.__description__ returns the correct description. - """ - with pytest.deprecated_call(): - assert ( - "Service identity verification for pyOpenSSL & cryptography." - == service_identity.__description__ - ) - - @pytest.mark.parametrize("name", ["uri", "url"]) - def test_uri(self, name): - """ - service_identity.__uri__ & __url__ return the correct project URL. - """ - with pytest.deprecated_call(): - assert "https://service-identity.readthedocs.io/" == getattr( - service_identity, f"__{name}__" - ) - - def test_email(self): - """ - service_identity.__email__ returns Hynek's email address. - """ - with pytest.deprecated_call(): - assert "hs@ox.cx" == service_identity.__email__ + assert ( + metadata.version("service-identity") + == service_identity.__version__ + ) def test_does_not_exist(self): """