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 ........
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """Tests for distutils.spawn."""
 | |
| import unittest
 | |
| import os
 | |
| import time
 | |
| from test.support import captured_stdout, run_unittest
 | |
| 
 | |
| from distutils.spawn import _nt_quote_args
 | |
| from distutils.spawn import spawn, find_executable
 | |
| from distutils.errors import DistutilsExecError
 | |
| from distutils.tests import support
 | |
| 
 | |
| class SpawnTestCase(support.TempdirManager,
 | |
|                     support.LoggingSilencer,
 | |
|                     unittest.TestCase):
 | |
| 
 | |
|     def test_nt_quote_args(self):
 | |
| 
 | |
|         for (args, wanted) in ((['with space', 'nospace'],
 | |
|                                 ['"with space"', 'nospace']),
 | |
|                                (['nochange', 'nospace'],
 | |
|                                 ['nochange', 'nospace'])):
 | |
|             res = _nt_quote_args(args)
 | |
|             self.assertEqual(res, wanted)
 | |
| 
 | |
| 
 | |
|     @unittest.skipUnless(os.name in ('nt', 'posix'),
 | |
|                          'Runs only under posix or nt')
 | |
|     def test_spawn(self):
 | |
|         tmpdir = self.mkdtemp()
 | |
| 
 | |
|         # creating something executable
 | |
|         # through the shell that returns 1
 | |
|         if os.name == 'posix':
 | |
|             exe = os.path.join(tmpdir, 'foo.sh')
 | |
|             self.write_file(exe, '#!/bin/sh\nexit 1')
 | |
|         else:
 | |
|             exe = os.path.join(tmpdir, 'foo.bat')
 | |
|             self.write_file(exe, 'exit 1')
 | |
| 
 | |
|         os.chmod(exe, 0o777)
 | |
|         self.assertRaises(DistutilsExecError, spawn, [exe])
 | |
| 
 | |
|         # now something that works
 | |
|         if os.name == 'posix':
 | |
|             exe = os.path.join(tmpdir, 'foo.sh')
 | |
|             self.write_file(exe, '#!/bin/sh\nexit 0')
 | |
|         else:
 | |
|             exe = os.path.join(tmpdir, 'foo.bat')
 | |
|             self.write_file(exe, 'exit 0')
 | |
| 
 | |
|         os.chmod(exe, 0o777)
 | |
|         spawn([exe])  # should work without any error
 | |
| 
 | |
| def test_suite():
 | |
|     return unittest.makeSuite(SpawnTestCase)
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     run_unittest(test_suite())
 |