From 027d180eda4e7ae2c21eea051feb8da09e9ad8c2 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Mon, 30 Mar 2020 21:53:02 +1100 Subject: [PATCH 1/3] Raise a DeprecationWarning when comparing PILLOW_VERSION --- Tests/test_image.py | 8 ++++++++ src/PIL/__init__.py | 25 ++++++++++++++++++++++++- 2 files changed, 32 insertions(+), 1 deletion(-) diff --git a/Tests/test_image.py b/Tests/test_image.py index 55e70a326..520364c7d 100644 --- a/Tests/test_image.py +++ b/Tests/test_image.py @@ -3,6 +3,7 @@ import os import shutil import tempfile +import PIL import pytest from PIL import Image, ImageDraw, ImagePalette, UnidentifiedImageError @@ -608,6 +609,13 @@ class TestImage: assert not fp.closed + def test_pillow_version(self): + with pytest.warns(DeprecationWarning): + assert PIL.__version__ == PIL.PILLOW_VERSION + + with pytest.warns(DeprecationWarning): + assert int(PIL.PILLOW_VERSION[0]) >= 7 + def test_overrun(self): for file in [ "fli_overrun.bin", diff --git a/src/PIL/__init__.py b/src/PIL/__init__.py index d459fa45d..3de278ded 100644 --- a/src/PIL/__init__.py +++ b/src/PIL/__init__.py @@ -13,12 +13,35 @@ Use PIL.__version__ for this Pillow version. ;-) """ +import warnings + from . import _version # VERSION was removed in Pillow 6.0.0. +__version__ = _version.__version__ + + +class _Deprecated_Version(str): + def _raise_warning(self): + warnings.warn( + "PILLOW_VERSION is deprecated and will be removed in a future release. " + "Use __version__ instead.", + DeprecationWarning, + stacklevel=3, + ) + + def __getitem__(self, key): + self._raise_warning() + return super().__getitem__(key) + + def __eq__(self, other): + self._raise_warning() + return super().__eq__(other) + + # PILLOW_VERSION is deprecated and will be removed in a future release. # Use __version__ instead. -PILLOW_VERSION = __version__ = _version.__version__ +PILLOW_VERSION = _Deprecated_Version(__version__) del _version From 7597a9fbfdfe5e347b961ad6de6019ab6f39afd5 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Tue, 31 Mar 2020 17:41:47 +1100 Subject: [PATCH 2/3] Raise warning for more operations --- Tests/test_image.py | 20 +++++++++++- src/PIL/Image.py | 20 ++++++++++-- src/PIL/__init__.py | 74 +++++++++++++++++++++++++++++++++------------ 3 files changed, 91 insertions(+), 23 deletions(-) diff --git a/Tests/test_image.py b/Tests/test_image.py index 520364c7d..9fb18b195 100644 --- a/Tests/test_image.py +++ b/Tests/test_image.py @@ -611,11 +611,29 @@ class TestImage: def test_pillow_version(self): with pytest.warns(DeprecationWarning): - assert PIL.__version__ == PIL.PILLOW_VERSION + assert PIL.PILLOW_VERSION == PIL.__version__ + + with pytest.warns(DeprecationWarning): + str(PIL.PILLOW_VERSION) with pytest.warns(DeprecationWarning): assert int(PIL.PILLOW_VERSION[0]) >= 7 + with pytest.warns(DeprecationWarning): + assert PIL.PILLOW_VERSION < "9.9.0" + + with pytest.warns(DeprecationWarning): + assert PIL.PILLOW_VERSION <= "9.9.0" + + with pytest.warns(DeprecationWarning): + assert PIL.PILLOW_VERSION != "7.0.0" + + with pytest.warns(DeprecationWarning): + assert PIL.PILLOW_VERSION >= "7.0.0" + + with pytest.warns(DeprecationWarning): + assert PIL.PILLOW_VERSION > "7.0.0" + def test_overrun(self): for file in [ "fli_overrun.bin", diff --git a/src/PIL/Image.py b/src/PIL/Image.py index 9328d44a0..7b96b14f4 100644 --- a/src/PIL/Image.py +++ b/src/PIL/Image.py @@ -42,18 +42,32 @@ from pathlib import Path # PILLOW_VERSION is deprecated and will be removed in a future release. # Use __version__ instead. from . import ( - PILLOW_VERSION, ImageMode, TiffTags, UnidentifiedImageError, __version__, _plugins, + _raise_version_warning, ) from ._binary import i8, i32le from ._util import deferred_error, isPath -# Silence warning -assert PILLOW_VERSION +if sys.version_info >= (3, 7): + + def __getattr__(name): + if name == "PILLOW_VERSION": + _raise_version_warning() + return __version__ + raise AttributeError("module '{}' has no attribute '{}'".format(__name__, name)) + + +else: + + from . import PILLOW_VERSION + + # Silence warning + assert PILLOW_VERSION + logger = logging.getLogger(__name__) diff --git a/src/PIL/__init__.py b/src/PIL/__init__.py index 3de278ded..f9cb15772 100644 --- a/src/PIL/__init__.py +++ b/src/PIL/__init__.py @@ -13,6 +13,7 @@ Use PIL.__version__ for this Pillow version. ;-) """ +import sys import warnings from . import _version @@ -21,27 +22,62 @@ from . import _version __version__ = _version.__version__ -class _Deprecated_Version(str): - def _raise_warning(self): - warnings.warn( - "PILLOW_VERSION is deprecated and will be removed in a future release. " - "Use __version__ instead.", - DeprecationWarning, - stacklevel=3, - ) - - def __getitem__(self, key): - self._raise_warning() - return super().__getitem__(key) - - def __eq__(self, other): - self._raise_warning() - return super().__eq__(other) - - # PILLOW_VERSION is deprecated and will be removed in a future release. # Use __version__ instead. -PILLOW_VERSION = _Deprecated_Version(__version__) +def _raise_version_warning(): + warnings.warn( + "PILLOW_VERSION is deprecated and will be removed in a future release. " + "Use __version__ instead.", + DeprecationWarning, + stacklevel=3, + ) + + +if sys.version_info >= (3, 7): + + def __getattr__(name): + if name == "PILLOW_VERSION": + _raise_version_warning() + return __version__ + raise AttributeError("module '{}' has no attribute '{}'".format(__name__, name)) + + +else: + + class _Deprecated_Version(str): + def __str__(self): + _raise_version_warning() + return super().__str__() + + def __getitem__(self, key): + _raise_version_warning() + return super().__getitem__(key) + + def __eq__(self, other): + _raise_version_warning() + return super().__eq__(other) + + def __ne__(self, other): + _raise_version_warning() + return super().__ne__(other) + + def __gt__(self, other): + _raise_version_warning() + return super().__gt__(other) + + def __lt__(self, other): + _raise_version_warning() + return super().__lt__(other) + + def __ge__(self, other): + _raise_version_warning() + return super().__gt__(other) + + def __le__(self, other): + _raise_version_warning() + return super().__lt__(other) + + PILLOW_VERSION = _Deprecated_Version(__version__) del _version From 750bbc72569cd36ca4219a369e84c761d6e9eec8 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Tue, 31 Mar 2020 17:25:26 +1100 Subject: [PATCH 3/3] Parametrized test --- Tests/test_image.py | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/Tests/test_image.py b/Tests/test_image.py index 9fb18b195..b0fd7c540 100644 --- a/Tests/test_image.py +++ b/Tests/test_image.py @@ -609,30 +609,33 @@ class TestImage: assert not fp.closed - def test_pillow_version(self): + @pytest.mark.parametrize( + "test_module", [PIL, Image], + ) + def test_pillow_version(self, test_module): with pytest.warns(DeprecationWarning): - assert PIL.PILLOW_VERSION == PIL.__version__ + assert test_module.PILLOW_VERSION == PIL.__version__ with pytest.warns(DeprecationWarning): - str(PIL.PILLOW_VERSION) + str(test_module.PILLOW_VERSION) with pytest.warns(DeprecationWarning): - assert int(PIL.PILLOW_VERSION[0]) >= 7 + assert int(test_module.PILLOW_VERSION[0]) >= 7 with pytest.warns(DeprecationWarning): - assert PIL.PILLOW_VERSION < "9.9.0" + assert test_module.PILLOW_VERSION < "9.9.0" with pytest.warns(DeprecationWarning): - assert PIL.PILLOW_VERSION <= "9.9.0" + assert test_module.PILLOW_VERSION <= "9.9.0" with pytest.warns(DeprecationWarning): - assert PIL.PILLOW_VERSION != "7.0.0" + assert test_module.PILLOW_VERSION != "7.0.0" with pytest.warns(DeprecationWarning): - assert PIL.PILLOW_VERSION >= "7.0.0" + assert test_module.PILLOW_VERSION >= "7.0.0" with pytest.warns(DeprecationWarning): - assert PIL.PILLOW_VERSION > "7.0.0" + assert test_module.PILLOW_VERSION > "7.0.0" def test_overrun(self): for file in [