mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 13:41:24 +00:00 
			
		
		
		
	 b344dd06c8
			
		
	
	
		b344dd06c8
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/branches/py3k The missing NEWS entries correspond to changes that were made before 3.1.3, but I think it’s not usual to edit entries of released versions, so I put them at the top. ........ r86236 | eric.araujo | 2010-11-06 03:44:43 +0100 (sam., 06 nov. 2010) | 2 lines Make sure each test can be run standalone (./python Lib/distutils/tests/x.py) ........ r86240 | eric.araujo | 2010-11-06 05:11:59 +0100 (sam., 06 nov. 2010) | 2 lines Prevent ResourceWarnings in test_gettext ........ r86332 | eric.araujo | 2010-11-08 19:15:17 +0100 (lun., 08 nov. 2010) | 4 lines Add missing NEWS entry for a fix committed by Senthil. All recent modifications to distutils should now be covered in NEWS. ........ r86340 | eric.araujo | 2010-11-08 22:48:23 +0100 (lun., 08 nov. 2010) | 2 lines This was actually fixed for the previous alpha. ........ r87271 | eric.araujo | 2010-12-15 20:09:58 +0100 (mer., 15 déc. 2010) | 2 lines Improve trace documentation (#9264). Patch by Eli Bendersky. ........ r87273 | eric.araujo | 2010-12-15 20:30:15 +0100 (mer., 15 déc. 2010) | 2 lines Use nested method directives, rewrap long lines, fix whitespace. ........ r87447 | eric.araujo | 2010-12-23 20:13:05 +0100 (jeu., 23 déc. 2010) | 2 lines Fix typo in superclass method name ........
		
			
				
	
	
		
			214 lines
		
	
	
	
		
			7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			214 lines
		
	
	
	
		
			7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """Tests for distutils.archive_util."""
 | |
| __revision__ = "$Id$"
 | |
| 
 | |
| import unittest
 | |
| import os
 | |
| import tarfile
 | |
| from os.path import splitdrive
 | |
| import warnings
 | |
| 
 | |
| from distutils.archive_util import (check_archive_formats, make_tarball,
 | |
|                                     make_zipfile, make_archive,
 | |
|                                     ARCHIVE_FORMATS)
 | |
| from distutils.spawn import find_executable, spawn
 | |
| from distutils.tests import support
 | |
| from test.support import check_warnings, run_unittest
 | |
| 
 | |
| try:
 | |
|     import zipfile
 | |
|     ZIP_SUPPORT = True
 | |
| except ImportError:
 | |
|     ZIP_SUPPORT = find_executable('zip')
 | |
| 
 | |
| class ArchiveUtilTestCase(support.TempdirManager,
 | |
|                           support.LoggingSilencer,
 | |
|                           unittest.TestCase):
 | |
| 
 | |
|     def test_make_tarball(self):
 | |
|         # creating something to tar
 | |
|         tmpdir = self.mkdtemp()
 | |
|         self.write_file([tmpdir, 'file1'], 'xxx')
 | |
|         self.write_file([tmpdir, 'file2'], 'xxx')
 | |
|         os.mkdir(os.path.join(tmpdir, 'sub'))
 | |
|         self.write_file([tmpdir, 'sub', 'file3'], 'xxx')
 | |
| 
 | |
|         tmpdir2 = self.mkdtemp()
 | |
|         unittest.skipUnless(splitdrive(tmpdir)[0] == splitdrive(tmpdir2)[0],
 | |
|                             "Source and target should be on same drive")
 | |
| 
 | |
|         base_name = os.path.join(tmpdir2, 'archive')
 | |
| 
 | |
|         # working with relative paths to avoid tar warnings
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             make_tarball(splitdrive(base_name)[1], '.')
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
| 
 | |
|         # check if the compressed tarball was created
 | |
|         tarball = base_name + '.tar.gz'
 | |
|         self.assertTrue(os.path.exists(tarball))
 | |
| 
 | |
|         # trying an uncompressed one
 | |
|         base_name = os.path.join(tmpdir2, 'archive')
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             make_tarball(splitdrive(base_name)[1], '.', compress=None)
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
|         tarball = base_name + '.tar'
 | |
|         self.assertTrue(os.path.exists(tarball))
 | |
| 
 | |
|     def _tarinfo(self, path):
 | |
|         tar = tarfile.open(path)
 | |
|         try:
 | |
|             names = tar.getnames()
 | |
|             names.sort()
 | |
|             return tuple(names)
 | |
|         finally:
 | |
|             tar.close()
 | |
| 
 | |
|     def _create_files(self):
 | |
|         # creating something to tar
 | |
|         tmpdir = self.mkdtemp()
 | |
|         dist = os.path.join(tmpdir, 'dist')
 | |
|         os.mkdir(dist)
 | |
|         self.write_file([dist, 'file1'], 'xxx')
 | |
|         self.write_file([dist, 'file2'], 'xxx')
 | |
|         os.mkdir(os.path.join(dist, 'sub'))
 | |
|         self.write_file([dist, 'sub', 'file3'], 'xxx')
 | |
|         os.mkdir(os.path.join(dist, 'sub2'))
 | |
|         tmpdir2 = self.mkdtemp()
 | |
|         base_name = os.path.join(tmpdir2, 'archive')
 | |
|         return tmpdir, tmpdir2, base_name
 | |
| 
 | |
|     @unittest.skipUnless(find_executable('tar') and find_executable('gzip'),
 | |
|                          'Need the tar command to run')
 | |
|     def test_tarfile_vs_tar(self):
 | |
|         tmpdir, tmpdir2, base_name =  self._create_files()
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             make_tarball(base_name, 'dist')
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
| 
 | |
|         # check if the compressed tarball was created
 | |
|         tarball = base_name + '.tar.gz'
 | |
|         self.assertTrue(os.path.exists(tarball))
 | |
| 
 | |
|         # now create another tarball using `tar`
 | |
|         tarball2 = os.path.join(tmpdir, 'archive2.tar.gz')
 | |
|         tar_cmd = ['tar', '-cf', 'archive2.tar', 'dist']
 | |
|         gzip_cmd = ['gzip', '-f9', 'archive2.tar']
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             spawn(tar_cmd)
 | |
|             spawn(gzip_cmd)
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
| 
 | |
|         self.assertTrue(os.path.exists(tarball2))
 | |
|         # let's compare both tarballs
 | |
|         self.assertEqual(self._tarinfo(tarball), self._tarinfo(tarball2))
 | |
| 
 | |
|         # trying an uncompressed one
 | |
|         base_name = os.path.join(tmpdir2, 'archive')
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             make_tarball(base_name, 'dist', compress=None)
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
|         tarball = base_name + '.tar'
 | |
|         self.assertTrue(os.path.exists(tarball))
 | |
| 
 | |
|         # now for a dry_run
 | |
|         base_name = os.path.join(tmpdir2, 'archive')
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             make_tarball(base_name, 'dist', compress=None, dry_run=True)
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
|         tarball = base_name + '.tar'
 | |
|         self.assertTrue(os.path.exists(tarball))
 | |
| 
 | |
|     @unittest.skipUnless(find_executable('compress'),
 | |
|                          'The compress program is required')
 | |
|     def test_compress_deprecated(self):
 | |
|         tmpdir, tmpdir2, base_name =  self._create_files()
 | |
| 
 | |
|         # using compress and testing the PendingDeprecationWarning
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             with check_warnings() as w:
 | |
|                 warnings.simplefilter("always")
 | |
|                 make_tarball(base_name, 'dist', compress='compress')
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
|         tarball = base_name + '.tar.Z'
 | |
|         self.assertTrue(os.path.exists(tarball))
 | |
|         self.assertEqual(len(w.warnings), 1)
 | |
| 
 | |
|         # same test with dry_run
 | |
|         os.remove(tarball)
 | |
|         old_dir = os.getcwd()
 | |
|         os.chdir(tmpdir)
 | |
|         try:
 | |
|             with check_warnings() as w:
 | |
|                 warnings.simplefilter("always")
 | |
|                 make_tarball(base_name, 'dist', compress='compress',
 | |
|                              dry_run=True)
 | |
|         finally:
 | |
|             os.chdir(old_dir)
 | |
|         self.assertTrue(not os.path.exists(tarball))
 | |
|         self.assertEqual(len(w.warnings), 1)
 | |
| 
 | |
|     @unittest.skipUnless(ZIP_SUPPORT, 'Need zip support to run')
 | |
|     def test_make_zipfile(self):
 | |
|         # creating something to tar
 | |
|         tmpdir = self.mkdtemp()
 | |
|         self.write_file([tmpdir, 'file1'], 'xxx')
 | |
|         self.write_file([tmpdir, 'file2'], 'xxx')
 | |
| 
 | |
|         tmpdir2 = self.mkdtemp()
 | |
|         base_name = os.path.join(tmpdir2, 'archive')
 | |
|         make_zipfile(base_name, tmpdir)
 | |
| 
 | |
|         # check if the compressed tarball was created
 | |
|         tarball = base_name + '.zip'
 | |
| 
 | |
|     def test_check_archive_formats(self):
 | |
|         self.assertEqual(check_archive_formats(['gztar', 'xxx', 'zip']),
 | |
|                          'xxx')
 | |
|         self.assertEqual(check_archive_formats(['gztar', 'zip']), None)
 | |
| 
 | |
|     def test_make_archive(self):
 | |
|         tmpdir = self.mkdtemp()
 | |
|         base_name = os.path.join(tmpdir, 'archive')
 | |
|         self.assertRaises(ValueError, make_archive, base_name, 'xxx')
 | |
| 
 | |
|     def test_make_archive_cwd(self):
 | |
|         current_dir = os.getcwd()
 | |
|         def _breaks(*args, **kw):
 | |
|             raise RuntimeError()
 | |
|         ARCHIVE_FORMATS['xxx'] = (_breaks, [], 'xxx file')
 | |
|         try:
 | |
|             try:
 | |
|                 make_archive('xxx', 'xxx', root_dir=self.mkdtemp())
 | |
|             except:
 | |
|                 pass
 | |
|             self.assertEqual(os.getcwd(), current_dir)
 | |
|         finally:
 | |
|             del ARCHIVE_FORMATS['xxx']
 | |
| 
 | |
| def test_suite():
 | |
|     return unittest.makeSuite(ArchiveUtilTestCase)
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     run_unittest(test_suite())
 |