diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-01-22 17:11:07 +0200 |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-01-22 17:11:07 +0200 |
commit | cc0172c00704e8292c90e02e776b0c193ca75477 (patch) | |
tree | 07543135f64a58a54b91ee7fd96de40acbc1780f /Lib/test/test_bz2.py | |
parent | 791c97a6a89e30d02fe4b0746daec61de44a5ad3 (diff) | |
parent | 57f9b7a12420d461e8ea5cc1ba63f80de778c7d5 (diff) | |
download | cpython-git-cc0172c00704e8292c90e02e776b0c193ca75477.tar.gz |
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.py | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_bz2.py b/Lib/test/test_bz2.py index 8703df7909..7090cd6935 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): |