mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 11:49:12 +00:00 
			
		
		
		
	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()
 |