2018-06-22 21:16:55 +02:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
import shutil
|
|
|
|
import os
|
|
|
|
|
2018-07-06 00:49:17 +02:00
|
|
|
from libmat2 import pdf, images, audio, office, parser_factory, torrent, harmless
|
2018-06-22 21:16:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
class TestUnsupportedFiles(unittest.TestCase):
|
|
|
|
def test_pdf(self):
|
|
|
|
shutil.copy('./tests/test_libmat2.py', './tests/clean.py')
|
|
|
|
parser, mimetype = parser_factory.get_parser('./tests/data/clean.py')
|
|
|
|
self.assertEqual(mimetype, 'text/x-python')
|
|
|
|
self.assertEqual(parser, None)
|
|
|
|
os.remove('./tests/clean.py')
|
|
|
|
|
2018-07-08 21:35:45 +02:00
|
|
|
class TestCorruptedEmbedded(unittest.TestCase):
|
|
|
|
def test_docx(self):
|
|
|
|
shutil.copy('./tests/data/embedded_corrupted.docx', './tests/data/clean.docx')
|
|
|
|
parser, mimetype = parser_factory.get_parser('./tests/data/clean.docx')
|
|
|
|
self.assertFalse(parser.remove_all())
|
|
|
|
self.assertIsNotNone(parser.get_meta())
|
|
|
|
os.remove('./tests/data/clean.docx')
|
|
|
|
|
|
|
|
def test_odt(self):
|
|
|
|
shutil.copy('./tests/data/embedded_corrupted.odt', './tests/data/clean.odt')
|
|
|
|
parser, mimetype = parser_factory.get_parser('./tests/data/clean.odt')
|
|
|
|
self.assertFalse(parser.remove_all())
|
|
|
|
self.assertEqual(parser.get_meta(), {'create_system': 'Weird', 'date_time': '2018-06-10 17:18:18', 'meta.xml': 'harmful content'})
|
|
|
|
os.remove('./tests/data/clean.odt')
|
|
|
|
|
2018-06-22 21:16:55 +02:00
|
|
|
|
|
|
|
class TestExplicitelyUnsupportedFiles(unittest.TestCase):
|
|
|
|
def test_pdf(self):
|
2018-07-06 00:42:09 +02:00
|
|
|
shutil.copy('./tests/test_libmat2.py', './tests/data/clean.py')
|
|
|
|
parser, mimetype = parser_factory.get_parser('./tests/data/clean.py')
|
|
|
|
self.assertEqual(mimetype, 'text/x-python')
|
2018-06-22 21:16:55 +02:00
|
|
|
self.assertEqual(parser, None)
|
2018-07-06 00:42:09 +02:00
|
|
|
os.remove('./tests/data/clean.py')
|
2018-06-22 21:16:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
class TestCorruptedFiles(unittest.TestCase):
|
|
|
|
def test_pdf(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.png')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
pdf.PDFParser('./tests/data/clean.png')
|
|
|
|
os.remove('./tests/data/clean.png')
|
|
|
|
|
|
|
|
def test_png(self):
|
|
|
|
shutil.copy('./tests/data/dirty.pdf', './tests/data/clean.pdf')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
images.PNGParser('./tests/data/clean.pdf')
|
|
|
|
os.remove('./tests/data/clean.pdf')
|
|
|
|
|
|
|
|
def test_png2(self):
|
|
|
|
shutil.copy('./tests/test_libmat2.py', './tests/clean.png')
|
|
|
|
parser, mimetype = parser_factory.get_parser('./tests/clean.png')
|
|
|
|
self.assertIsNone(parser)
|
|
|
|
os.remove('./tests/clean.png')
|
|
|
|
|
|
|
|
def test_torrent(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.torrent')
|
2018-07-08 13:47:00 +02:00
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
torrent.TorrentParser('./tests/data/clean.torrent')
|
2018-06-22 21:16:55 +02:00
|
|
|
|
|
|
|
with open("./tests/data/clean.torrent", "a") as f:
|
|
|
|
f.write("trailing garbage")
|
2018-07-08 13:47:00 +02:00
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
torrent.TorrentParser('./tests/data/clean.torrent')
|
|
|
|
|
2018-07-08 15:13:03 +02:00
|
|
|
with open("./tests/data/clean.torrent", "w") as f:
|
|
|
|
f.write("i-0e")
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
torrent.TorrentParser('./tests/data/clean.torrent')
|
|
|
|
|
|
|
|
with open("./tests/data/clean.torrent", "w") as f:
|
|
|
|
f.write("i00e")
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
torrent.TorrentParser('./tests/data/clean.torrent')
|
|
|
|
|
|
|
|
with open("./tests/data/clean.torrent", "w") as f:
|
2018-07-08 22:27:37 +02:00
|
|
|
f.write("01:AAAAAAAAA")
|
2018-07-08 15:13:03 +02:00
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
torrent.TorrentParser('./tests/data/clean.torrent')
|
|
|
|
|
|
|
|
with open("./tests/data/clean.torrent", "w") as f:
|
|
|
|
f.write("1:aaa")
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
torrent.TorrentParser('./tests/data/clean.torrent')
|
|
|
|
|
2018-06-22 21:16:55 +02:00
|
|
|
os.remove('./tests/data/clean.torrent')
|
|
|
|
|
|
|
|
def test_odg(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.odg')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
office.LibreOfficeParser('./tests/data/clean.odg')
|
|
|
|
os.remove('./tests/data/clean.odg')
|
|
|
|
|
|
|
|
def test_bmp(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.bmp')
|
2018-07-06 00:49:17 +02:00
|
|
|
harmless.HarmlessParser('./tests/data/clean.bmp')
|
2018-06-22 21:16:55 +02:00
|
|
|
os.remove('./tests/data/clean.bmp')
|
|
|
|
|
|
|
|
def test_docx(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.docx')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
office.MSOfficeParser('./tests/data/clean.docx')
|
|
|
|
os.remove('./tests/data/clean.docx')
|
|
|
|
|
|
|
|
def test_flac(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.flac')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
audio.FLACParser('./tests/data/clean.flac')
|
|
|
|
os.remove('./tests/data/clean.flac')
|
|
|
|
|
|
|
|
def test_mp3(self):
|
|
|
|
shutil.copy('./tests/data/dirty.png', './tests/data/clean.mp3')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
audio.MP3Parser('./tests/data/clean.mp3')
|
|
|
|
os.remove('./tests/data/clean.mp3')
|
2018-07-07 18:02:53 +02:00
|
|
|
|
|
|
|
def test_jpg(self):
|
|
|
|
shutil.copy('./tests/data/dirty.mp3', './tests/data/clean.jpg')
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
images.JPGParser('./tests/data/clean.jpg')
|
|
|
|
os.remove('./tests/data/clean.jpg')
|