Pillow/Tests/test_imagepalette.py

141 lines
3.6 KiB
Python
Raw Normal View History

import pytest
from PIL import Image, ImagePalette
from .helper import PillowTestCase, assert_image_equal
2014-06-10 13:10:47 +04:00
class TestImagePalette(PillowTestCase):
def test_sanity(self):
2019-06-13 18:54:46 +03:00
ImagePalette.ImagePalette("RGB", list(range(256)) * 3)
with pytest.raises(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
assert len(test_map) == 256
with pytest.raises(ValueError):
palette.getcolor((1, 2, 3))
2017-09-01 13:36:51 +03:00
# Test unknown color specifier
with pytest.raises(ValueError):
palette.getcolor("unknown")
2017-09-01 13:36:51 +03:00
2014-06-10 13:10:47 +04:00
def test_file(self):
2019-06-13 18:54:46 +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
assert len(p[0]) == 768
assert p[1] == "RGB"
2017-09-01 13:36:51 +03:00
p = ImagePalette.raw(p[1], p[0])
assert isinstance(p, ImagePalette.ImagePalette)
assert 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
assert isinstance(lut, list)
assert len(lut) == 256
# Check values
for i in range(0, len(lut)):
assert lut[i] == i
def test_make_linear_lut_not_yet_implemented(self):
# Update after FIXME
# Arrange
black = 1
white = 255
# Act
with pytest.raises(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
assert isinstance(lut, list)
assert len(lut) == 256
2014-07-19 02:45:57 +04:00
# Check a few values
assert lut[0] == 0
assert lut[63] == 0
assert lut[127] == 8
assert lut[191] == 60
assert lut[255] == 255
2014-07-19 02:45:57 +04:00
def test_rawmode_valueerrors(self):
# Arrange
2019-06-13 18:54:46 +03:00
palette = ImagePalette.raw("RGB", list(range(256)) * 3)
# Act / Assert
with pytest.raises(ValueError):
palette.tobytes()
with pytest.raises(ValueError):
palette.getcolor((1, 2, 3))
f = self.tempfile("temp.lut")
with pytest.raises(ValueError):
palette.save(f)
def test_getdata(self):
# Arrange
2019-06-13 18:54:46 +03:00
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
assert mode == "RGB;L"
def test_rawmode_getdata(self):
# Arrange
2019-06-13 18:54:46 +03:00
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
assert rawmode == "RGB"
assert data_in == data_out
def test_2bit_palette(self):
# issue #2258, 2 bit palettes are corrupted.
2019-06-13 18:54:46 +03:00
outfile = self.tempfile("temp.png")
2017-04-20 14:14:23 +03:00
2019-06-13 18:54:46 +03:00
rgb = b"\x00" * 2 + b"\x01" * 2 + b"\x02" * 2
img = Image.frombytes("P", (6, 1), rgb)
img.putpalette(b"\xFF\x00\x00\x00\xFF\x00\x00\x00\xFF") # RGB
img.save(outfile, format="PNG")
2019-11-25 23:03:23 +03:00
with Image.open(outfile) as reloaded:
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):
with pytest.raises(IOError):
ImagePalette.load("Tests/images/hopper.jpg")