@@ -2059,6 +2059,66 @@ def test_decompress_without_3rd_party_library(self):
2059
2059
with zipfile .ZipFile (zip_file ) as zf :
2060
2060
self .assertRaises (RuntimeError , zf .extract , 'a.txt' )
2061
2061
2062
+ @requires_zlib ()
2063
+ def test_full_overlap (self ):
2064
+ data = (
2065
+ b'PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 \x1e '
2066
+ b'8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 a\xed '
2067
+ b'\xc0 \x81 \x08 \x00 \x00 \x00 \xc0 0\xd6 \xfb K\\ d\x0b `P'
2068
+ b'K\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 '
2069
+ b'\x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 \x00 '
2070
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 aPK'
2071
+ b'\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 \x1e '
2072
+ b'8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 \x00 \x00 '
2073
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 bPK\x05 '
2074
+ b'\x06 \x00 \x00 \x00 \x00 \x02 \x00 \x02 \x00 ^\x00 \x00 \x00 /\x00 \x00 '
2075
+ b'\x00 \x00 \x00 '
2076
+ )
2077
+ with zipfile .ZipFile (io .BytesIO (data ), 'r' ) as zipf :
2078
+ self .assertEqual (zipf .namelist (), ['a' , 'b' ])
2079
+ zi = zipf .getinfo ('a' )
2080
+ self .assertEqual (zi .header_offset , 0 )
2081
+ self .assertEqual (zi .compress_size , 16 )
2082
+ self .assertEqual (zi .file_size , 1033 )
2083
+ zi = zipf .getinfo ('b' )
2084
+ self .assertEqual (zi .header_offset , 0 )
2085
+ self .assertEqual (zi .compress_size , 16 )
2086
+ self .assertEqual (zi .file_size , 1033 )
2087
+ self .assertEqual (len (zipf .read ('a' )), 1033 )
2088
+ with self .assertRaisesRegex (zipfile .BadZipFile , 'File name.*differ' ):
2089
+ zipf .read ('b' )
2090
+
2091
+ @requires_zlib ()
2092
+ def test_quoted_overlap (self ):
2093
+ data = (
2094
+ b'PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 Y\xfc '
2095
+ b'8\x04 4\x00 \x00 \x00 (\x04 \x00 \x00 \x01 \x00 \x00 \x00 a\x00 '
2096
+ b'\x1f \x00 \xe0 \xff PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 l'
2097
+ b'H\x05 \xe2 \x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 '
2098
+ b'\x00 \x00 b\xed \xc0 \x81 \x08 \x00 \x00 \x00 \xc0 0\xd6 \xfb K\\ '
2099
+ b'd\x0b `PK\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 '
2100
+ b'lH\x05 Y\xfc 8\x04 4\x00 \x00 \x00 (\x04 \x00 \x00 \x01 '
2101
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 '
2102
+ b'\x00 aPK\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 l'
2103
+ b'H\x05 \xe2 \x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 '
2104
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 $\x00 \x00 \x00 '
2105
+ b'bPK\x05 \x06 \x00 \x00 \x00 \x00 \x02 \x00 \x02 \x00 ^\x00 \x00 '
2106
+ b'\x00 S\x00 \x00 \x00 \x00 \x00 '
2107
+ )
2108
+ with zipfile .ZipFile (io .BytesIO (data ), 'r' ) as zipf :
2109
+ self .assertEqual (zipf .namelist (), ['a' , 'b' ])
2110
+ zi = zipf .getinfo ('a' )
2111
+ self .assertEqual (zi .header_offset , 0 )
2112
+ self .assertEqual (zi .compress_size , 52 )
2113
+ self .assertEqual (zi .file_size , 1064 )
2114
+ zi = zipf .getinfo ('b' )
2115
+ self .assertEqual (zi .header_offset , 36 )
2116
+ self .assertEqual (zi .compress_size , 16 )
2117
+ self .assertEqual (zi .file_size , 1033 )
2118
+ with self .assertRaisesRegex (zipfile .BadZipFile , 'Overlapped entries' ):
2119
+ zipf .read ('a' )
2120
+ self .assertEqual (len (zipf .read ('b' )), 1033 )
2121
+
2062
2122
def tearDown (self ):
2063
2123
unlink (TESTFN )
2064
2124
unlink (TESTFN2 )
0 commit comments