@@ -2245,6 +2245,64 @@ def test_decompress_without_3rd_party_library(self):
22452245 with zipfile .ZipFile (zip_file ) as zf :
22462246 self .assertRaises (RuntimeError , zf .extract , 'a.txt' )
22472247
2248+ def test_full_overlap (self ):
2249+ data = (
2250+ b'PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 \x1e '
2251+ b'8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 a\xed '
2252+ b'\xc0 \x81 \x08 \x00 \x00 \x00 \xc0 0\xd6 \xfb K\\ d\x0b `P'
2253+ b'K\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 '
2254+ b'\x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 \x00 '
2255+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 aPK'
2256+ b'\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 \x1e '
2257+ b'8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 \x00 \x00 '
2258+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 bPK\x05 '
2259+ b'\x06 \x00 \x00 \x00 \x00 \x02 \x00 \x02 \x00 ^\x00 \x00 \x00 /\x00 \x00 '
2260+ b'\x00 \x00 \x00 '
2261+ )
2262+ with zipfile .ZipFile (io .BytesIO (data ), 'r' ) as zipf :
2263+ self .assertEqual (zipf .namelist (), ['a' , 'b' ])
2264+ zi = zipf .getinfo ('a' )
2265+ self .assertEqual (zi .header_offset , 0 )
2266+ self .assertEqual (zi .compress_size , 16 )
2267+ self .assertEqual (zi .file_size , 1033 )
2268+ zi = zipf .getinfo ('b' )
2269+ self .assertEqual (zi .header_offset , 0 )
2270+ self .assertEqual (zi .compress_size , 16 )
2271+ self .assertEqual (zi .file_size , 1033 )
2272+ self .assertEqual (len (zipf .read ('a' )), 1033 )
2273+ with self .assertRaisesRegex (zipfile .BadZipFile , 'File name.*differ' ):
2274+ zipf .read ('b' )
2275+
2276+ def test_quoted_overlap (self ):
2277+ data = (
2278+ b'PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 Y\xfc '
2279+ b'8\x04 4\x00 \x00 \x00 (\x04 \x00 \x00 \x01 \x00 \x00 \x00 a\x00 '
2280+ b'\x1f \x00 \xe0 \xff PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 l'
2281+ b'H\x05 \xe2 \x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 '
2282+ b'\x00 \x00 b\xed \xc0 \x81 \x08 \x00 \x00 \x00 \xc0 0\xd6 \xfb K\\ '
2283+ b'd\x0b `PK\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 '
2284+ b'lH\x05 Y\xfc 8\x04 4\x00 \x00 \x00 (\x04 \x00 \x00 \x01 '
2285+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 '
2286+ b'\x00 aPK\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 l'
2287+ b'H\x05 \xe2 \x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 '
2288+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 $\x00 \x00 \x00 '
2289+ b'bPK\x05 \x06 \x00 \x00 \x00 \x00 \x02 \x00 \x02 \x00 ^\x00 \x00 '
2290+ b'\x00 S\x00 \x00 \x00 \x00 \x00 '
2291+ )
2292+ with zipfile .ZipFile (io .BytesIO (data ), 'r' ) as zipf :
2293+ self .assertEqual (zipf .namelist (), ['a' , 'b' ])
2294+ zi = zipf .getinfo ('a' )
2295+ self .assertEqual (zi .header_offset , 0 )
2296+ self .assertEqual (zi .compress_size , 52 )
2297+ self .assertEqual (zi .file_size , 1064 )
2298+ zi = zipf .getinfo ('b' )
2299+ self .assertEqual (zi .header_offset , 36 )
2300+ self .assertEqual (zi .compress_size , 16 )
2301+ self .assertEqual (zi .file_size , 1033 )
2302+ with self .assertRaisesRegex (zipfile .BadZipFile , 'Overlapped entries' ):
2303+ zipf .read ('a' )
2304+ self .assertEqual (len (zipf .read ('b' )), 1033 )
2305+
22482306 def tearDown (self ):
22492307 unlink (TESTFN )
22502308 unlink (TESTFN2 )
0 commit comments