Skip to content

Commit 6c61de9

Browse files
committed
Added GD tests
1 parent e0c6ca9 commit 6c61de9

File tree

3 files changed

+40
-6
lines changed

3 files changed

+40
-6
lines changed

Tests/images/hopper.gd

17 KB
Binary file not shown.

Tests/test_file_gd.py

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
from helper import unittest, PillowTestCase
2+
3+
from PIL import GdImageFile
4+
5+
import io
6+
7+
TEST_GD_FILE = "Tests/images/hopper.gd"
8+
9+
10+
class TestFileGd(PillowTestCase):
11+
12+
def test_sanity(self):
13+
im = GdImageFile.open(TEST_GD_FILE)
14+
self.assertEqual(im.size, (128, 128))
15+
self.assertEqual(im.format, "GD")
16+
17+
def test_bad_mode(self):
18+
self.assertRaises(ValueError,
19+
GdImageFile.open, TEST_GD_FILE, 'bad mode')
20+
21+
def test_invalid_file(self):
22+
invalid_file = "Tests/images/flower.jpg"
23+
24+
self.assertRaises(IOError, GdImageFile.open, invalid_file)
25+
26+
27+
if __name__ == '__main__':
28+
unittest.main()

src/PIL/GdImageFile.py

Lines changed: 12 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@
2424

2525

2626
from . import ImageFile, ImagePalette
27-
from ._binary import i16be as i16
27+
from ._binary import i8, i16be as i16, i32be as i32
2828

2929
__version__ = "0.1"
3030

@@ -43,19 +43,25 @@ class GdImageFile(ImageFile.ImageFile):
4343
def _open(self):
4444

4545
# Header
46-
s = self.fp.read(775)
46+
s = self.fp.read(1037)
47+
48+
if not i16(s[:2]) in [65534, 65535]:
49+
raise SyntaxError("Not a valid GD 2.x .gd file")
4750

4851
self.mode = "L" # FIXME: "P"
49-
self.size = i16(s[0:2]), i16(s[2:4])
52+
self.size = i16(s[2:4]), i16(s[4:6])
53+
54+
trueColor = i8(s[6])
55+
trueColorOffset = 2 if trueColor else 0
5056

5157
# transparency index
52-
tindex = i16(s[5:7])
58+
tindex = i32(s[7+trueColorOffset:7+trueColorOffset+4])
5359
if tindex < 256:
5460
self.info["transparency"] = tindex
5561

56-
self.palette = ImagePalette.raw("RGB", s[7:])
62+
self.palette = ImagePalette.raw("XBGR", s[7+trueColorOffset+4:7+trueColorOffset+4+256*4])
5763

58-
self.tile = [("raw", (0, 0)+self.size, 775, ("L", 0, -1))]
64+
self.tile = [("raw", (0, 0)+self.size, 7+trueColorOffset+4+256*4, ("L", 0, 1))]
5965

6066

6167
def open(fp, mode="r"):

0 commit comments

Comments
 (0)