Skip to content

Commit 0ff3d95

Browse files
authored
bpo-45507: EOFErrors should be thrown for truncated gzip members (GH-29029)
1 parent 7e44dc0 commit 0ff3d95

File tree

3 files changed

+12
-0
lines changed

3 files changed

+12
-0
lines changed

Lib/gzip.py

+3
Original file line numberDiff line numberDiff line change
@@ -603,6 +603,9 @@ def decompress(data):
603603
do = zlib.decompressobj(wbits=-zlib.MAX_WBITS)
604604
# Read all the data except the header
605605
decompressed = do.decompress(data[fp.tell():])
606+
if not do.eof or len(do.unused_data) < 8:
607+
raise EOFError("Compressed file ended before the end-of-stream "
608+
"marker was reached")
606609
crc, length = struct.unpack("<II", do.unused_data[:8])
607610
if crc != zlib.crc32(decompressed):
608611
raise BadGzipFile("CRC check failed")

Lib/test/test_gzip.py

+8
Original file line numberDiff line numberDiff line change
@@ -562,6 +562,14 @@ def test_decompress(self):
562562
datac = gzip.compress(data)
563563
self.assertEqual(gzip.decompress(datac), data)
564564

565+
def test_decompress_truncated_trailer(self):
566+
compressed_data = gzip.compress(data1)
567+
self.assertRaises(EOFError, gzip.decompress, compressed_data[:-4])
568+
569+
def test_decompress_missing_trailer(self):
570+
compressed_data = gzip.compress(data1)
571+
self.assertRaises(EOFError, gzip.decompress, compressed_data[:-8])
572+
565573
def test_read_truncated(self):
566574
data = data1*50
567575
# Drop the CRC (4 bytes) and file size (4 bytes).
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Add tests for truncated/missing trailers in gzip.decompress implementation.

0 commit comments

Comments
 (0)