2019-02-03 18:34:53 +03:00
|
|
|
from .helper import PillowTestCase, hopper
|
2014-07-17 02:20:19 +04:00
|
|
|
|
|
|
|
from PIL import Image, DcxImagePlugin
|
|
|
|
|
2014-09-04 14:24:53 +04:00
|
|
|
# Created with ImageMagick: convert hopper.ppm hopper.dcx
|
|
|
|
TEST_FILE = "Tests/images/hopper.dcx"
|
2014-07-17 02:20:19 +04:00
|
|
|
|
|
|
|
|
|
|
|
class TestFileDcx(PillowTestCase):
|
|
|
|
def test_sanity(self):
|
|
|
|
# Arrange
|
|
|
|
|
|
|
|
# Act
|
|
|
|
im = Image.open(TEST_FILE)
|
|
|
|
|
|
|
|
# Assert
|
|
|
|
self.assertEqual(im.size, (128, 128))
|
|
|
|
self.assertIsInstance(im, DcxImagePlugin.DcxImageFile)
|
2014-09-04 14:24:53 +04:00
|
|
|
orig = hopper()
|
2014-07-17 02:20:19 +04:00
|
|
|
self.assert_image_equal(im, orig)
|
|
|
|
|
2018-11-17 13:56:06 +03:00
|
|
|
def test_unclosed_file(self):
|
|
|
|
def open():
|
|
|
|
im = Image.open(TEST_FILE)
|
|
|
|
im.load()
|
2019-06-13 18:53:42 +03:00
|
|
|
|
2018-11-17 13:56:06 +03:00
|
|
|
self.assert_warning(None, open)
|
|
|
|
|
2015-07-03 08:03:25 +03:00
|
|
|
def test_invalid_file(self):
|
|
|
|
with open("Tests/images/flower.jpg", "rb") as fp:
|
2019-06-13 18:53:42 +03:00
|
|
|
self.assertRaises(SyntaxError, DcxImagePlugin.DcxImageFile, fp)
|
2015-07-03 08:03:25 +03:00
|
|
|
|
2014-07-17 02:20:19 +04:00
|
|
|
def test_tell(self):
|
|
|
|
# Arrange
|
|
|
|
im = Image.open(TEST_FILE)
|
|
|
|
|
|
|
|
# Act
|
|
|
|
frame = im.tell()
|
|
|
|
|
|
|
|
# Assert
|
|
|
|
self.assertEqual(frame, 0)
|
|
|
|
|
2015-06-07 18:01:34 +03:00
|
|
|
def test_n_frames(self):
|
|
|
|
im = Image.open(TEST_FILE)
|
|
|
|
self.assertEqual(im.n_frames, 1)
|
2015-06-30 06:25:00 +03:00
|
|
|
self.assertFalse(im.is_animated)
|
2015-06-07 18:01:34 +03:00
|
|
|
|
2015-06-18 17:49:18 +03:00
|
|
|
def test_eoferror(self):
|
|
|
|
im = Image.open(TEST_FILE)
|
|
|
|
n_frames = im.n_frames
|
2017-09-06 06:19:33 +03:00
|
|
|
|
|
|
|
# Test seeking past the last frame
|
|
|
|
self.assertRaises(EOFError, im.seek, n_frames)
|
|
|
|
self.assertLess(im.tell(), n_frames)
|
|
|
|
|
|
|
|
# Test that seeking to the last frame does not raise an error
|
2019-06-13 18:53:42 +03:00
|
|
|
im.seek(n_frames - 1)
|
2015-06-18 17:49:18 +03:00
|
|
|
|
2014-07-17 02:20:19 +04:00
|
|
|
def test_seek_too_far(self):
|
|
|
|
# Arrange
|
|
|
|
im = Image.open(TEST_FILE)
|
|
|
|
frame = 999 # too big on purpose
|
|
|
|
|
|
|
|
# Act / Assert
|
2017-09-01 14:05:40 +03:00
|
|
|
self.assertRaises(EOFError, im.seek, frame)
|