mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-30 23:47:27 +03:00 
			
		
		
		
	Replace unittest with pytest
This commit is contained in:
		
							parent
							
								
									85e06057e2
								
							
						
					
					
						commit
						946a038b13
					
				|  | @ -1,128 +1,139 @@ | ||||||
| import io | import io | ||||||
| 
 | 
 | ||||||
|  | import pytest | ||||||
| from PIL import BmpImagePlugin, Image | from PIL import BmpImagePlugin, Image | ||||||
| 
 | 
 | ||||||
| from .helper import PillowTestCase, assert_image_equal, hopper | from .helper import assert_image_equal, hopper | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class TestFileBmp(PillowTestCase): | def test_sanity(tmp_path): | ||||||
|     def roundtrip(self, im): |     def roundtrip(im): | ||||||
|         outfile = self.tempfile("temp.bmp") |         outfile = str(tmp_path / "temp.bmp") | ||||||
| 
 | 
 | ||||||
|         im.save(outfile, "BMP") |         im.save(outfile, "BMP") | ||||||
| 
 | 
 | ||||||
|         with Image.open(outfile) as reloaded: |         with Image.open(outfile) as reloaded: | ||||||
|             reloaded.load() |             reloaded.load() | ||||||
|             self.assertEqual(im.mode, reloaded.mode) |             assert im.mode == reloaded.mode | ||||||
|             self.assertEqual(im.size, reloaded.size) |             assert im.size == reloaded.size | ||||||
|             self.assertEqual(reloaded.format, "BMP") |             assert reloaded.format == "BMP" | ||||||
|             self.assertEqual(reloaded.get_format_mimetype(), "image/bmp") |             assert reloaded.get_format_mimetype() == "image/bmp" | ||||||
| 
 | 
 | ||||||
|     def test_sanity(self): |     roundtrip(hopper()) | ||||||
|         self.roundtrip(hopper()) |  | ||||||
| 
 | 
 | ||||||
|         self.roundtrip(hopper("1")) |     roundtrip(hopper("1")) | ||||||
|         self.roundtrip(hopper("L")) |     roundtrip(hopper("L")) | ||||||
|         self.roundtrip(hopper("P")) |     roundtrip(hopper("P")) | ||||||
|         self.roundtrip(hopper("RGB")) |     roundtrip(hopper("RGB")) | ||||||
| 
 | 
 | ||||||
|     def test_invalid_file(self): |  | ||||||
|         with open("Tests/images/flower.jpg", "rb") as fp: |  | ||||||
|             self.assertRaises(SyntaxError, BmpImagePlugin.BmpImageFile, fp) |  | ||||||
| 
 | 
 | ||||||
|     def test_save_to_bytes(self): | def test_invalid_file(): | ||||||
|         output = io.BytesIO() |     with open("Tests/images/flower.jpg", "rb") as fp: | ||||||
|         im = hopper() |         with pytest.raises(SyntaxError): | ||||||
|         im.save(output, "BMP") |             BmpImagePlugin.BmpImageFile(fp) | ||||||
| 
 | 
 | ||||||
|         output.seek(0) |  | ||||||
|         with Image.open(output) as reloaded: |  | ||||||
|             self.assertEqual(im.mode, reloaded.mode) |  | ||||||
|             self.assertEqual(im.size, reloaded.size) |  | ||||||
|             self.assertEqual(reloaded.format, "BMP") |  | ||||||
| 
 | 
 | ||||||
|     def test_save_too_large(self): | def test_save_to_bytes(): | ||||||
|         outfile = self.tempfile("temp.bmp") |     output = io.BytesIO() | ||||||
|         with Image.new("RGB", (1, 1)) as im: |     im = hopper() | ||||||
|             im._size = (37838, 37838) |     im.save(output, "BMP") | ||||||
|             with self.assertRaises(ValueError): |  | ||||||
|                 im.save(outfile) |  | ||||||
| 
 | 
 | ||||||
|     def test_dpi(self): |     output.seek(0) | ||||||
|         dpi = (72, 72) |     with Image.open(output) as reloaded: | ||||||
|  |         assert im.mode == reloaded.mode | ||||||
|  |         assert im.size == reloaded.size | ||||||
|  |         assert reloaded.format == "BMP" | ||||||
| 
 | 
 | ||||||
|         output = io.BytesIO() |  | ||||||
|         with hopper() as im: |  | ||||||
|             im.save(output, "BMP", dpi=dpi) |  | ||||||
| 
 | 
 | ||||||
|         output.seek(0) | def test_save_too_large(tmp_path): | ||||||
|         with Image.open(output) as reloaded: |     outfile = str(tmp_path / "temp.bmp") | ||||||
|             self.assertEqual(reloaded.info["dpi"], dpi) |     with Image.new("RGB", (1, 1)) as im: | ||||||
| 
 |         im._size = (37838, 37838) | ||||||
|     def test_save_bmp_with_dpi(self): |         with pytest.raises(ValueError): | ||||||
|         # Test for #1301 |  | ||||||
|         # Arrange |  | ||||||
|         outfile = self.tempfile("temp.jpg") |  | ||||||
|         with Image.open("Tests/images/hopper.bmp") as im: |  | ||||||
| 
 |  | ||||||
|             # Act |  | ||||||
|             im.save(outfile, "JPEG", dpi=im.info["dpi"]) |  | ||||||
| 
 |  | ||||||
|             # Assert |  | ||||||
|             with Image.open(outfile) as reloaded: |  | ||||||
|                 reloaded.load() |  | ||||||
|                 self.assertEqual(im.info["dpi"], reloaded.info["dpi"]) |  | ||||||
|                 self.assertEqual(im.size, reloaded.size) |  | ||||||
|                 self.assertEqual(reloaded.format, "JPEG") |  | ||||||
| 
 |  | ||||||
|     def test_load_dpi_rounding(self): |  | ||||||
|         # Round up |  | ||||||
|         with Image.open("Tests/images/hopper.bmp") as im: |  | ||||||
|             self.assertEqual(im.info["dpi"], (96, 96)) |  | ||||||
| 
 |  | ||||||
|         # Round down |  | ||||||
|         with Image.open("Tests/images/hopper_roundDown.bmp") as im: |  | ||||||
|             self.assertEqual(im.info["dpi"], (72, 72)) |  | ||||||
| 
 |  | ||||||
|     def test_save_dpi_rounding(self): |  | ||||||
|         outfile = self.tempfile("temp.bmp") |  | ||||||
|         with Image.open("Tests/images/hopper.bmp") as im: |  | ||||||
|             im.save(outfile, dpi=(72.2, 72.2)) |  | ||||||
|             with Image.open(outfile) as reloaded: |  | ||||||
|                 self.assertEqual(reloaded.info["dpi"], (72, 72)) |  | ||||||
| 
 |  | ||||||
|             im.save(outfile, dpi=(72.8, 72.8)) |  | ||||||
|         with Image.open(outfile) as reloaded: |  | ||||||
|             self.assertEqual(reloaded.info["dpi"], (73, 73)) |  | ||||||
| 
 |  | ||||||
|     def test_load_dib(self): |  | ||||||
|         # test for #1293, Imagegrab returning Unsupported Bitfields Format |  | ||||||
|         with Image.open("Tests/images/clipboard.dib") as im: |  | ||||||
|             self.assertEqual(im.format, "DIB") |  | ||||||
|             self.assertEqual(im.get_format_mimetype(), "image/bmp") |  | ||||||
| 
 |  | ||||||
|             with Image.open("Tests/images/clipboard_target.png") as target: |  | ||||||
|                 assert_image_equal(im, target) |  | ||||||
| 
 |  | ||||||
|     def test_save_dib(self): |  | ||||||
|         outfile = self.tempfile("temp.dib") |  | ||||||
| 
 |  | ||||||
|         with Image.open("Tests/images/clipboard.dib") as im: |  | ||||||
|             im.save(outfile) |             im.save(outfile) | ||||||
| 
 | 
 | ||||||
|             with Image.open(outfile) as reloaded: |  | ||||||
|                 self.assertEqual(reloaded.format, "DIB") |  | ||||||
|                 self.assertEqual(reloaded.get_format_mimetype(), "image/bmp") |  | ||||||
|                 assert_image_equal(im, reloaded) |  | ||||||
| 
 | 
 | ||||||
|     def test_rgba_bitfields(self): | def test_dpi(): | ||||||
|         # This test image has been manually hexedited |     dpi = (72, 72) | ||||||
|         # to change the bitfield compression in the header from XBGR to RGBA |  | ||||||
|         with Image.open("Tests/images/rgb32bf-rgba.bmp") as im: |  | ||||||
| 
 | 
 | ||||||
|             # So before the comparing the image, swap the channels |     output = io.BytesIO() | ||||||
|             b, g, r = im.split()[1:] |     with hopper() as im: | ||||||
|             im = Image.merge("RGB", (r, g, b)) |         im.save(output, "BMP", dpi=dpi) | ||||||
| 
 | 
 | ||||||
|         with Image.open("Tests/images/bmp/q/rgb32bf-xbgr.bmp") as target: |     output.seek(0) | ||||||
|  |     with Image.open(output) as reloaded: | ||||||
|  |         assert reloaded.info["dpi"] == dpi | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test_save_bmp_with_dpi(tmp_path): | ||||||
|  |     # Test for #1301 | ||||||
|  |     # Arrange | ||||||
|  |     outfile = str(tmp_path / "temp.jpg") | ||||||
|  |     with Image.open("Tests/images/hopper.bmp") as im: | ||||||
|  | 
 | ||||||
|  |         # Act | ||||||
|  |         im.save(outfile, "JPEG", dpi=im.info["dpi"]) | ||||||
|  | 
 | ||||||
|  |         # Assert | ||||||
|  |         with Image.open(outfile) as reloaded: | ||||||
|  |             reloaded.load() | ||||||
|  |             assert im.info["dpi"] == reloaded.info["dpi"] | ||||||
|  |             assert im.size == reloaded.size | ||||||
|  |             assert reloaded.format == "JPEG" | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test_load_dpi_rounding(): | ||||||
|  |     # Round up | ||||||
|  |     with Image.open("Tests/images/hopper.bmp") as im: | ||||||
|  |         assert im.info["dpi"] == (96, 96) | ||||||
|  | 
 | ||||||
|  |     # Round down | ||||||
|  |     with Image.open("Tests/images/hopper_roundDown.bmp") as im: | ||||||
|  |         assert im.info["dpi"] == (72, 72) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test_save_dpi_rounding(tmp_path): | ||||||
|  |     outfile = str(tmp_path / "temp.bmp") | ||||||
|  |     with Image.open("Tests/images/hopper.bmp") as im: | ||||||
|  |         im.save(outfile, dpi=(72.2, 72.2)) | ||||||
|  |         with Image.open(outfile) as reloaded: | ||||||
|  |             assert reloaded.info["dpi"] == (72, 72) | ||||||
|  | 
 | ||||||
|  |         im.save(outfile, dpi=(72.8, 72.8)) | ||||||
|  |     with Image.open(outfile) as reloaded: | ||||||
|  |         assert reloaded.info["dpi"] == (73, 73) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test_load_dib(): | ||||||
|  |     # test for #1293, Imagegrab returning Unsupported Bitfields Format | ||||||
|  |     with Image.open("Tests/images/clipboard.dib") as im: | ||||||
|  |         assert im.format == "DIB" | ||||||
|  |         assert im.get_format_mimetype() == "image/bmp" | ||||||
|  | 
 | ||||||
|  |         with Image.open("Tests/images/clipboard_target.png") as target: | ||||||
|             assert_image_equal(im, target) |             assert_image_equal(im, target) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test_save_dib(tmp_path): | ||||||
|  |     outfile = str(tmp_path / "temp.dib") | ||||||
|  | 
 | ||||||
|  |     with Image.open("Tests/images/clipboard.dib") as im: | ||||||
|  |         im.save(outfile) | ||||||
|  | 
 | ||||||
|  |         with Image.open(outfile) as reloaded: | ||||||
|  |             assert reloaded.format == "DIB" | ||||||
|  |             assert reloaded.get_format_mimetype() == "image/bmp" | ||||||
|  |             assert_image_equal(im, reloaded) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test_rgba_bitfields(): | ||||||
|  |     # This test image has been manually hexedited | ||||||
|  |     # to change the bitfield compression in the header from XBGR to RGBA | ||||||
|  |     with Image.open("Tests/images/rgb32bf-rgba.bmp") as im: | ||||||
|  | 
 | ||||||
|  |         # So before the comparing the image, swap the channels | ||||||
|  |         b, g, r = im.split()[1:] | ||||||
|  |         im = Image.merge("RGB", (r, g, b)) | ||||||
|  | 
 | ||||||
|  |     with Image.open("Tests/images/bmp/q/rgb32bf-xbgr.bmp") as target: | ||||||
|  |         assert_image_equal(im, target) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user