summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_bz2.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2013-01-22 15:11:07 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2013-01-22 15:11:07 (GMT)
commitcc0172c00704e8292c90e02e776b0c193ca75477 (patch)
tree07543135f64a58a54b91ee7fd96de40acbc1780f /Lib/test/test_bz2.py
parent791c97a6a89e30d02fe4b0746daec61de44a5ad3 (diff)
parent57f9b7a12420d461e8ea5cc1ba63f80de778c7d5 (diff)
downloadcpython-cc0172c00704e8292c90e02e776b0c193ca75477.zip
cpython-cc0172c00704e8292c90e02e776b0c193ca75477.tar.gz
cpython-cc0172c00704e8292c90e02e776b0c193ca75477.tar.bz2
Issue #1159051: GzipFile now raises EOFError when reading a corrupted file
with truncated header or footer. Added tests for reading truncated gzip, bzip2, and lzma files.
Diffstat (limited to 'Lib/test/test_bz2.py')
-rw-r--r--Lib/test/test_bz2.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_bz2.py b/Lib/test/test_bz2.py
index 8703df7..7090cd6 100644
--- a/Lib/test/test_bz2.py
+++ b/Lib/test/test_bz2.py
@@ -569,6 +569,19 @@ class BZ2FileTest(BaseTest):
bz2f.seek(-150, 1)
self.assertEqual(bz2f.read(), self.TEXT[500-150:])
+ def test_read_truncated(self):
+ # Drop the eos_magic field (6 bytes) and CRC (4 bytes).
+ truncated = self.DATA[:-10]
+ with BZ2File(BytesIO(truncated)) as f:
+ self.assertRaises(EOFError, f.read)
+ with BZ2File(BytesIO(truncated)) as f:
+ self.assertEqual(f.read(len(self.TEXT)), self.TEXT)
+ self.assertRaises(EOFError, f.read, 1)
+ # Incomplete 4-byte file header, and block header of at least 146 bits.
+ for i in range(22):
+ with BZ2File(BytesIO(truncated[:i])) as f:
+ self.assertRaises(EOFError, f.read, 1)
+
class BZ2CompressorTest(BaseTest):
def testCompress(self):