| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  | # Tests of the full ZIP64 functionality of zipfile | 
					
						
							|  |  |  | # The test_support.requires call is the only reason for keeping this separate | 
					
						
							|  |  |  | # from test_zipfile | 
					
						
							|  |  |  | from test import test_support | 
					
						
							| 
									
										
										
										
											2006-06-16 04:30:34 +00:00
										 |  |  | # XXX(nnorwitz): disable this test by looking for extra largfile resource | 
					
						
							|  |  |  | # which doesn't exist.  This test takes over 30 minutes to run in general | 
					
						
							|  |  |  | # and requires more disk space than most of the buildbots. | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  | test_support.requires( | 
					
						
							| 
									
										
										
										
											2006-06-16 04:30:34 +00:00
										 |  |  |         'extralargefile', | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         'test requires loads of disk-space bytes and a long time to run' | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # We can test part of the module without zlib. | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     import zlib | 
					
						
							|  |  |  | except ImportError: | 
					
						
							|  |  |  |     zlib = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import zipfile, os, unittest | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  | import time | 
					
						
							|  |  |  | import sys | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | from StringIO import StringIO | 
					
						
							|  |  |  | from tempfile import TemporaryFile | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from test.test_support import TESTFN, run_unittest | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TESTFN2 = TESTFN + "2" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  | # How much time in seconds can pass before we print a 'Still working' message. | 
					
						
							|  |  |  | _PRINT_WORKING_MSG_INTERVAL = 5 * 60 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  | class TestsWithSourceFile(unittest.TestCase): | 
					
						
							|  |  |  |     def setUp(self): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |         # Create test data. | 
					
						
							|  |  |  |         # xrange() is important here -- don't want to create immortal space | 
					
						
							|  |  |  |         # for a million ints. | 
					
						
							|  |  |  |         line_gen = ("Test of zipfile line %d." % i for i in xrange(1000000)) | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         self.data = '\n'.join(line_gen) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |         # And write it to a file. | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         fp = open(TESTFN, "wb") | 
					
						
							|  |  |  |         fp.write(self.data) | 
					
						
							|  |  |  |         fp.close() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def zipTest(self, f, compression): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |         # Create the ZIP archive. | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         zipfp = zipfile.ZipFile(f, "w", compression, allowZip64=True) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |         # It will contain enough copies of self.data to reach about 6GB of | 
					
						
							|  |  |  |         # raw data to store. | 
					
						
							| 
									
										
										
										
											2006-06-15 18:38:19 +00:00
										 |  |  |         filecount = 6*1024**3 // len(self.data) | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  |         next_time = time.time() + _PRINT_WORKING_MSG_INTERVAL | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         for num in range(filecount): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |             zipfp.writestr("testfn%d" % num, self.data) | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  |             # Print still working message since this test can be really slow | 
					
						
							|  |  |  |             if next_time <= time.time(): | 
					
						
							|  |  |  |                 next_time = time.time() + _PRINT_WORKING_MSG_INTERVAL | 
					
						
							| 
									
										
										
										
											2006-06-15 10:24:49 +00:00
										 |  |  |                 print >>sys.__stdout__, ( | 
					
						
							|  |  |  |                    '  zipTest still writing %d of %d, be patient...' % | 
					
						
							|  |  |  |                    (num, filecount)) | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  |                 sys.__stdout__.flush() | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         zipfp.close() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Read the ZIP archive | 
					
						
							|  |  |  |         zipfp = zipfile.ZipFile(f, "r", compression) | 
					
						
							|  |  |  |         for num in range(filecount): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |             self.assertEqual(zipfp.read("testfn%d" % num), self.data) | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  |             # Print still working message since this test can be really slow | 
					
						
							|  |  |  |             if next_time <= time.time(): | 
					
						
							|  |  |  |                 next_time = time.time() + _PRINT_WORKING_MSG_INTERVAL | 
					
						
							| 
									
										
										
										
											2006-06-15 10:24:49 +00:00
										 |  |  |                 print >>sys.__stdout__, ( | 
					
						
							|  |  |  |                    '  zipTest still reading %d of %d, be patient...' % | 
					
						
							|  |  |  |                    (num, filecount)) | 
					
						
							| 
									
										
										
										
											2006-06-15 09:57:03 +00:00
										 |  |  |                 sys.__stdout__.flush() | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |         zipfp.close() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def testStored(self): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |         # Try the temp file first.  If we do TESTFN2 first, then it hogs | 
					
						
							|  |  |  |         # gigabytes of disk space for the duration of the test. | 
					
						
							|  |  |  |         for f in TemporaryFile(), TESTFN2: | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |             self.zipTest(f, zipfile.ZIP_STORED) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if zlib: | 
					
						
							|  |  |  |         def testDeflated(self): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |             # Try the temp file first.  If we do TESTFN2 first, then it hogs | 
					
						
							|  |  |  |             # gigabytes of disk space for the duration of the test. | 
					
						
							|  |  |  |             for f in TemporaryFile(), TESTFN2: | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  |                 self.zipTest(f, zipfile.ZIP_DEFLATED) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def tearDown(self): | 
					
						
							| 
									
										
										
										
											2006-06-15 18:04:40 +00:00
										 |  |  |         for fname in TESTFN, TESTFN2: | 
					
						
							|  |  |  |             if os.path.exists(fname): | 
					
						
							|  |  |  |                 os.remove(fname) | 
					
						
							| 
									
										
										
										
											2006-06-15 08:14:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def test_main(): | 
					
						
							|  |  |  |     run_unittest(TestsWithSourceFile) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if __name__ == "__main__": | 
					
						
							|  |  |  |     test_main() |