mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-10-24 04:31:06 +03:00
Merge pull request #6134 from radarhere/created_cleanup
If an error occurs after creating a file, remove the file
This commit is contained in:
commit
9134f07615
|
@ -652,6 +652,15 @@ class TestImage:
|
||||||
with warnings.catch_warnings():
|
with warnings.catch_warnings():
|
||||||
im.save(temp_file)
|
im.save(temp_file)
|
||||||
|
|
||||||
|
def test_no_new_file_on_error(self, tmp_path):
|
||||||
|
temp_file = str(tmp_path / "temp.jpg")
|
||||||
|
|
||||||
|
im = Image.new("RGB", (0, 0))
|
||||||
|
with pytest.raises(SystemError):
|
||||||
|
im.save(temp_file)
|
||||||
|
|
||||||
|
assert not os.path.exists(temp_file)
|
||||||
|
|
||||||
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:
|
||||||
|
|
||||||
|
|
|
@ -2286,7 +2286,9 @@ class Image:
|
||||||
else:
|
else:
|
||||||
save_handler = SAVE[format.upper()]
|
save_handler = SAVE[format.upper()]
|
||||||
|
|
||||||
|
created = False
|
||||||
if open_fp:
|
if open_fp:
|
||||||
|
created = not os.path.exists(filename)
|
||||||
if params.get("append", False):
|
if params.get("append", False):
|
||||||
# Open also for reading ("+"), because TIFF save_all
|
# Open also for reading ("+"), because TIFF save_all
|
||||||
# writer needs to go back and edit the written data.
|
# writer needs to go back and edit the written data.
|
||||||
|
@ -2296,10 +2298,17 @@ class Image:
|
||||||
|
|
||||||
try:
|
try:
|
||||||
save_handler(self, fp, filename)
|
save_handler(self, fp, filename)
|
||||||
finally:
|
except Exception:
|
||||||
# do what we can to clean up
|
|
||||||
if open_fp:
|
if open_fp:
|
||||||
fp.close()
|
fp.close()
|
||||||
|
if created:
|
||||||
|
try:
|
||||||
|
os.remove(filename)
|
||||||
|
except PermissionError:
|
||||||
|
pass
|
||||||
|
raise
|
||||||
|
if open_fp:
|
||||||
|
fp.close()
|
||||||
|
|
||||||
def seek(self, frame):
|
def seek(self, frame):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in New Issue
Block a user