-
-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
Copy pathtest_tiff_ifdrational.py
69 lines (46 loc) · 1.66 KB
/
test_tiff_ifdrational.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
from __future__ import annotations
from fractions import Fraction
from pathlib import Path
from PIL import Image, TiffImagePlugin, features
from PIL.TiffImagePlugin import IFDRational
from .helper import hopper
def _test_equal(num, denom, target) -> None:
t = IFDRational(num, denom)
assert target == t
assert t == target
def test_sanity() -> None:
_test_equal(1, 1, 1)
_test_equal(1, 1, Fraction(1, 1))
_test_equal(2, 2, 1)
_test_equal(1.0, 1, Fraction(1, 1))
_test_equal(Fraction(1, 1), 1, Fraction(1, 1))
_test_equal(IFDRational(1, 1), 1, 1)
_test_equal(1, 2, Fraction(1, 2))
_test_equal(1, 2, IFDRational(1, 2))
_test_equal(7, 5, 1.4)
def test_ranges() -> None:
for num in range(1, 10):
for denom in range(1, 10):
assert IFDRational(num, denom) == IFDRational(num, denom)
def test_nonetype() -> None:
# Fails if the _delegate function doesn't return a valid function
xres = IFDRational(72)
yres = IFDRational(72)
assert xres._val is not None
assert xres.numerator is not None
assert xres.denominator is not None
assert yres._val is not None
assert xres and 1
assert xres and yres
def test_ifd_rational_save(tmp_path: Path) -> None:
methods = [True]
if features.check("libtiff"):
methods.append(False)
for libtiff in methods:
TiffImagePlugin.WRITE_LIBTIFF = libtiff
im = hopper()
out = str(tmp_path / "temp.tiff")
res = IFDRational(301, 1)
im.save(out, dpi=(res, res), compression="raw")
with Image.open(out) as reloaded:
assert float(IFDRational(301, 1)) == float(reloaded.tag_v2[282])