1
from __future__ import annotations
5
from PIL import Image, ImageEnhance
7
from .helper import assert_image_equal, hopper
10
def test_sanity() -> None:
13
ImageEnhance.Color(hopper()).enhance(0.5)
14
ImageEnhance.Contrast(hopper()).enhance(0.5)
15
ImageEnhance.Brightness(hopper()).enhance(0.5)
16
ImageEnhance.Sharpness(hopper()).enhance(0.5)
19
def test_crash() -> None:
21
im = Image.new("RGB", (1, 1))
22
ImageEnhance.Sharpness(im).enhance(0.5)
25
def _half_transparent_image() -> Image.Image:
29
transparent = Image.new("L", im.size, 0)
30
solid = Image.new("L", (im.size[0] // 2, im.size[1]), 255)
31
transparent.paste(solid, (0, 0))
32
im.putalpha(transparent)
38
im: Image.Image, original: Image.Image, op: str, amount: float
40
assert im.getbands() == original.getbands()
43
original.getchannel("A"),
44
f"Diff on {op}: {amount}",
48
@pytest.mark.parametrize("op", ("Color", "Brightness", "Contrast", "Sharpness"))
49
def test_alpha(op: str) -> None:
53
original = _half_transparent_image()
55
for amount in [0, 0.5, 1.0]:
57
getattr(ImageEnhance, op)(original).enhance(amount),