add some tests

This commit is contained in:
John Cupitt 2016-11-10 07:24:04 +00:00
parent 3d459a82c1
commit bf7f1cd9a4
2 changed files with 27 additions and 10 deletions

2
TODO
View File

@ -1,5 +1,7 @@
- test with libwebp 0.3, the earliest that supports libwebpmux - test with libwebp 0.3, the earliest that supports libwebpmux
test under valgrind
- not sure about utf8 error messages on win - not sure about utf8 error messages on win

View File

@ -15,6 +15,8 @@ import gi
gi.require_version('Vips', '8.0') gi.require_version('Vips', '8.0')
from gi.repository import Vips from gi.repository import Vips
from gi.repository import GObject
Vips.leak_set(True) Vips.leak_set(True)
# an expanding zip ... if either of the args is not a list, duplicate it down # an expanding zip ... if either of the args is not a list, duplicate it down
@ -170,17 +172,9 @@ class TestForeign(unittest.TestCase):
self.save_load("%s.jpg", self.mono) self.save_load("%s.jpg", self.mono)
self.save_load("%s.jpg", self.colour) self.save_load("%s.jpg", self.colour)
# see if we have exif parsing # see if we have exif parsing: our test image has this field
have_exif = False
x = Vips.Image.new_from_file(self.jpeg_file) x = Vips.Image.new_from_file(self.jpeg_file)
try: if x.get_typeof("exif-ifd0-Orientation") != GObject.TYPE_INVALID:
# our test image has this field
y = x.get_value("exif-ifd0-Orientation")
have_exif = True
except:
pass
if have_exif:
# we need a copy of the image to set the new metadata on # we need a copy of the image to set the new metadata on
# otherwise we get caching problems # otherwise we get caching problems
x = Vips.Image.new_from_file(self.jpeg_file) x = Vips.Image.new_from_file(self.jpeg_file)
@ -393,6 +387,27 @@ class TestForeign(unittest.TestCase):
b2 = im.webpsave_buffer(Q = 90) b2 = im.webpsave_buffer(Q = 90)
self.assertGreater(len(b2), len(b1)) self.assertGreater(len(b2), len(b1))
# try saving an image with an ICC profile and reading it back ... if we
# can do it, our webp supports metadata load/save
buf = self.colour.webpsave_buffer()
im = Vips.Image.new_from_buffer(buf, "")
if im.get_typeof("icc-profile-data") != GObject.TYPE_INVALID:
# verify that the profile comes back unharmed
p1 = self.colour.get_value("icc-profile-data")
p2 = im.get_value("icc-profile-data")
self.assertEqual(p1, p2)
# add tests for exif, xmp, exif
# the exif test will need us to be able to walk the header, we can't
# just check exif-data
# we can test that exif changes change the output of webpsave
x = self.colour.copy()
x.set_value("orientation", 6)
buf = x.webpsave_buffer()
y = Vips.Image.new_from_buffer(buf, "")
self.assertEqual(y.get_value("orientation"), 6)
def test_analyzeload(self): def test_analyzeload(self):
x = Vips.type_find("VipsForeign", "analyzeload") x = Vips.type_find("VipsForeign", "analyzeload")
if not x.is_instantiatable(): if not x.is_instantiatable():