From e824558076f4b305fa0e4ca0f802884df77e2e57 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Fri, 8 Apr 2022 21:22:31 +1000 Subject: [PATCH] If removal version has arrived, raise an error --- Tests/test_deprecate.py | 21 +++++++++++++++++++++ src/PIL/_deprecate.py | 10 +++++++--- 2 files changed, 28 insertions(+), 3 deletions(-) diff --git a/Tests/test_deprecate.py b/Tests/test_deprecate.py index 906b337e6..30ed4a808 100644 --- a/Tests/test_deprecate.py +++ b/Tests/test_deprecate.py @@ -29,6 +29,27 @@ def test_unknown_version(): _deprecate.deprecate("Old thing", 12345, "new thing") +@pytest.mark.parametrize( + "deprecated, plural, expected", + [ + ( + "Old thing", + False, + r"Old thing is deprecated and should be removed\.", + ), + ( + "Old things", + True, + r"Old things are deprecated and should be removed\.", + ), + ], +) +def test_old_version(deprecated, plural, expected): + expected = r"" + with pytest.raises(RuntimeError, match=expected): + _deprecate.deprecate(deprecated, 1, plural=plural) + + def test_plural(): expected = ( r"Old things are deprecated and will be removed in Pillow 10 \(2023-07-01\)\. " diff --git a/src/PIL/_deprecate.py b/src/PIL/_deprecate.py index abc562570..6a148f3d8 100644 --- a/src/PIL/_deprecate.py +++ b/src/PIL/_deprecate.py @@ -2,6 +2,8 @@ from __future__ import annotations import warnings +from . import __version__ + def deprecate( deprecated: str, @@ -38,10 +40,12 @@ def deprecate( is_ = "are" if plural else "is" - if when == 10: - removed = "Pillow 10 (2023-07-01)" - elif when is None: + if when is None: removed = "a future version" + elif when <= int(__version__.split(".")[0]): + raise RuntimeError(f"{deprecated} {is_} deprecated and should be removed.") + elif when == 10: + removed = "Pillow 10 (2023-07-01)" else: raise ValueError(f"Unknown removal version, update {__name__}?")