2014-09-05 14:03:56 +04:00
|
|
|
from helper import unittest, PillowTestCase, hopper
|
2012-10-16 00:26:38 +04:00
|
|
|
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
class TestImagePutData(PillowTestCase):
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
def test_sanity(self):
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-09-05 14:03:56 +04:00
|
|
|
im1 = hopper()
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
data = list(im1.getdata())
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
im2 = Image.new(im1.mode, im1.size, 0)
|
|
|
|
im2.putdata(data)
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
self.assert_image_equal(im1, im2)
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
# readonly
|
|
|
|
im2 = Image.new(im1.mode, im2.size, 0)
|
|
|
|
im2.readonly = 1
|
|
|
|
im2.putdata(data)
|
2012-10-16 00:26:38 +04:00
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
self.assertFalse(im2.readonly)
|
|
|
|
self.assert_image_equal(im1, im2)
|
|
|
|
|
|
|
|
def test_long_integers(self):
|
|
|
|
# see bug-200802-systemerror
|
|
|
|
def put(value):
|
|
|
|
im = Image.new("RGBA", (1, 1))
|
|
|
|
im.putdata([value])
|
|
|
|
return im.getpixel((0, 0))
|
|
|
|
self.assertEqual(put(0xFFFFFFFF), (255, 255, 255, 255))
|
|
|
|
self.assertEqual(put(0xFFFFFFFF), (255, 255, 255, 255))
|
|
|
|
self.assertEqual(put(-1), (255, 255, 255, 255))
|
|
|
|
self.assertEqual(put(-1), (255, 255, 255, 255))
|
|
|
|
if sys.maxsize > 2**32:
|
|
|
|
self.assertEqual(put(sys.maxsize), (255, 255, 255, 255))
|
|
|
|
else:
|
|
|
|
self.assertEqual(put(sys.maxsize), (255, 255, 255, 127))
|
|
|
|
|
2014-07-24 02:29:10 +04:00
|
|
|
def test_pypy_performance(self):
|
2014-08-28 15:44:19 +04:00
|
|
|
im = Image.new('L', (256, 256))
|
2014-07-24 02:29:10 +04:00
|
|
|
im.putdata(list(range(256))*256)
|
|
|
|
|
2014-07-29 09:09:52 +04:00
|
|
|
def test_mode_i(self):
|
2014-09-05 14:03:56 +04:00
|
|
|
src = hopper('L')
|
2014-07-29 09:09:52 +04:00
|
|
|
data = list(src.getdata())
|
|
|
|
im = Image.new('I', src.size, 0)
|
|
|
|
im.putdata(data, 2, 256)
|
|
|
|
|
2014-08-28 15:44:19 +04:00
|
|
|
target = [2 * elt + 256 for elt in data]
|
2014-07-29 09:09:52 +04:00
|
|
|
self.assertEqual(list(im.getdata()), target)
|
|
|
|
|
|
|
|
def test_mode_F(self):
|
2014-09-05 14:03:56 +04:00
|
|
|
src = hopper('L')
|
2014-07-29 09:09:52 +04:00
|
|
|
data = list(src.getdata())
|
|
|
|
im = Image.new('F', src.size, 0)
|
|
|
|
im.putdata(data, 2.0, 256.0)
|
|
|
|
|
2014-08-28 15:44:19 +04:00
|
|
|
target = [2.0 * float(elt) + 256.0 for elt in data]
|
2014-07-29 09:09:52 +04:00
|
|
|
self.assertEqual(list(im.getdata()), target)
|
|
|
|
|
|
|
|
|
2014-06-10 13:10:47 +04:00
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|
|
|
|
|
|
|
|
# End of file
|