mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-10-24 12:41:11 +03:00
105 lines
3.0 KiB
Python
105 lines
3.0 KiB
Python
from __future__ import annotations
|
|
|
|
import io
|
|
import os
|
|
|
|
import pytest
|
|
|
|
from PIL import Image, SunImagePlugin, _binary
|
|
|
|
from .helper import assert_image_equal_tofile, assert_image_similar, hopper
|
|
|
|
EXTRA_DIR = "Tests/images/sunraster"
|
|
|
|
|
|
def test_sanity() -> None:
|
|
# Arrange
|
|
# Created with ImageMagick: convert hopper.jpg hopper.ras
|
|
test_file = "Tests/images/hopper.ras"
|
|
|
|
# Act
|
|
with Image.open(test_file) as im:
|
|
# Assert
|
|
assert im.size == (128, 128)
|
|
|
|
assert_image_similar(im, hopper(), 5) # visually verified
|
|
|
|
invalid_file = "Tests/images/flower.jpg"
|
|
with pytest.raises(SyntaxError):
|
|
SunImagePlugin.SunImageFile(invalid_file)
|
|
|
|
|
|
def test_im1() -> None:
|
|
with Image.open("Tests/images/sunraster.im1") as im:
|
|
assert_image_equal_tofile(im, "Tests/images/sunraster.im1.png")
|
|
|
|
|
|
def _sun_header(
|
|
depth: int = 0, file_type: int = 0, palette_length: int = 0
|
|
) -> io.BytesIO:
|
|
return io.BytesIO(
|
|
_binary.o32be(0x59A66A95)
|
|
+ b"\x00" * 8
|
|
+ _binary.o32be(depth)
|
|
+ b"\x00" * 4
|
|
+ _binary.o32be(file_type)
|
|
+ b"\x00" * 4
|
|
+ _binary.o32be(palette_length)
|
|
)
|
|
|
|
|
|
def test_unsupported_mode_bit_depth() -> None:
|
|
with pytest.raises(SyntaxError, match="Unsupported Mode/Bit Depth"):
|
|
with SunImagePlugin.SunImageFile(_sun_header()):
|
|
pass
|
|
|
|
|
|
def test_unsupported_color_palette_length() -> None:
|
|
with pytest.raises(SyntaxError, match="Unsupported Color Palette Length"):
|
|
with SunImagePlugin.SunImageFile(_sun_header(depth=1, palette_length=1025)):
|
|
pass
|
|
|
|
|
|
def test_unsupported_palette_type() -> None:
|
|
with pytest.raises(SyntaxError, match="Unsupported Palette Type"):
|
|
with SunImagePlugin.SunImageFile(_sun_header(depth=1, palette_length=1)):
|
|
pass
|
|
|
|
|
|
def test_unsupported_file_type() -> None:
|
|
with pytest.raises(SyntaxError, match="Unsupported Sun Raster file type"):
|
|
with SunImagePlugin.SunImageFile(_sun_header(depth=1, file_type=6)):
|
|
pass
|
|
|
|
|
|
@pytest.mark.skipif(
|
|
not os.path.exists(EXTRA_DIR), reason="Extra image files not installed"
|
|
)
|
|
def test_rgbx() -> None:
|
|
with open(os.path.join(EXTRA_DIR, "32bpp.ras"), "rb") as fp:
|
|
data = fp.read()
|
|
|
|
# Set file type to 3
|
|
data = data[:20] + _binary.o32be(3) + data[24:]
|
|
|
|
with Image.open(io.BytesIO(data)) as im:
|
|
r, g, b = im.split()
|
|
im = Image.merge("RGB", (b, g, r))
|
|
assert_image_equal_tofile(im, os.path.join(EXTRA_DIR, "32bpp.png"))
|
|
|
|
|
|
@pytest.mark.skipif(
|
|
not os.path.exists(EXTRA_DIR), reason="Extra image files not installed"
|
|
)
|
|
def test_others() -> None:
|
|
files = (
|
|
os.path.join(EXTRA_DIR, f)
|
|
for f in os.listdir(EXTRA_DIR)
|
|
if os.path.splitext(f)[1] in (".sun", ".SUN", ".ras")
|
|
)
|
|
for path in files:
|
|
with Image.open(path) as im:
|
|
im.load()
|
|
assert isinstance(im, SunImagePlugin.SunImageFile)
|
|
assert_image_equal_tofile(im, f"{os.path.splitext(path)[0]}.png")
|