diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/ReadMetadataTestCase.py | 125 | ||||
-rw-r--r-- | test/data/exiv2-bug540.jpg | bin | 0 -> 10011 bytes |
2 files changed, 124 insertions, 1 deletions
diff --git a/test/ReadMetadataTestCase.py b/test/ReadMetadataTestCase.py index b99a221..358cf7c 100644 --- a/test/ReadMetadataTestCase.py +++ b/test/ReadMetadataTestCase.py @@ -66,6 +66,12 @@ class ReadMetadataTestCase(unittest.TestCase): self.assertEqual(type(tag.values[0]), etype) self.assertEqual(tag.values[0], evalue) + def assertCorrectFile(self, filename, md5sum): + """ + Ensure that the filename and the MD5 checksum match up. + """ + self.assert_(testutils.CheckFileSum(filename, md5sum)) + def testReadMetadata(self): """ Perform various tests on reading the metadata contained in a file. @@ -73,7 +79,7 @@ class ReadMetadataTestCase(unittest.TestCase): # Check that the reference file is not corrupted filename = os.path.join('data', 'smiley1.jpg') md5sum = 'c066958457c685853293058f9bf129c1' - self.assert_(testutils.CheckFileSum(filename, md5sum)) + self.assertCorrectFile(filename, md5sum) # Read the image metadata image = pyexiv2.ImageMetadata(filename) @@ -111,3 +117,120 @@ class ReadMetadataTestCase(unittest.TestCase): self.assertEqual(image.iptc_keys, [tag[0] for tag in iptcTags]) for key, ktype, value in iptcTags: self.checkIPTCTypeAndValue(image[key], ktype, value) + + def testReadMetadataXMP(self): + filename = os.path.join('data', 'exiv2-bug540.jpg') + md5sum = '64d4b7eab1e78f1f6bfb3c966e99eef2' + self.assertCorrectFile(filename, md5sum) + + # Read the image metadata + image = pyexiv2.ImageMetadata(filename) + image.read() + + xmpTags = [('Xmp.dc.creator', 'seq ProperName', [u'Ian Britton']), + ('Xmp.dc.description', 'Lang Alt', {u'x-default': u'Communications'}), + ('Xmp.dc.rights', 'Lang Alt', {u'x-default': u'ian Britton - FreeFoto.com'}), + ('Xmp.dc.source', 'Text', u'FreeFoto.com'), + ('Xmp.dc.subject', 'bag Text', [u'Communications']), + ('Xmp.dc.title', 'Lang Alt', {u'x-default': u'Communications'}), + ('Xmp.exif.ApertureValue', + 'Rational', + pyexiv2.utils.Rational(8, 1)), + ('Xmp.exif.BrightnessValue', + 'Rational', + pyexiv2.utils.Rational(333, 1280)), + ('Xmp.exif.ColorSpace', 'Closed Choice of Integer', 1), + ('Xmp.exif.DateTimeOriginal', + 'Date', + datetime.datetime(2002, 7, 13, 15, 58, 28, tzinfo=pyexiv2.utils.FixedOffset())), + ('Xmp.exif.ExifVersion', 'Closed Choice of Text', u'0200'), + ('Xmp.exif.ExposureBiasValue', + 'Rational', + pyexiv2.utils.Rational(-13, 20)), + ('Xmp.exif.ExposureProgram', 'Closed Choice of Integer', 4), + ('Xmp.exif.FNumber', + 'Rational', + pyexiv2.utils.Rational(3, 5)), + ('Xmp.exif.FileSource', 'Closed Choice of Integer', 0), + ('Xmp.exif.FlashpixVersion', 'Closed Choice of Text', u'0100'), + ('Xmp.exif.FocalLength', + 'Rational', + pyexiv2.utils.Rational(0, 1)), + ('Xmp.exif.FocalPlaneResolutionUnit', 'Closed Choice of Integer', 2), + ('Xmp.exif.FocalPlaneXResolution', + 'Rational', + pyexiv2.utils.Rational(3085, 256)), + ('Xmp.exif.FocalPlaneYResolution', + 'Rational', + pyexiv2.utils.Rational(3085, 256)), + ('Xmp.exif.GPSLatitude', + 'GPSCoordinate', + pyexiv2.utils.GPSCoordinate.from_string('54,59.380000N')), + ('Xmp.exif.GPSLongitude', + 'GPSCoordinate', + pyexiv2.utils.GPSCoordinate.from_string('1,54.850000W')), + ('Xmp.exif.GPSMapDatum', 'Text', u'WGS84'), + ('Xmp.exif.GPSTimeStamp', + 'Date', + datetime.datetime(2002, 7, 13, 14, 58, 24, tzinfo=pyexiv2.utils.FixedOffset())), + ('Xmp.exif.GPSVersionID', 'Text', u'2.0.0.0'), + ('Xmp.exif.ISOSpeedRatings', 'seq Integer', [0]), + ('Xmp.exif.MeteringMode', 'Closed Choice of Integer', 5), + ('Xmp.exif.PixelXDimension', 'Integer', 2400), + ('Xmp.exif.PixelYDimension', 'Integer', 1600), + ('Xmp.exif.SceneType', 'Closed Choice of Integer', 0), + ('Xmp.exif.SensingMethod', 'Closed Choice of Integer', 2), + ('Xmp.exif.ShutterSpeedValue', + 'Rational', + pyexiv2.utils.Rational(30827, 3245)), + ('Xmp.pdf.Keywords', 'Text', u'Communications'), + ('Xmp.photoshop.AuthorsPosition', 'Text', u'Photographer'), + ('Xmp.photoshop.CaptionWriter', 'ProperName', u'Ian Britton'), + ('Xmp.photoshop.Category', 'Text', u'BUS'), + ('Xmp.photoshop.City', 'Text', u' '), + ('Xmp.photoshop.Country', 'Text', u'Ubited Kingdom'), + ('Xmp.photoshop.Credit', 'Text', u'Ian Britton'), + ('Xmp.photoshop.DateCreated', 'Date', datetime.date(2002, 6, 20)), + ('Xmp.photoshop.Headline', 'Text', u'Communications'), + ('Xmp.photoshop.State', 'Text', u' '), + ('Xmp.photoshop.SupplementalCategories', 'bag Text', [u'Communications']), + ('Xmp.photoshop.Urgency', 'Integer', 5), + ('Xmp.tiff.Artist', 'ProperName', u'Ian Britton'), + ('Xmp.tiff.BitsPerSample', 'seq Integer', [8]), + ('Xmp.tiff.Compression', 'Closed Choice of Integer', 6), + ('Xmp.tiff.Copyright', + 'Lang Alt', + {u'x-default': u'ian Britton - FreeFoto.com'}), + ('Xmp.tiff.ImageDescription', 'Lang Alt', {u'x-default': u'Communications'}), + ('Xmp.tiff.ImageLength', 'Integer', 400), + ('Xmp.tiff.ImageWidth', 'Integer', 600), + ('Xmp.tiff.Make', 'ProperName', u'FUJIFILM'), + ('Xmp.tiff.Model', 'ProperName', u'FinePixS1Pro'), + ('Xmp.tiff.Orientation', 'Closed Choice of Integer', 1), + ('Xmp.tiff.ResolutionUnit', 'Closed Choice of Integer', 2), + ('Xmp.tiff.Software', 'AgentName', u'Adobe Photoshop 7.0'), + ('Xmp.tiff.XResolution', + 'Rational', + pyexiv2.utils.Rational(300, 1)), + ('Xmp.tiff.YCbCrPositioning', 'Closed Choice of Integer', 2), + ('Xmp.tiff.YResolution', + 'Rational', + pyexiv2.utils.Rational(300, 1)), + ('Xmp.xmp.CreateDate', + 'Date', + datetime.datetime(2002, 7, 13, 15, 58, 28, tzinfo=pyexiv2.utils.FixedOffset())), + ('Xmp.xmp.ModifyDate', + 'Date', + datetime.datetime(2002, 7, 19, 13, 28, 10, tzinfo=pyexiv2.utils.FixedOffset())), + ('Xmp.xmpBJ.JobRef', 'bag Job', []), + ('Xmp.xmpBJ.JobRef[1]', '', ''), + ('Xmp.xmpBJ.JobRef[1]/stJob:name', '', 'Photographer'), + ('Xmp.xmpMM.DocumentID', + 'URI', + 'adobe:docid:photoshop:84d4dba8-9b11-11d6-895d-c4d063a70fb0'), + ('Xmp.xmpRights.Marked', 'Boolean', True), + ('Xmp.xmpRights.WebStatement', 'URL', 'www.freefoto.com')] + for key, xtype, value in xmpTags: + tag = image[key] + self.assertEqual(tag.type, xtype) + self.assertEqual(tag.value, value) diff --git a/test/data/exiv2-bug540.jpg b/test/data/exiv2-bug540.jpg Binary files differnew file mode 100644 index 0000000..62c0e56 --- /dev/null +++ b/test/data/exiv2-bug540.jpg |