zip archives: keep individual files compression type
While hardcoding the compression to zipfile.ZIP_DEFLATED works for most use cases of mat, being able to produce cleaned up uncompressed zip files is useful for content that cannot be compressed more. In addition it also enables to use mat2 for reproducible builds of Android bootanimation files file that don't support compression. Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
This commit is contained in:
parent
541b3c83b2
commit
1703ed6ebb
2 changed files with 62 additions and 8 deletions
|
@ -175,14 +175,30 @@ class TestGetMeta(unittest.TestCase):
|
|||
|
||||
def test_zip(self):
|
||||
with zipfile.ZipFile('./tests/data/dirty.zip', 'w') as zout:
|
||||
zout.write('./tests/data/dirty.flac')
|
||||
zout.write('./tests/data/dirty.docx')
|
||||
zout.write('./tests/data/dirty.jpg')
|
||||
zout.write('./tests/data/dirty.flac',
|
||||
compress_type = zipfile.ZIP_STORED)
|
||||
zout.write('./tests/data/dirty.docx',
|
||||
compress_type = zipfile.ZIP_DEFLATED)
|
||||
zout.write('./tests/data/dirty.jpg',
|
||||
compress_type = zipfile.ZIP_BZIP2)
|
||||
zout.write('./tests/data/dirty.txt',
|
||||
compress_type = zipfile.ZIP_LZMA)
|
||||
p, mimetype = parser_factory.get_parser('./tests/data/dirty.zip')
|
||||
self.assertEqual(mimetype, 'application/zip')
|
||||
meta = p.get_meta()
|
||||
self.assertEqual(meta['tests/data/dirty.flac']['comments'], 'Thank you for using MAT !')
|
||||
self.assertEqual(meta['tests/data/dirty.docx']['word/media/image1.png']['Comment'], 'This is a comment, be careful!')
|
||||
|
||||
with zipfile.ZipFile('./tests/data/dirty.zip') as zipin:
|
||||
members = {
|
||||
'tests/data/dirty.flac' : zipfile.ZIP_STORED,
|
||||
'tests/data/dirty.docx': zipfile.ZIP_DEFLATED,
|
||||
'tests/data/dirty.jpg' : zipfile.ZIP_BZIP2,
|
||||
'tests/data/dirty.txt' : zipfile.ZIP_LZMA,
|
||||
}
|
||||
for k, v in members.items():
|
||||
self.assertEqual(zipin.getinfo(k).compress_type, v)
|
||||
|
||||
os.remove('./tests/data/dirty.zip')
|
||||
|
||||
def test_wmv(self):
|
||||
|
@ -595,9 +611,14 @@ class TestCleaning(unittest.TestCase):
|
|||
class TestCleaningArchives(unittest.TestCase):
|
||||
def test_zip(self):
|
||||
with zipfile.ZipFile('./tests/data/dirty.zip', 'w') as zout:
|
||||
zout.write('./tests/data/dirty.flac')
|
||||
zout.write('./tests/data/dirty.docx')
|
||||
zout.write('./tests/data/dirty.jpg')
|
||||
zout.write('./tests/data/dirty.flac',
|
||||
compress_type = zipfile.ZIP_STORED)
|
||||
zout.write('./tests/data/dirty.docx',
|
||||
compress_type = zipfile.ZIP_DEFLATED)
|
||||
zout.write('./tests/data/dirty.jpg',
|
||||
compress_type = zipfile.ZIP_BZIP2)
|
||||
zout.write('./tests/data/dirty.txt',
|
||||
compress_type = zipfile.ZIP_LZMA)
|
||||
p = archive.ZipParser('./tests/data/dirty.zip')
|
||||
meta = p.get_meta()
|
||||
self.assertEqual(meta['tests/data/dirty.docx']['word/media/image1.png']['Comment'], 'This is a comment, be careful!')
|
||||
|
@ -609,6 +630,16 @@ class TestCleaningArchives(unittest.TestCase):
|
|||
self.assertEqual(p.get_meta(), {})
|
||||
self.assertTrue(p.remove_all())
|
||||
|
||||
with zipfile.ZipFile('./tests/data/dirty.zip') as zipin:
|
||||
members = {
|
||||
'tests/data/dirty.flac' : zipfile.ZIP_STORED,
|
||||
'tests/data/dirty.docx': zipfile.ZIP_DEFLATED,
|
||||
'tests/data/dirty.jpg' : zipfile.ZIP_BZIP2,
|
||||
'tests/data/dirty.txt' : zipfile.ZIP_LZMA,
|
||||
}
|
||||
for k, v in members.items():
|
||||
self.assertEqual(zipin.getinfo(k).compress_type, v)
|
||||
|
||||
os.remove('./tests/data/dirty.zip')
|
||||
os.remove('./tests/data/dirty.cleaned.zip')
|
||||
os.remove('./tests/data/dirty.cleaned.cleaned.zip')
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue