mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 05:31:20 +00:00 
			
		
		
		
	 590fe02ebd
			
		
	
	
		590fe02ebd
		
	
	
	
	
		
			
			Make sure we aren't masking any errors raised in tempfile.mkdtemp() by
    referencing the (then) unbound local 'dir'.
		
	
			
		
			
				
	
	
		
			64 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| '''
 | |
|    Tests for commands module
 | |
|    Nick Mathewson
 | |
| '''
 | |
| import unittest
 | |
| import os, tempfile, re
 | |
| 
 | |
| from test.test_support import TestSkipped, run_unittest
 | |
| from commands import *
 | |
| 
 | |
| # The module says:
 | |
| #   "NB This only works (and is only relevant) for UNIX."
 | |
| #
 | |
| # Actually, getoutput should work on any platform with an os.popen, but
 | |
| # I'll take the comment as given, and skip this suite.
 | |
| 
 | |
| if os.name != 'posix':
 | |
|     raise TestSkipped('Not posix; skipping test_commands')
 | |
| 
 | |
| 
 | |
| class CommandTests(unittest.TestCase):
 | |
| 
 | |
|     def test_getoutput(self):
 | |
|         self.assertEquals(getoutput('echo xyzzy'), 'xyzzy')
 | |
|         self.assertEquals(getstatusoutput('echo xyzzy'), (0, 'xyzzy'))
 | |
| 
 | |
|         # we use mkdtemp in the next line to create an empty directory
 | |
|         # under our exclusive control; from that, we can invent a pathname
 | |
|         # that we _know_ won't exist.  This is guaranteed to fail.
 | |
|         dir = None
 | |
|         try:
 | |
|             dir = tempfile.mkdtemp()
 | |
|             name = os.path.join(dir, "foo")
 | |
| 
 | |
|             status, output = getstatusoutput('cat ' + name)
 | |
|             self.assertNotEquals(status, 0)
 | |
|         finally:
 | |
|             if dir is not None:
 | |
|                 os.rmdir(dir)
 | |
| 
 | |
|     def test_getstatus(self):
 | |
|         # This pattern should match 'ls -ld /.' on any posix
 | |
|         # system, however perversely configured.  Even on systems
 | |
|         # (e.g., Cygwin) where user and group names can have spaces:
 | |
|         #     drwxr-xr-x   15 Administ Domain U     4096 Aug 12 12:50 /
 | |
|         #     drwxr-xr-x   15 Joe User My Group     4096 Aug 12 12:50 /
 | |
|         # Note that the first case above has a space in the group name
 | |
|         # while the second one has a space in both names.
 | |
|         pat = r'''d.........   # It is a directory.
 | |
|                   \+?          # It may have ACLs.
 | |
|                   \s+\d+       # It has some number of links.
 | |
|                   [^/]*        # Skip user, group, size, and date.
 | |
|                   /\.          # and end with the name of the file.
 | |
|                '''
 | |
| 
 | |
|         self.assert_(re.match(pat, getstatus("/."), re.VERBOSE))
 | |
| 
 | |
| 
 | |
| def test_main():
 | |
|     run_unittest(CommandTests)
 | |
| 
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     test_main()
 |