2019-07-06 23:40:53 +03:00
|
|
|
from fractions import Fraction
|
2015-11-18 19:51:57 +03:00
|
|
|
|
2019-07-06 23:40:53 +03:00
|
|
|
from PIL import Image, TiffImagePlugin
|
2015-11-18 19:51:57 +03:00
|
|
|
from PIL.TiffImagePlugin import IFDRational
|
|
|
|
|
2019-07-06 23:40:53 +03:00
|
|
|
from .helper import PillowTestCase, hopper
|
2015-11-18 19:51:57 +03:00
|
|
|
|
|
|
|
|
2016-02-05 01:57:13 +03:00
|
|
|
class Test_IFDRational(PillowTestCase):
|
2015-11-18 19:51:57 +03:00
|
|
|
def _test_equal(self, num, denom, target):
|
2016-01-24 04:44:31 +03:00
|
|
|
|
2015-11-18 19:51:57 +03:00
|
|
|
t = IFDRational(num, denom)
|
|
|
|
|
|
|
|
self.assertEqual(target, t)
|
|
|
|
self.assertEqual(t, target)
|
2016-01-24 04:44:31 +03:00
|
|
|
|
2015-11-18 19:51:57 +03:00
|
|
|
def test_sanity(self):
|
2016-01-24 04:44:31 +03:00
|
|
|
|
2015-11-18 19:51:57 +03:00
|
|
|
self._test_equal(1, 1, 1)
|
2016-02-05 01:57:13 +03:00
|
|
|
self._test_equal(1, 1, Fraction(1, 1))
|
2015-11-18 19:51:57 +03:00
|
|
|
|
|
|
|
self._test_equal(2, 2, 1)
|
2016-02-05 01:57:13 +03:00
|
|
|
self._test_equal(1.0, 1, Fraction(1, 1))
|
2016-01-24 04:44:31 +03:00
|
|
|
|
2016-02-05 01:57:13 +03:00
|
|
|
self._test_equal(Fraction(1, 1), 1, Fraction(1, 1))
|
|
|
|
self._test_equal(IFDRational(1, 1), 1, 1)
|
2016-01-24 04:44:31 +03:00
|
|
|
|
2016-02-05 01:57:13 +03:00
|
|
|
self._test_equal(1, 2, Fraction(1, 2))
|
|
|
|
self._test_equal(1, 2, IFDRational(1, 2))
|
2015-11-18 19:51:57 +03:00
|
|
|
|
|
|
|
def test_nonetype(self):
|
2019-02-03 07:59:24 +03:00
|
|
|
# Fails if the _delegate function doesn't return a valid function
|
2016-01-24 04:44:31 +03:00
|
|
|
|
|
|
|
xres = IFDRational(72)
|
|
|
|
yres = IFDRational(72)
|
2017-06-03 07:04:54 +03:00
|
|
|
self.assertIsNotNone(xres._val)
|
|
|
|
self.assertIsNotNone(xres.numerator)
|
|
|
|
self.assertIsNotNone(xres.denominator)
|
|
|
|
self.assertIsNotNone(yres._val)
|
2015-11-18 19:51:57 +03:00
|
|
|
|
2016-01-24 04:44:31 +03:00
|
|
|
self.assertTrue(xres and 1)
|
|
|
|
self.assertTrue(xres and yres)
|
2015-11-18 19:51:57 +03:00
|
|
|
|
2015-12-30 01:00:36 +03:00
|
|
|
def test_ifd_rational_save(self):
|
2016-05-06 19:07:00 +03:00
|
|
|
methods = (True, False)
|
2019-06-13 18:54:46 +03:00
|
|
|
if "libtiff_encoder" not in dir(Image.core):
|
2016-12-01 20:10:03 +03:00
|
|
|
methods = (False,)
|
2016-08-04 09:40:12 +03:00
|
|
|
|
2016-05-06 19:07:00 +03:00
|
|
|
for libtiff in methods:
|
2015-12-30 01:00:36 +03:00
|
|
|
TiffImagePlugin.WRITE_LIBTIFF = libtiff
|
2016-01-24 04:44:31 +03:00
|
|
|
|
2015-12-30 01:00:36 +03:00
|
|
|
im = hopper()
|
2019-06-13 18:54:46 +03:00
|
|
|
out = self.tempfile("temp.tiff")
|
2016-02-05 01:57:13 +03:00
|
|
|
res = IFDRational(301, 1)
|
2019-06-13 18:54:46 +03:00
|
|
|
im.save(out, dpi=(res, res), compression="raw")
|
2015-12-30 01:00:36 +03:00
|
|
|
|
|
|
|
reloaded = Image.open(out)
|
2019-06-13 18:54:46 +03:00
|
|
|
self.assertEqual(float(IFDRational(301, 1)), float(reloaded.tag_v2[282]))
|