Pillow/Tests/test_image_array.py

47 lines
1.9 KiB
Python
Raw Normal View History

from helper import unittest, PillowTestCase, hopper
from PIL import Image
im = hopper().resize((128, 100))
2014-06-10 13:10:47 +04:00
class TestImageArray(PillowTestCase):
2014-06-10 13:10:47 +04:00
def test_toarray(self):
def test(mode):
ai = im.convert(mode).__array_interface__
return ai['version'], ai["shape"], ai["typestr"], len(ai["data"])
# self.assertEqual(test("1"), (3, (100, 128), '|b1', 1600))
self.assertEqual(test("L"), (3, (100, 128), '|u1', 12800))
2014-06-10 13:10:47 +04:00
# FIXME: wrong?
self.assertEqual(test("I"), (3, (100, 128), Image._ENDIAN + 'i4', 51200))
2014-06-10 13:10:47 +04:00
# FIXME: wrong?
self.assertEqual(test("F"), (3, (100, 128), Image._ENDIAN + 'f4', 51200))
2014-06-10 13:10:47 +04:00
2016-04-28 17:30:43 +03:00
self.assertEqual(test("LA"), (3, (100, 128, 2), '|u1', 25600))
self.assertEqual(test("RGB"), (3, (100, 128, 3), '|u1', 38400))
self.assertEqual(test("RGBA"), (3, (100, 128, 4), '|u1', 51200))
self.assertEqual(test("RGBX"), (3, (100, 128, 4), '|u1', 51200))
2014-06-10 13:10:47 +04:00
def test_fromarray(self):
def test(mode):
i = im.convert(mode)
a = i.__array_interface__
2016-08-13 05:32:13 +03:00
a["strides"] = 1 # pretend it's non-contiguous
2014-06-10 13:10:47 +04:00
i.__array_interface__ = a # patch in new version of attribute
out = Image.fromarray(i)
return out.mode, out.size, list(i.getdata()) == list(out.getdata())
# self.assertEqual(test("1"), ("1", (128, 100), True))
self.assertEqual(test("L"), ("L", (128, 100), True))
self.assertEqual(test("I"), ("I", (128, 100), True))
self.assertEqual(test("F"), ("F", (128, 100), True))
2016-04-28 17:30:43 +03:00
self.assertEqual(test("LA"), ("LA", (128, 100), True))
2014-06-10 13:10:47 +04:00
self.assertEqual(test("RGB"), ("RGB", (128, 100), True))
self.assertEqual(test("RGBA"), ("RGBA", (128, 100), True))
self.assertEqual(test("RGBX"), ("RGBA", (128, 100), True))
if __name__ == '__main__':
unittest.main()