Updated checks that no warnings were raised

This commit is contained in:
Andrew Murray 2022-02-21 13:49:01 +11:00
parent 54be93c8b0
commit dae1f691c2
17 changed files with 50 additions and 75 deletions

View File

@ -1,6 +1,5 @@
import os import os
import warnings
import pytest
from PIL import Image from PIL import Image
@ -20,16 +19,14 @@ def test_bad():
either""" either"""
for f in get_files("b"): for f in get_files("b"):
with pytest.warns(None) as record: # Assert that there is no unclosed file warning
with warnings.catch_warnings():
try: try:
with Image.open(f) as im: with Image.open(f) as im:
im.load() im.load()
except Exception: # as msg: except Exception: # as msg:
pass pass
# Assert that there is no unclosed file warning
assert not record
def test_questionable(): def test_questionable():
"""These shouldn't crash/dos, but it's not well defined that these """These shouldn't crash/dos, but it's not well defined that these

View File

@ -1,3 +1,5 @@
import warnings
import pytest import pytest
from PIL import DcxImagePlugin, Image from PIL import DcxImagePlugin, Image
@ -31,21 +33,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(TEST_FILE) im = Image.open(TEST_FILE)
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(TEST_FILE) as im: with Image.open(TEST_FILE) as im:
im.load() im.load()
assert not record
def test_invalid_file(): def test_invalid_file():
with open("Tests/images/flower.jpg", "rb") as fp: with open("Tests/images/flower.jpg", "rb") as fp:

View File

@ -1,3 +1,5 @@
import warnings
import pytest import pytest
from PIL import FliImagePlugin, Image from PIL import FliImagePlugin, Image
@ -38,21 +40,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(static_test_file) im = Image.open(static_test_file)
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(static_test_file) as im: with Image.open(static_test_file) as im:
im.load() im.load()
assert not record
def test_tell(): def test_tell():
# Arrange # Arrange

View File

@ -1,3 +1,4 @@
import warnings
from io import BytesIO from io import BytesIO
import pytest import pytest
@ -39,21 +40,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(TEST_GIF) im = Image.open(TEST_GIF)
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(TEST_GIF) as im: with Image.open(TEST_GIF) as im:
im.load() im.load()
assert not record
def test_invalid_file(): def test_invalid_file():
invalid_file = "Tests/images/flower.jpg" invalid_file = "Tests/images/flower.jpg"

View File

@ -1,5 +1,6 @@
import io import io
import os import os
import warnings
import pytest import pytest
@ -19,9 +20,8 @@ def test_sanity():
with Image.open(TEST_FILE) as im: with Image.open(TEST_FILE) as im:
# Assert that there is no unclosed file warning # Assert that there is no unclosed file warning
with pytest.warns(None) as record: with warnings.catch_warnings():
im.load() im.load()
assert not record
assert im.mode == "RGBA" assert im.mode == "RGBA"
assert im.size == (1024, 1024) assert im.size == (1024, 1024)

View File

@ -1,4 +1,5 @@
import filecmp import filecmp
import warnings
import pytest import pytest
@ -35,21 +36,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(TEST_IM) im = Image.open(TEST_IM)
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(TEST_IM) as im: with Image.open(TEST_IM) as im:
im.load() im.load()
assert not record
def test_tell(): def test_tell():
# Arrange # Arrange

View File

@ -1,5 +1,6 @@
import os import os
import re import re
import warnings
from io import BytesIO from io import BytesIO
import pytest import pytest
@ -756,9 +757,8 @@ class TestFileJpeg:
assert exif[282] == 180 assert exif[282] == 180
out = str(tmp_path / "out.jpg") out = str(tmp_path / "out.jpg")
with pytest.warns(None) as record: with warnings.catch_warnings():
im.save(out, exif=exif) im.save(out, exif=exif)
assert not record
with Image.open(out) as reloaded: with Image.open(out) as reloaded:
assert reloaded.getexif()[282] == 180 assert reloaded.getexif()[282] == 180

View File

@ -1,3 +1,4 @@
import warnings
from io import BytesIO from io import BytesIO
import pytest import pytest
@ -41,21 +42,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(test_files[0]) im = Image.open(test_files[0])
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(test_files[0]) as im: with Image.open(test_files[0]) as im:
im.load() im.load()
assert not record
def test_app(): def test_app():
for test_file in test_files: for test_file in test_files:

View File

@ -1,5 +1,6 @@
import re import re
import sys import sys
import warnings
import zlib import zlib
from io import BytesIO from io import BytesIO
@ -331,9 +332,8 @@ class TestFilePng:
with Image.open(TEST_PNG_FILE) as im: with Image.open(TEST_PNG_FILE) as im:
# Assert that there is no unclosed file warning # Assert that there is no unclosed file warning
with pytest.warns(None) as record: with warnings.catch_warnings():
im.verify() im.verify()
assert not record
with Image.open(TEST_PNG_FILE) as im: with Image.open(TEST_PNG_FILE) as im:
im.load() im.load()

View File

@ -1,3 +1,5 @@
import warnings
import pytest import pytest
from PIL import Image, PsdImagePlugin from PIL import Image, PsdImagePlugin
@ -29,21 +31,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(test_file) im = Image.open(test_file)
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(test_file) as im: with Image.open(test_file) as im:
im.load() im.load()
assert not record
def test_invalid_file(): def test_invalid_file():
invalid_file = "Tests/images/flower.jpg" invalid_file = "Tests/images/flower.jpg"

View File

@ -1,4 +1,5 @@
import tempfile import tempfile
import warnings
from io import BytesIO from io import BytesIO
import pytest import pytest
@ -28,21 +29,17 @@ def test_unclosed_file():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open(TEST_FILE) im = Image.open(TEST_FILE)
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(): def test_context_manager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open(TEST_FILE) as im: with Image.open(TEST_FILE) as im:
im.load() im.load()
assert not record
def test_save(tmp_path): def test_save(tmp_path):
# Arrange # Arrange

View File

@ -1,3 +1,5 @@
import warnings
import pytest import pytest
from PIL import Image, TarIO, features from PIL import Image, TarIO, features
@ -31,16 +33,12 @@ def test_unclosed_file():
def test_close(): def test_close():
with pytest.warns(None) as record: with warnings.catch_warnings():
tar = TarIO.TarIO(TEST_TAR_FILE, "hopper.jpg") tar = TarIO.TarIO(TEST_TAR_FILE, "hopper.jpg")
tar.close() tar.close()
assert not record
def test_contextmanager(): def test_contextmanager():
with pytest.warns(None) as record: with warnings.catch_warnings():
with TarIO.TarIO(TEST_TAR_FILE, "hopper.jpg"): with TarIO.TarIO(TEST_TAR_FILE, "hopper.jpg"):
pass pass
assert not record

View File

@ -1,4 +1,5 @@
import os import os
import warnings
from io import BytesIO from io import BytesIO
import pytest import pytest
@ -64,20 +65,16 @@ class TestFileTiff:
pytest.warns(ResourceWarning, open) pytest.warns(ResourceWarning, open)
def test_closed_file(self): def test_closed_file(self):
with pytest.warns(None) as record: with warnings.catch_warnings():
im = Image.open("Tests/images/multipage.tiff") im = Image.open("Tests/images/multipage.tiff")
im.load() im.load()
im.close() im.close()
assert not record
def test_context_manager(self): def test_context_manager(self):
with pytest.warns(None) as record: with warnings.catch_warnings():
with Image.open("Tests/images/multipage.tiff") as im: with Image.open("Tests/images/multipage.tiff") as im:
im.load() im.load()
assert not record
def test_mac_tiff(self): def test_mac_tiff(self):
# Read RGBa images from macOS [@PIL136] # Read RGBa images from macOS [@PIL136]

View File

@ -1,6 +1,7 @@
import io import io
import re import re
import sys import sys
import warnings
import pytest import pytest
@ -161,9 +162,8 @@ class TestFileWebp:
file_path = "Tests/images/hopper.webp" file_path = "Tests/images/hopper.webp"
with Image.open(file_path) as image: with Image.open(file_path) as image:
temp_file = str(tmp_path / "temp.webp") temp_file = str(tmp_path / "temp.webp")
with pytest.warns(None) as record: with warnings.catch_warnings():
image.save(temp_file) image.save(temp_file)
assert not record
def test_file_pointer_could_be_reused(self): def test_file_pointer_could_be_reused(self):
file_path = "Tests/images/hopper.webp" file_path = "Tests/images/hopper.webp"

View File

@ -3,6 +3,7 @@ import os
import shutil import shutil
import sys import sys
import tempfile import tempfile
import warnings
import pytest import pytest
@ -648,9 +649,8 @@ class TestImage:
# Act/Assert # Act/Assert
with Image.open(test_file) as im: with Image.open(test_file) as im:
with pytest.warns(None) as record: with warnings.catch_warnings():
im.save(temp_file) im.save(temp_file)
assert not record
def test_load_on_nonexclusive_multiframe(self): def test_load_on_nonexclusive_multiframe(self):
with open("Tests/images/frozenpond.mpo", "rb") as fp: with open("Tests/images/frozenpond.mpo", "rb") as fp:

View File

@ -1,3 +1,5 @@
import warnings
import pytest import pytest
from PIL import ImageQt from PIL import ImageQt
@ -56,7 +58,5 @@ def test_image():
def test_closed_file(): def test_closed_file():
with pytest.warns(None) as record: with warnings.catch_warnings():
ImageQt.ImageQt("Tests/images/hopper.gif") ImageQt.ImageQt("Tests/images/hopper.gif")
assert not record

View File

@ -1,3 +1,5 @@
import warnings
import pytest import pytest
from PIL import Image from PIL import Image
@ -237,6 +239,5 @@ def test_no_resource_warning_for_numpy_array():
with Image.open(test_file) as im: with Image.open(test_file) as im:
# Act/Assert # Act/Assert
with pytest.warns(None) as record: with warnings.catch_warnings():
array(im) array(im)
assert not record