mirror of
https://github.com/python/cpython.git
synced 2025-08-19 00:00:48 +00:00
#10694: zipfile now ignores garbage at the end of a zipfile.
Original fix by 'rep', final patch (with tests) by Xuanji Li.
This commit is contained in:
parent
5446f08c60
commit
873c583244
3 changed files with 27 additions and 9 deletions
|
@ -335,6 +335,24 @@ class TestsWithSourceFile(unittest.TestCase):
|
|||
with zipfile.ZipFile(f, "r") as zipfp:
|
||||
self.assertEqual(zipfp.namelist(), [TESTFN])
|
||||
|
||||
def test_ignores_newline_at_end(self):
|
||||
with zipfile.ZipFile(TESTFN2, "w", zipfile.ZIP_STORED) as zipfp:
|
||||
zipfp.write(TESTFN, TESTFN)
|
||||
with open(TESTFN2, 'a') as f:
|
||||
f.write("\r\n\00\00\00")
|
||||
with zipfile.ZipFile(TESTFN2, "r") as zipfp:
|
||||
self.assertIsInstance(zipfp, zipfile.ZipFile)
|
||||
|
||||
def test_ignores_stuff_appended_past_comments(self):
|
||||
with zipfile.ZipFile(TESTFN2, "w", zipfile.ZIP_STORED) as zipfp:
|
||||
zipfp.comment = b"this is a comment"
|
||||
zipfp.write(TESTFN, TESTFN)
|
||||
with open(TESTFN2, 'a') as f:
|
||||
f.write("abcdef\r\n")
|
||||
with zipfile.ZipFile(TESTFN2, "r") as zipfp:
|
||||
self.assertIsInstance(zipfp, zipfile.ZipFile)
|
||||
self.assertEqual(zipfp.comment, b"this is a comment")
|
||||
|
||||
def test_write_default_name(self):
|
||||
"""Check that calling ZipFile.write without arcname specified
|
||||
produces the expected result."""
|
||||
|
|
|
@ -236,10 +236,8 @@ def _EndRecData(fpin):
|
|||
# found the magic number; attempt to unpack and interpret
|
||||
recData = data[start:start+sizeEndCentDir]
|
||||
endrec = list(struct.unpack(structEndArchive, recData))
|
||||
comment = data[start+sizeEndCentDir:]
|
||||
# check that comment length is correct
|
||||
if endrec[_ECD_COMMENT_SIZE] == len(comment):
|
||||
# Append the archive comment and start offset
|
||||
commentSize = endrec[_ECD_COMMENT_SIZE] #as claimed by the zip file
|
||||
comment = data[start+sizeEndCentDir:start+sizeEndCentDir+commentSize]
|
||||
endrec.append(comment)
|
||||
endrec.append(maxCommentStart + start)
|
||||
|
||||
|
|
|
@ -16,6 +16,8 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #10694: zipfile now ignores garbage at the end of a zipfile.
|
||||
|
||||
- Issue #11583: Speed up os.path.isdir on Windows by using GetFileAttributes
|
||||
instead of os.stat.
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue