| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | """Tests for distutils.dir_util.""" | 
					
						
							|  |  |  | import unittest | 
					
						
							|  |  |  | import os | 
					
						
							| 
									
										
										
										
											2010-09-17 16:35:37 +00:00
										 |  |  | import stat | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | import shutil | 
					
						
							| 
									
										
										
										
											2010-09-18 02:55:03 +00:00
										 |  |  | import sys | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-17 11:14:15 +00:00
										 |  |  | from distutils.dir_util import (mkpath, remove_tree, create_tree, copy_tree, | 
					
						
							|  |  |  |                                 ensure_relative) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | from distutils import log | 
					
						
							| 
									
										
										
										
											2009-02-14 14:35:51 +00:00
										 |  |  | from distutils.tests import support | 
					
						
							| 
									
										
										
										
											2010-11-06 02:44:43 +00:00
										 |  |  | from test.support import run_unittest | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-14 14:35:51 +00:00
										 |  |  | class DirUtilTestCase(support.TempdirManager, unittest.TestCase): | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def _log(self, msg, *args): | 
					
						
							|  |  |  |         if len(args) > 0: | 
					
						
							|  |  |  |             self._logs.append(msg % args) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self._logs.append(msg) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def setUp(self): | 
					
						
							| 
									
										
										
										
											2009-05-29 09:14:04 +00:00
										 |  |  |         super(DirUtilTestCase, self).setUp() | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |         self._logs = [] | 
					
						
							| 
									
										
										
										
											2009-02-14 14:35:51 +00:00
										 |  |  |         tmp_dir = self.mkdtemp() | 
					
						
							|  |  |  |         self.root_target = os.path.join(tmp_dir, 'deep') | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |         self.target = os.path.join(self.root_target, 'here') | 
					
						
							| 
									
										
										
										
											2009-02-14 14:35:51 +00:00
										 |  |  |         self.target2 = os.path.join(tmp_dir, 'deep2') | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |         self.old_log = log.info | 
					
						
							|  |  |  |         log.info = self._log | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def tearDown(self): | 
					
						
							|  |  |  |         log.info = self.old_log | 
					
						
							| 
									
										
										
										
											2009-05-29 09:14:04 +00:00
										 |  |  |         super(DirUtilTestCase, self).tearDown() | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_mkpath_remove_tree_verbosity(self): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         mkpath(self.target, verbose=0) | 
					
						
							|  |  |  |         wanted = [] | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, wanted) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |         remove_tree(self.root_target, verbose=0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         mkpath(self.target, verbose=1) | 
					
						
							|  |  |  |         wanted = ['creating %s' % self.root_target, | 
					
						
							|  |  |  |                   'creating %s' % self.target] | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, wanted) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |         self._logs = [] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         remove_tree(self.root_target, verbose=1) | 
					
						
							|  |  |  |         wanted = ["removing '%s' (and everything under it)" % self.root_target] | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, wanted) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-18 02:55:03 +00:00
										 |  |  |     @unittest.skipIf(sys.platform.startswith('win'), | 
					
						
							|  |  |  |                         "This test is only appropriate for POSIX-like systems.") | 
					
						
							| 
									
										
										
										
											2010-09-17 16:35:37 +00:00
										 |  |  |     def test_mkpath_with_custom_mode(self): | 
					
						
							| 
									
										
										
										
											2010-09-19 03:09:54 +00:00
										 |  |  |         # Get and set the current umask value for testing mode bits. | 
					
						
							|  |  |  |         umask = os.umask(0o002) | 
					
						
							|  |  |  |         os.umask(umask) | 
					
						
							| 
									
										
										
										
											2010-09-17 16:35:37 +00:00
										 |  |  |         mkpath(self.target, 0o700) | 
					
						
							| 
									
										
										
										
											2010-09-19 03:09:54 +00:00
										 |  |  |         self.assertEqual( | 
					
						
							|  |  |  |             stat.S_IMODE(os.stat(self.target).st_mode), 0o700 & ~umask) | 
					
						
							| 
									
										
										
										
											2010-09-17 16:35:37 +00:00
										 |  |  |         mkpath(self.target2, 0o555) | 
					
						
							| 
									
										
										
										
											2010-09-19 03:09:54 +00:00
										 |  |  |         self.assertEqual( | 
					
						
							|  |  |  |             stat.S_IMODE(os.stat(self.target2).st_mode), 0o555 & ~umask) | 
					
						
							| 
									
										
										
										
											2010-09-17 16:35:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |     def test_create_tree_verbosity(self): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         create_tree(self.root_target, ['one', 'two', 'three'], verbose=0) | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, []) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  |         remove_tree(self.root_target, verbose=0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         wanted = ['creating %s' % self.root_target] | 
					
						
							|  |  |  |         create_tree(self.root_target, ['one', 'two', 'three'], verbose=1) | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, wanted) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         remove_tree(self.root_target, verbose=0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_copy_tree_verbosity(self): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         mkpath(self.target, verbose=0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         copy_tree(self.target, self.target2, verbose=0) | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, []) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         remove_tree(self.root_target, verbose=0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         mkpath(self.target, verbose=0) | 
					
						
							|  |  |  |         a_file = os.path.join(self.target, 'ok.txt') | 
					
						
							|  |  |  |         f = open(a_file, 'w') | 
					
						
							| 
									
										
										
										
											2010-11-05 23:51:56 +00:00
										 |  |  |         try: | 
					
						
							|  |  |  |             f.write('some content') | 
					
						
							|  |  |  |         finally: | 
					
						
							|  |  |  |             f.close() | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         wanted = ['copying %s -> %s' % (a_file, self.target2)] | 
					
						
							|  |  |  |         copy_tree(self.target, self.target2, verbose=1) | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self._logs, wanted) | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         remove_tree(self.root_target, verbose=0) | 
					
						
							|  |  |  |         remove_tree(self.target2, verbose=0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-17 11:14:15 +00:00
										 |  |  |     def test_ensure_relative(self): | 
					
						
							|  |  |  |         if os.sep == '/': | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |             self.assertEqual(ensure_relative('/home/foo'), 'home/foo') | 
					
						
							|  |  |  |             self.assertEqual(ensure_relative('some/path'), 'some/path') | 
					
						
							| 
									
										
										
										
											2009-05-17 11:14:15 +00:00
										 |  |  |         else:   # \\ | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |             self.assertEqual(ensure_relative('c:\\home\\foo'), 'c:home\\foo') | 
					
						
							|  |  |  |             self.assertEqual(ensure_relative('home\\foo'), 'home\\foo') | 
					
						
							| 
									
										
										
										
											2009-05-17 11:14:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-06 00:38:35 +00:00
										 |  |  | def test_suite(): | 
					
						
							|  |  |  |     return unittest.makeSuite(DirUtilTestCase) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if __name__ == "__main__": | 
					
						
							| 
									
										
										
										
											2010-11-06 02:44:43 +00:00
										 |  |  |     run_unittest(test_suite()) |