mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-28 02:04:36 +03:00
add test for regression
This commit is contained in:
parent
f8d4aa5882
commit
e7aa44f58c
|
@ -9,14 +9,7 @@ except ImportError:
|
||||||
HAVE_WEBP = False
|
HAVE_WEBP = False
|
||||||
|
|
||||||
|
|
||||||
class TestFileWebp(PillowTestCase):
|
class TestUnsupportedWebp(PillowTestCase):
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
if not HAVE_WEBP:
|
|
||||||
return
|
|
||||||
|
|
||||||
self.rgb_mode = "RGB"
|
|
||||||
|
|
||||||
def test_unsupported(self):
|
def test_unsupported(self):
|
||||||
if HAVE_WEBP:
|
if HAVE_WEBP:
|
||||||
WebPImagePlugin.SUPPORTED = False
|
WebPImagePlugin.SUPPORTED = False
|
||||||
|
@ -28,12 +21,18 @@ class TestFileWebp(PillowTestCase):
|
||||||
if HAVE_WEBP:
|
if HAVE_WEBP:
|
||||||
WebPImagePlugin.SUPPORTED = True
|
WebPImagePlugin.SUPPORTED = True
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
|
|
||||||
|
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
||||||
|
class TestFileWebp(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
self.rgb_mode = "RGB"
|
||||||
|
|
||||||
def test_version(self):
|
def test_version(self):
|
||||||
_webp.WebPDecoderVersion()
|
_webp.WebPDecoderVersion()
|
||||||
_webp.WebPDecoderBuggyAlpha()
|
_webp.WebPDecoderBuggyAlpha()
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_read_rgb(self):
|
def test_read_rgb(self):
|
||||||
"""
|
"""
|
||||||
Can we read a RGB mode WebP file without error?
|
Can we read a RGB mode WebP file without error?
|
||||||
|
@ -53,7 +52,6 @@ class TestFileWebp(PillowTestCase):
|
||||||
self.assert_image_similar_tofile(
|
self.assert_image_similar_tofile(
|
||||||
image, 'Tests/images/hopper_webp_bits.ppm', 1.0)
|
image, 'Tests/images/hopper_webp_bits.ppm', 1.0)
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_write_rgb(self):
|
def test_write_rgb(self):
|
||||||
"""
|
"""
|
||||||
Can we write a RGB mode file to webp without error.
|
Can we write a RGB mode file to webp without error.
|
||||||
|
@ -83,7 +81,6 @@ class TestFileWebp(PillowTestCase):
|
||||||
target = hopper(self.rgb_mode)
|
target = hopper(self.rgb_mode)
|
||||||
self.assert_image_similar(image, target, 12.0)
|
self.assert_image_similar(image, target, 12.0)
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_write_unsupported_mode_L(self):
|
def test_write_unsupported_mode_L(self):
|
||||||
"""
|
"""
|
||||||
Saving a black-and-white file to WebP format should work, and be
|
Saving a black-and-white file to WebP format should work, and be
|
||||||
|
@ -104,7 +101,6 @@ class TestFileWebp(PillowTestCase):
|
||||||
|
|
||||||
self.assert_image_similar(image, target, 10.0)
|
self.assert_image_similar(image, target, 10.0)
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_write_unsupported_mode_P(self):
|
def test_write_unsupported_mode_P(self):
|
||||||
"""
|
"""
|
||||||
Saving a palette-based file to WebP format should work, and be
|
Saving a palette-based file to WebP format should work, and be
|
||||||
|
@ -125,7 +121,6 @@ class TestFileWebp(PillowTestCase):
|
||||||
|
|
||||||
self.assert_image_similar(image, target, 50.0)
|
self.assert_image_similar(image, target, 50.0)
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_WebPEncode_with_invalid_args(self):
|
def test_WebPEncode_with_invalid_args(self):
|
||||||
"""
|
"""
|
||||||
Calling encoder functions with no arguments should result in an error.
|
Calling encoder functions with no arguments should result in an error.
|
||||||
|
@ -135,7 +130,6 @@ class TestFileWebp(PillowTestCase):
|
||||||
self.assertRaises(TypeError, _webp.WebPAnimEncoder)
|
self.assertRaises(TypeError, _webp.WebPAnimEncoder)
|
||||||
self.assertRaises(TypeError, _webp.WebPEncode)
|
self.assertRaises(TypeError, _webp.WebPEncode)
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_WebPDecode_with_invalid_args(self):
|
def test_WebPDecode_with_invalid_args(self):
|
||||||
"""
|
"""
|
||||||
Calling decoder functions with no arguments should result in an error.
|
Calling decoder functions with no arguments should result in an error.
|
||||||
|
@ -145,7 +139,6 @@ class TestFileWebp(PillowTestCase):
|
||||||
self.assertRaises(TypeError, _webp.WebPAnimDecoder)
|
self.assertRaises(TypeError, _webp.WebPAnimDecoder)
|
||||||
self.assertRaises(TypeError, _webp.WebPDecode)
|
self.assertRaises(TypeError, _webp.WebPDecode)
|
||||||
|
|
||||||
@unittest.skipIf(not HAVE_WEBP, "WebP support not installed")
|
|
||||||
def test_no_resource_warning(self):
|
def test_no_resource_warning(self):
|
||||||
file_path = "Tests/images/hopper.webp"
|
file_path = "Tests/images/hopper.webp"
|
||||||
image = Image.open(file_path)
|
image = Image.open(file_path)
|
||||||
|
@ -153,6 +146,12 @@ class TestFileWebp(PillowTestCase):
|
||||||
temp_file = self.tempfile("temp.webp")
|
temp_file = self.tempfile("temp.webp")
|
||||||
self.assert_warning(None, image.save, temp_file)
|
self.assert_warning(None, image.save, temp_file)
|
||||||
|
|
||||||
|
def test_file_pointer_could_be_reused(self):
|
||||||
|
file_path = "Tests/images/hopper.webp"
|
||||||
|
with open(file_path, 'rb') as blob:
|
||||||
|
Image.open(blob).load()
|
||||||
|
Image.open(blob).load()
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user