Pillow/Tests/test_imagepalette.py

141 lines
3.8 KiB
Python
Raw Normal View History

from .helper import unittest, PillowTestCase
from PIL import ImagePalette, Image
2014-06-10 13:10:47 +04:00
class TestImagePalette(PillowTestCase):
2014-06-10 13:10:47 +04:00
def test_sanity(self):
2017-09-01 13:36:51 +03:00
ImagePalette.ImagePalette("RGB", list(range(256))*3)
self.assertRaises(ValueError,
ImagePalette.ImagePalette, "RGB", list(range(256))*2)
2014-06-10 13:10:47 +04:00
def test_getcolor(self):
2017-09-01 13:36:51 +03:00
palette = ImagePalette.ImagePalette()
2015-04-24 11:24:52 +03:00
test_map = {}
2014-06-10 13:10:47 +04:00
for i in range(256):
2015-04-24 11:24:52 +03:00
test_map[palette.getcolor((i, i, i))] = i
2015-04-24 11:24:52 +03:00
self.assertEqual(len(test_map), 256)
2017-09-01 14:05:40 +03:00
self.assertRaises(ValueError, palette.getcolor, (1, 2, 3))
2017-09-01 13:36:51 +03:00
# Test unknown color specifier
2017-09-01 14:05:40 +03:00
self.assertRaises(ValueError, palette.getcolor, "unknown")
2017-09-01 13:36:51 +03:00
2014-06-10 13:10:47 +04:00
def test_file(self):
2017-09-01 13:36:51 +03:00
palette = ImagePalette.ImagePalette("RGB", list(range(256))*3)
f = self.tempfile("temp.lut")
palette.save(f)
2017-09-01 13:36:51 +03:00
p = ImagePalette.load(f)
2014-06-10 13:10:47 +04:00
# load returns raw palette information
self.assertEqual(len(p[0]), 768)
self.assertEqual(p[1], "RGB")
2017-09-01 13:36:51 +03:00
p = ImagePalette.raw(p[1], p[0])
self.assertIsInstance(p, ImagePalette.ImagePalette)
self.assertEqual(p.palette, palette.tobytes())
2014-06-10 13:10:47 +04:00
def test_make_linear_lut(self):
# Arrange
black = 0
white = 255
# Act
2017-09-01 13:36:51 +03:00
lut = ImagePalette.make_linear_lut(black, white)
# Assert
self.assertIsInstance(lut, list)
self.assertEqual(len(lut), 256)
# Check values
for i in range(0, len(lut)):
self.assertEqual(lut[i], i)
def test_make_linear_lut_not_yet_implemented(self):
# Update after FIXME
# Arrange
black = 1
white = 255
# Act
2017-09-01 14:05:40 +03:00
self.assertRaises(NotImplementedError,
ImagePalette.make_linear_lut, black, white)
2014-07-19 02:45:57 +04:00
def test_make_gamma_lut(self):
# Arrange
exp = 5
# Act
2017-09-01 13:36:51 +03:00
lut = ImagePalette.make_gamma_lut(exp)
2014-07-19 02:45:57 +04:00
# Assert
self.assertIsInstance(lut, list)
self.assertEqual(len(lut), 256)
# Check a few values
self.assertEqual(lut[0], 0)
self.assertEqual(lut[63], 0)
self.assertEqual(lut[127], 8)
self.assertEqual(lut[191], 60)
self.assertEqual(lut[255], 255)
def test_rawmode_valueerrors(self):
# Arrange
2017-09-01 13:36:51 +03:00
palette = ImagePalette.raw("RGB", list(range(256))*3)
# Act / Assert
2015-04-02 10:08:14 +03:00
self.assertRaises(ValueError, palette.tobytes)
2017-09-01 14:05:40 +03:00
self.assertRaises(ValueError, palette.getcolor, (1, 2, 3))
f = self.tempfile("temp.lut")
2017-09-01 14:05:40 +03:00
self.assertRaises(ValueError, palette.save, f)
def test_getdata(self):
# Arrange
data_in = list(range(256))*3
2017-09-01 13:36:51 +03:00
palette = ImagePalette.ImagePalette("RGB", data_in)
# Act
mode, data_out = palette.getdata()
# Assert
self.assertEqual(mode, "RGB;L")
def test_rawmode_getdata(self):
# Arrange
data_in = list(range(256))*3
2017-09-01 13:36:51 +03:00
palette = ImagePalette.raw("RGB", data_in)
# Act
rawmode, data_out = palette.getdata()
# Assert
self.assertEqual(rawmode, "RGB")
self.assertEqual(data_in, data_out)
def test_2bit_palette(self):
# issue #2258, 2 bit palettes are corrupted.
outfile = self.tempfile('temp.png')
2017-04-20 14:14:23 +03:00
rgb = b'\x00' * 2 + b'\x01' * 2 + b'\x02' * 2
img = Image.frombytes('P', (6, 1), rgb)
2017-04-20 14:14:23 +03:00
img.putpalette(b'\xFF\x00\x00\x00\xFF\x00\x00\x00\xFF') # RGB
img.save(outfile, format='PNG')
reloaded = Image.open(outfile)
self.assert_image_equal(img, reloaded)
2017-04-20 14:14:23 +03:00
2017-09-01 13:36:51 +03:00
def test_invalid_palette(self):
self.assertRaises(IOError,
ImagePalette.load, "Tests/images/hopper.jpg")
2017-09-01 13:36:51 +03:00
2014-07-19 02:45:57 +04:00
2014-06-10 13:10:47 +04:00
if __name__ == '__main__':
unittest.main()