Merge branch 'master' into rm-2.7

This commit is contained in:
Hugo van Kemenade 2019-11-20 10:26:55 +02:00 committed by GitHub
commit a949d7882e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 24 additions and 12 deletions

View File

@ -5,6 +5,9 @@ Changelog (Pillow)
7.0.0 (unreleased) 7.0.0 (unreleased)
------------------ ------------------
- Remove deprecated __version__ from plugins #4197
[hugovk, radarhere]
- Fixed freeing unallocated pointer when resizing with height too large #4116 - Fixed freeing unallocated pointer when resizing with height too large #4116
[radarhere] [radarhere]

View File

@ -1,4 +1,4 @@
from PIL import GdImageFile from PIL import GdImageFile, UnidentifiedImageError
from .helper import PillowTestCase from .helper import PillowTestCase
@ -17,4 +17,4 @@ class TestFileGd(PillowTestCase):
def test_invalid_file(self): def test_invalid_file(self):
invalid_file = "Tests/images/flower.jpg" invalid_file = "Tests/images/flower.jpg"
self.assertRaises(IOError, GdImageFile.open, invalid_file) self.assertRaises(UnidentifiedImageError, GdImageFile.open, invalid_file)

View File

@ -2,7 +2,7 @@ import os
import shutil import shutil
import tempfile import tempfile
from PIL import Image from PIL import Image, UnidentifiedImageError
from .helper import PillowTestCase, hopper, is_win32, unittest from .helper import PillowTestCase, hopper, is_win32, unittest
@ -47,6 +47,9 @@ class TestImage(PillowTestCase):
Image.new(mode, (1, 1)) Image.new(mode, (1, 1))
self.assertEqual(str(e.exception), "unrecognized image mode") self.assertEqual(str(e.exception), "unrecognized image mode")
def test_exception_inheritance(self):
self.assertTrue(issubclass(UnidentifiedImageError, IOError))
def test_sanity(self): def test_sanity(self):
im = Image.new("L", (100, 100)) im = Image.new("L", (100, 100))
@ -82,7 +85,7 @@ class TestImage(PillowTestCase):
import io import io
im = io.BytesIO(b"") im = io.BytesIO(b"")
self.assertRaises(IOError, Image.open, im) self.assertRaises(UnidentifiedImageError, Image.open, im)
def test_bad_mode(self): def test_bad_mode(self):
self.assertRaises(ValueError, Image.open, "filename", "bad mode") self.assertRaises(ValueError, Image.open, "filename", "bad mode")

View File

@ -63,11 +63,11 @@ TODO
API Additions API Additions
============= =============
TODO Custom unidentified image error
^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
TODO
Pillow will now throw a custom ``UnidentifiedImageError`` when an image cannot be
identified. For backwards compatibility, this will inherit from ``IOError``.
Other Changes Other Changes
============= =============

View File

@ -23,7 +23,7 @@
# purposes only. # purposes only.
from . import ImageFile, ImagePalette from . import ImageFile, ImagePalette, UnidentifiedImageError
from ._binary import i8, i16be as i16, i32be as i32 from ._binary import i8, i16be as i16, i32be as i32
## ##
@ -82,4 +82,4 @@ def open(fp, mode="r"):
try: try:
return GdImageFile(fp) return GdImageFile(fp)
except SyntaxError: except SyntaxError:
raise OSError("cannot identify this image file") raise UnidentifiedImageError("cannot identify this image file")

View File

@ -41,7 +41,7 @@ from pathlib import Path
# VERSION was removed in Pillow 6.0.0. # VERSION was removed in Pillow 6.0.0.
# PILLOW_VERSION was removed in Pillow 7.0.0. # PILLOW_VERSION was removed in Pillow 7.0.0.
# Use __version__ instead. # Use __version__ instead.
from . import ImageMode, TiffTags, __version__, _plugins from . import ImageMode, TiffTags, UnidentifiedImageError, __version__, _plugins
from ._binary import i8, i32le from ._binary import i8, i32le
from ._util import deferred_error, isPath from ._util import deferred_error, isPath
@ -2743,7 +2743,9 @@ def open(fp, mode="r"):
fp.close() fp.close()
for message in accept_warnings: for message in accept_warnings:
warnings.warn(message) warnings.warn(message)
raise OSError("cannot identify image file %r" % (filename if filename else fp)) raise UnidentifiedImageError(
"cannot identify image file %r" % (filename if filename else fp)
)
# #

View File

@ -70,3 +70,7 @@ _plugins = [
"XpmImagePlugin", "XpmImagePlugin",
"XVThumbImagePlugin", "XVThumbImagePlugin",
] ]
class UnidentifiedImageError(IOError):
pass