From 8b71f3d3c19729251d59f02ed6026fdfaf620627 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Thu, 19 Oct 2023 18:42:41 +1100 Subject: [PATCH 1/2] Added messages to errors --- Tests/test_file_palm.py | 2 +- src/PIL/FliImagePlugin.py | 3 ++- src/PIL/GifImagePlugin.py | 6 ++++-- src/PIL/Image.py | 6 ++++-- src/PIL/ImageFile.py | 10 ++++++---- src/PIL/ImagePalette.py | 3 ++- src/PIL/ImageSequence.py | 6 ++++-- src/PIL/ImageShow.py | 3 ++- src/PIL/JpegImagePlugin.py | 6 ++++-- src/PIL/PngImagePlugin.py | 10 ++++++---- 10 files changed, 35 insertions(+), 20 deletions(-) diff --git a/Tests/test_file_palm.py b/Tests/test_file_palm.py index be7c8d0c86a..ecf512041f2 100644 --- a/Tests/test_file_palm.py +++ b/Tests/test_file_palm.py @@ -27,7 +27,7 @@ def open_with_magick(magick, tmp_path, f): magick + [f, outfile], stdout=subprocess.DEVNULL, stderr=subprocess.STDOUT ) if rc: - raise OSError + assert False return Image.open(outfile) diff --git a/src/PIL/FliImagePlugin.py b/src/PIL/FliImagePlugin.py index 8f641ece998..b05a16259e6 100644 --- a/src/PIL/FliImagePlugin.py +++ b/src/PIL/FliImagePlugin.py @@ -150,7 +150,8 @@ def _seek(self, frame): s = self.fp.read(4) if not s: - raise EOFError + msg = "missing frame size" + raise EOFError(msg) framesize = i32(s) diff --git a/src/PIL/GifImagePlugin.py b/src/PIL/GifImagePlugin.py index 92074b0d49e..4ce295f7f21 100644 --- a/src/PIL/GifImagePlugin.py +++ b/src/PIL/GifImagePlugin.py @@ -183,7 +183,8 @@ def _seek(self, frame, update_image=True): s = self.fp.read(1) if not s or s == b";": - raise EOFError + msg = "no more images in GIF file" + raise EOFError(msg) palette = None @@ -288,7 +289,8 @@ def _seek(self, frame, update_image=True): if interlace is None: # self._fp = None - raise EOFError + msg = "image not found in GIF frame" + raise EOFError(msg) self.__frame = frame if not update_image: diff --git a/src/PIL/Image.py b/src/PIL/Image.py index 1adca9ad5b1..b493c65b6cb 100644 --- a/src/PIL/Image.py +++ b/src/PIL/Image.py @@ -1862,7 +1862,8 @@ def putalpha(self, alpha): # do things the hard way im = self.im.convert(mode) if im.mode not in ("LA", "PA", "RGBA"): - raise ValueError from e # sanity check + msg = "alpha channel could not be added" + raise ValueError(msg) from e # sanity check self.im = im self.pyaccess = None self._mode = self.im.mode @@ -2467,7 +2468,8 @@ def seek(self, frame): # overridden by file handlers if frame != 0: - raise EOFError + msg = "no more images in file" + raise EOFError(msg) def show(self, title=None): """ diff --git a/src/PIL/ImageFile.py b/src/PIL/ImageFile.py index 8e4f7dfb2c8..8432a187f85 100644 --- a/src/PIL/ImageFile.py +++ b/src/PIL/ImageFile.py @@ -200,8 +200,8 @@ def load(self): with open(self.filename) as fp: self.map = mmap.mmap(fp.fileno(), 0, access=mmap.ACCESS_READ) if offset + self.size[1] * args[1] > self.map.size(): - # buffer is not large enough - raise OSError + msg = "buffer is not large enough" + raise OSError(msg) self.im = Image.core.map_buffer( self.map, self.size, decoder_name, offset, args ) @@ -690,7 +690,8 @@ def decode(self, buffer): If finished with decoding return -1 for the bytes consumed. Err codes are from :data:`.ImageFile.ERRORS`. """ - raise NotImplementedError() + msg = "unavailable in base decoder" + raise NotImplementedError(msg) def set_as_raw(self, data, rawmode=None): """ @@ -739,7 +740,8 @@ def encode(self, bufsize): If finished with encoding return 1 for the error code. Err codes are from :data:`.ImageFile.ERRORS`. """ - raise NotImplementedError() + msg = "unavailable in base encoder" + raise NotImplementedError(msg) def encode_to_pyfd(self): """ diff --git a/src/PIL/ImagePalette.py b/src/PIL/ImagePalette.py index f0c09470863..1ba50b5ec6b 100644 --- a/src/PIL/ImagePalette.py +++ b/src/PIL/ImagePalette.py @@ -205,7 +205,8 @@ def make_linear_lut(black, white): for i in range(256): lut.append(white * i // 255) else: - raise NotImplementedError # FIXME + msg = "unavailable when black is non-zero" + raise NotImplementedError(msg) # FIXME return lut diff --git a/src/PIL/ImageSequence.py b/src/PIL/ImageSequence.py index c4bb6334acf..2d96b8b1365 100644 --- a/src/PIL/ImageSequence.py +++ b/src/PIL/ImageSequence.py @@ -40,7 +40,8 @@ def __getitem__(self, ix): self.im.seek(ix) return self.im except EOFError as e: - raise IndexError from e # end of sequence + msg = "end of sequence" + raise IndexError(msg) from e def __iter__(self): return self @@ -51,7 +52,8 @@ def __next__(self): self.position += 1 return self.im except EOFError as e: - raise StopIteration from e + msg = "end of sequence" + raise StopIteration(msg) from e def all_frames(im, func=None): diff --git a/src/PIL/ImageShow.py b/src/PIL/ImageShow.py index 8b1c3f8bb63..3d8fa2e402f 100644 --- a/src/PIL/ImageShow.py +++ b/src/PIL/ImageShow.py @@ -99,7 +99,8 @@ def get_command(self, file, **options): Returns the command used to display the file. Not implemented in the base class. """ - raise NotImplementedError + msg = "unavailable in base viewer" + raise NotImplementedError(msg) def save_image(self, image): """Save to temporary file and return filename.""" diff --git a/src/PIL/JpegImagePlugin.py b/src/PIL/JpegImagePlugin.py index 917bbf39fbb..c091697f52d 100644 --- a/src/PIL/JpegImagePlugin.py +++ b/src/PIL/JpegImagePlugin.py @@ -165,7 +165,8 @@ def APP(self, marker): except TypeError: dpi = x_resolution if math.isnan(dpi): - raise ValueError + msg = "DPI is not a number" + raise ValueError(msg) if resolution_unit == 3: # cm # 1 dpcm = 2.54 dpi dpi *= 2.54 @@ -719,7 +720,8 @@ def validate_qtables(qtables): for idx, table in enumerate(qtables): try: if len(table) != 64: - raise TypeError + msg = "Invalid quantization table" + raise TypeError(msg) table = array.array("H", table) except TypeError as e: msg = "Invalid quantization table" diff --git a/src/PIL/PngImagePlugin.py b/src/PIL/PngImagePlugin.py index 5e5a8cf6a2d..55ca87b0bb9 100644 --- a/src/PIL/PngImagePlugin.py +++ b/src/PIL/PngImagePlugin.py @@ -438,11 +438,12 @@ def chunk_IDAT(self, pos, length): tile = [("zip", (0, 0) + self.im_size, pos, self.im_rawmode)] self.im_tile = tile self.im_idat = length - raise EOFError + msg = "image data found" + raise EOFError(msg) def chunk_IEND(self, pos, length): - # end of PNG image - raise EOFError + msg = "end of PNG image" + raise EOFError(msg) def chunk_PLTE(self, pos, length): # palette @@ -891,7 +892,8 @@ def _seek(self, frame, rewind=False): self.dispose_extent = self.info.get("bbox") if not self.tile: - raise EOFError + msg = "image not found in APNG frame" + raise EOFError(msg) # setup frame disposal (actual disposal done when needed in the next _seek()) if self._prev_im is None and self.dispose_op == Disposal.OP_PREVIOUS: From e760b02bfa37584400eb936277ea97a1146f214b Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Thu, 19 Oct 2023 20:34:28 +1100 Subject: [PATCH 2/2] Combine if and assert statement --- Tests/test_file_palm.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/Tests/test_file_palm.py b/Tests/test_file_palm.py index ecf512041f2..926fdb26f6b 100644 --- a/Tests/test_file_palm.py +++ b/Tests/test_file_palm.py @@ -26,8 +26,7 @@ def open_with_magick(magick, tmp_path, f): rc = subprocess.call( magick + [f, outfile], stdout=subprocess.DEVNULL, stderr=subprocess.STDOUT ) - if rc: - assert False + assert not rc return Image.open(outfile)