diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-04-08 19:35:02 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-04-08 19:35:02 (GMT) |
commit | 7e69f0085e5365347bf00f4ed08d07e5f4785a96 (patch) | |
tree | b028993963f97dd40a197d0de4e9568c86102c2a /Lib | |
parent | b0f9fa7a03ed56c2155fb251fbd423637dc86536 (diff) | |
download | cpython-7e69f0085e5365347bf00f4ed08d07e5f4785a96.zip cpython-7e69f0085e5365347bf00f4ed08d07e5f4785a96.tar.gz cpython-7e69f0085e5365347bf00f4ed08d07e5f4785a96.tar.bz2 |
Close #17666: Fix reading gzip files with an extra field.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/gzip.py | 3 | ||||
-rw-r--r-- | Lib/test/test_gzip.py | 7 |
2 files changed, 9 insertions, 1 deletions
diff --git a/Lib/gzip.py b/Lib/gzip.py index d7da02c..a1f13b4 100644 --- a/Lib/gzip.py +++ b/Lib/gzip.py @@ -302,7 +302,8 @@ class GzipFile(io.BufferedIOBase): if flag & FEXTRA: # Read & discard the extra field, if present - self._read_exact(struct.unpack("<H", self._read_exact(2))) + extra_len, = struct.unpack("<H", self._read_exact(2)) + self._read_exact(extra_len) if flag & FNAME: # Read and discard a null-terminated string containing the filename while True: diff --git a/Lib/test/test_gzip.py b/Lib/test/test_gzip.py index ebd4c43..37fe853 100644 --- a/Lib/test/test_gzip.py +++ b/Lib/test/test_gzip.py @@ -403,6 +403,13 @@ class TestGzip(BaseTest): with gzip.GzipFile(fileobj=io.BytesIO(truncated[:i])) as f: self.assertRaises(EOFError, f.read, 1) + def test_read_with_extra(self): + # Gzip data with an extra field + gzdata = (b'\x1f\x8b\x08\x04\xb2\x17cQ\x02\xff' + b'\x05\x00Extra' + b'\x0bI-.\x01\x002\xd1Mx\x04\x00\x00\x00') + with gzip.GzipFile(fileobj=io.BytesIO(gzdata)) as f: + self.assertEqual(f.read(), b'Test') class TestOpen(BaseTest): def test_binary_modes(self): |