1
from __future__ import annotations
3
from pathlib import Path
9
from .helper import hopper
11
original = hopper().resize((32, 32)).convert("I")
14
def verify(im1: Image.Image) -> None:
16
assert im1.size == im2.size
19
assert pix1 is not None
20
assert pix2 is not None
21
for y in range(im1.size[1]):
22
for x in range(im1.size[0]):
28
), f"got {repr(p1)} from mode {im1.mode} at {xy}, expected {repr(p2)}"
31
@pytest.mark.parametrize("mode", ("L", "I;16", "I;16B", "I;16L", "I"))
32
def test_basic(tmp_path: Path, mode: str) -> None:
36
im_in = original.convert(mode)
44
im_out = im_in.transform((w, h), Image.Transform.EXTENT, (0, 0, w, h))
47
filename = str(tmp_path / "temp.im")
50
with Image.open(filename) as im_out:
54
im_out = im_in.crop((0, 0, w, h))
57
im_out = Image.new(mode, (w, h), None)
58
im_out.paste(im_in.crop((0, 0, w // 2, h)), (0, 0))
59
im_out.paste(im_in.crop((w // 2, 0, w, h)), (w // 2, 0))
64
im_in = Image.new(mode, (1, 1), 1)
65
assert im_in.getpixel((0, 0)) == 1
67
im_in.putpixel((0, 0), 2)
68
assert im_in.getpixel((0, 0)) == 2
75
im_in = Image.new(mode, (1, 1), 256)
76
assert im_in.getpixel((0, 0)) == min(256, maximum)
78
im_in.putpixel((0, 0), 512)
79
assert im_in.getpixel((0, 0)) == min(512, maximum)
82
def test_tobytes() -> None:
83
def tobytes(mode: str) -> bytes:
84
return Image.new(mode, (1, 1), 1).tobytes()
86
order = 1 if Image._ENDIAN == "<" else -1
88
assert tobytes("L") == b"\x01"
89
assert tobytes("I;16") == b"\x01\x00"
90
assert tobytes("I;16B") == b"\x00\x01"
91
assert tobytes("I") == b"\x01\x00\x00\x00"[::order]
94
def test_convert() -> None:
97
for mode in ("I;16", "I;16B", "I;16N"):
98
verify(im.convert(mode))
99
verify(im.convert(mode).convert("L"))
100
verify(im.convert(mode).convert("I"))