2014-12-01 10:31:29 +03:00
|
|
|
from helper import unittest, PillowTestCase
|
2014-12-30 04:10:27 +03:00
|
|
|
from PIL import Image, PngImagePlugin
|
2014-12-01 10:31:29 +03:00
|
|
|
from io import BytesIO
|
2014-12-30 04:10:27 +03:00
|
|
|
import zlib
|
2014-12-01 10:31:29 +03:00
|
|
|
|
2014-12-31 03:57:24 +03:00
|
|
|
TEST_FILE = "Tests/images/png_decompression_dos.png"
|
2014-12-01 10:31:29 +03:00
|
|
|
|
|
|
|
class TestPngDos(PillowTestCase):
|
|
|
|
def test_dos_text(self):
|
|
|
|
|
|
|
|
try:
|
2014-12-31 03:57:24 +03:00
|
|
|
im = Image.open(TEST_FILE)
|
2014-12-01 10:31:29 +03:00
|
|
|
im.load()
|
|
|
|
except ValueError as msg:
|
2014-12-31 03:57:24 +03:00
|
|
|
self.assertTrue(msg, "Decompressed Data Too Large")
|
2014-12-01 10:31:29 +03:00
|
|
|
return
|
|
|
|
|
|
|
|
for s in im.text.values():
|
2014-12-31 03:57:24 +03:00
|
|
|
self.assertLess(len(s), 1024*1024, "Text chunk larger than 1M")
|
2014-12-01 10:31:29 +03:00
|
|
|
|
2014-12-30 04:10:27 +03:00
|
|
|
def test_dos_total_memory(self):
|
|
|
|
im = Image.new('L',(1,1))
|
|
|
|
compressed_data = zlib.compress('a'*1024*1023)
|
|
|
|
|
|
|
|
info = PngImagePlugin.PngInfo()
|
|
|
|
|
|
|
|
for x in range(64):
|
|
|
|
info.add_text('t%s'%x, compressed_data, 1)
|
|
|
|
info.add_itxt('i%s'%x, compressed_data, zip=True)
|
|
|
|
|
|
|
|
b = BytesIO()
|
|
|
|
im.save(b, 'PNG', pnginfo=info)
|
|
|
|
b.seek(0)
|
|
|
|
|
|
|
|
try:
|
|
|
|
im2 = Image.open(b)
|
|
|
|
except ValueError as msg:
|
2014-12-31 03:57:24 +03:00
|
|
|
self.assertIn("Too much memory", msg)
|
2014-12-30 04:10:27 +03:00
|
|
|
return
|
|
|
|
|
|
|
|
total_len = 0
|
|
|
|
for txt in im2.text.values():
|
|
|
|
total_len += len(txt)
|
2014-12-31 03:57:24 +03:00
|
|
|
self.assertLess(total_len, 64*1024*1024, "Total text chunks greater than 64M")
|
2014-12-30 04:10:27 +03:00
|
|
|
|
2014-12-01 10:31:29 +03:00
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|