mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-07-10 16:22:22 +03:00
test for truncated png memory leak #2541
This commit is contained in:
parent
e6da335206
commit
8eb1dcb7c5
|
@ -1,14 +1,16 @@
|
||||||
from helper import unittest, PillowTestCase, hopper
|
from helper import unittest, PillowTestCase, hopper
|
||||||
|
from PIL import Image, ImageFile, PngImagePlugin
|
||||||
|
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
|
|
||||||
from PIL import Image
|
|
||||||
from PIL import ImageFile
|
|
||||||
from PIL import PngImagePlugin
|
|
||||||
import zlib
|
import zlib
|
||||||
|
import sys
|
||||||
|
|
||||||
codecs = dir(Image.core)
|
codecs = dir(Image.core)
|
||||||
|
|
||||||
|
# For Truncated phng memory leak
|
||||||
|
MEM_LIMIT = 1 # max increase in MB
|
||||||
|
ITERATIONS = 100
|
||||||
|
|
||||||
# sample png stream
|
# sample png stream
|
||||||
|
|
||||||
TEST_PNG_FILE = "Tests/images/hopper.png"
|
TEST_PNG_FILE = "Tests/images/hopper.png"
|
||||||
|
@ -530,5 +532,33 @@ class TestFilePng(PillowTestCase):
|
||||||
self.assertLess(chunks.index(b"pHYs"), chunks.index(b"IDAT"))
|
self.assertLess(chunks.index(b"pHYs"), chunks.index(b"IDAT"))
|
||||||
|
|
||||||
|
|
||||||
|
@unittest.skipIf(sys.platform.startswith('win32'), "requires Unix or MacOS")
|
||||||
|
class TestTruncatedPngPLeaks(PillowTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
if "zip_encoder" not in codecs or "zip_decoder" not in codecs:
|
||||||
|
self.skipTest("zip/deflate support not available")
|
||||||
|
|
||||||
|
def _get_mem_usage(self):
|
||||||
|
from resource import getpagesize, getrusage, RUSAGE_SELF
|
||||||
|
mem = getrusage(RUSAGE_SELF).ru_maxrss
|
||||||
|
return mem * getpagesize() / 1024 / 1024
|
||||||
|
|
||||||
|
def test_leak_load(self):
|
||||||
|
with open('Tests/images/hopper.png', 'rb') as f:
|
||||||
|
DATA = BytesIO(f.read(16 * 1024))
|
||||||
|
|
||||||
|
ImageFile.LOAD_TRUNCATED_IMAGES = True
|
||||||
|
start_mem = self._get_mem_usage()
|
||||||
|
try:
|
||||||
|
for _ in range(ITERATIONS):
|
||||||
|
with Image.open(DATA) as im:
|
||||||
|
im.load()
|
||||||
|
mem = (self._get_mem_usage() - start_mem)
|
||||||
|
self.assertLess(mem, MEM_LIMIT, msg='memory usage limit exceeded')
|
||||||
|
finally:
|
||||||
|
ImageFile.LOAD_TRUNCATED_IMAGES = False
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user