@@ -2272,6 +2272,66 @@ def test_decompress_without_3rd_party_library(self):
2272
2272
with zipfile .ZipFile (zip_file ) as zf :
2273
2273
self .assertRaises (RuntimeError , zf .extract , 'a.txt' )
2274
2274
2275
+ @requires_zlib ()
2276
+ def test_full_overlap (self ):
2277
+ data = (
2278
+ b'PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 \x1e '
2279
+ b'8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 a\xed '
2280
+ b'\xc0 \x81 \x08 \x00 \x00 \x00 \xc0 0\xd6 \xfb K\\ d\x0b `P'
2281
+ b'K\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 '
2282
+ b'\x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 \x00 '
2283
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 aPK'
2284
+ b'\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 \xe2 \x1e '
2285
+ b'8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 \x00 \x00 \x00 \x00 '
2286
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 bPK\x05 '
2287
+ b'\x06 \x00 \x00 \x00 \x00 \x02 \x00 \x02 \x00 ^\x00 \x00 \x00 /\x00 \x00 '
2288
+ b'\x00 \x00 \x00 '
2289
+ )
2290
+ with zipfile .ZipFile (io .BytesIO (data ), 'r' ) as zipf :
2291
+ self .assertEqual (zipf .namelist (), ['a' , 'b' ])
2292
+ zi = zipf .getinfo ('a' )
2293
+ self .assertEqual (zi .header_offset , 0 )
2294
+ self .assertEqual (zi .compress_size , 16 )
2295
+ self .assertEqual (zi .file_size , 1033 )
2296
+ zi = zipf .getinfo ('b' )
2297
+ self .assertEqual (zi .header_offset , 0 )
2298
+ self .assertEqual (zi .compress_size , 16 )
2299
+ self .assertEqual (zi .file_size , 1033 )
2300
+ self .assertEqual (len (zipf .read ('a' )), 1033 )
2301
+ with self .assertRaisesRegex (zipfile .BadZipFile , 'File name.*differ' ):
2302
+ zipf .read ('b' )
2303
+
2304
+ @requires_zlib ()
2305
+ def test_quoted_overlap (self ):
2306
+ data = (
2307
+ b'PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 lH\x05 Y\xfc '
2308
+ b'8\x04 4\x00 \x00 \x00 (\x04 \x00 \x00 \x01 \x00 \x00 \x00 a\x00 '
2309
+ b'\x1f \x00 \xe0 \xff PK\x03 \x04 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 l'
2310
+ b'H\x05 \xe2 \x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 '
2311
+ b'\x00 \x00 b\xed \xc0 \x81 \x08 \x00 \x00 \x00 \xc0 0\xd6 \xfb K\\ '
2312
+ b'd\x0b `PK\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 '
2313
+ b'lH\x05 Y\xfc 8\x04 4\x00 \x00 \x00 (\x04 \x00 \x00 \x01 '
2314
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 '
2315
+ b'\x00 aPK\x01 \x02 \x14 \x00 \x14 \x00 \x00 \x00 \x08 \x00 \xa0 l'
2316
+ b'H\x05 \xe2 \x1e 8\xbb \x10 \x00 \x00 \x00 \t \x04 \x00 \x00 \x01 \x00 '
2317
+ b'\x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 \x00 $\x00 \x00 \x00 '
2318
+ b'bPK\x05 \x06 \x00 \x00 \x00 \x00 \x02 \x00 \x02 \x00 ^\x00 \x00 '
2319
+ b'\x00 S\x00 \x00 \x00 \x00 \x00 '
2320
+ )
2321
+ with zipfile .ZipFile (io .BytesIO (data ), 'r' ) as zipf :
2322
+ self .assertEqual (zipf .namelist (), ['a' , 'b' ])
2323
+ zi = zipf .getinfo ('a' )
2324
+ self .assertEqual (zi .header_offset , 0 )
2325
+ self .assertEqual (zi .compress_size , 52 )
2326
+ self .assertEqual (zi .file_size , 1064 )
2327
+ zi = zipf .getinfo ('b' )
2328
+ self .assertEqual (zi .header_offset , 36 )
2329
+ self .assertEqual (zi .compress_size , 16 )
2330
+ self .assertEqual (zi .file_size , 1033 )
2331
+ with self .assertRaisesRegex (zipfile .BadZipFile , 'Overlapped entries' ):
2332
+ zipf .read ('a' )
2333
+ self .assertEqual (len (zipf .read ('b' )), 1033 )
2334
+
2275
2335
def tearDown (self ):
2276
2336
unlink (TESTFN )
2277
2337
unlink (TESTFN2 )
0 commit comments