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/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: