mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 03:44:55 +00:00 
			
		
		
		
	svn+ssh://pythondev@svn.python.org/python/trunk ........ r80030 | georg.brandl | 2010-04-13 08:43:54 +0200 (Di, 13 Apr 2010) | 1 line Get rid of multi-row cells. ........ r80067 | georg.brandl | 2010-04-14 10:53:38 +0200 (Mi, 14 Apr 2010) | 1 line #5341: typo. ........ r80069 | georg.brandl | 2010-04-14 15:50:31 +0200 (Mi, 14 Apr 2010) | 1 line Add an x-ref to where the O_ constants are documented and move the SEEK_ constants after lseek(). ........ r80080 | georg.brandl | 2010-04-14 21:16:38 +0200 (Mi, 14 Apr 2010) | 1 line #8399: add note about Windows and O_BINARY. ........ r80081 | georg.brandl | 2010-04-14 23:34:44 +0200 (Mi, 14 Apr 2010) | 1 line #5250: document __instancecheck__ and __subclasscheck__. I hope the part about the class/metaclass distinction is understandable. ........ r80084 | georg.brandl | 2010-04-14 23:46:45 +0200 (Mi, 14 Apr 2010) | 1 line Fix missing. ........ r80432 | georg.brandl | 2010-04-24 10:56:58 +0200 (Sa, 24 Apr 2010) | 1 line Markup fixes. ........ r80433 | georg.brandl | 2010-04-24 11:08:10 +0200 (Sa, 24 Apr 2010) | 1 line #7507: quote "!" in pipes.quote(); it is a special character for some shells. ........ r80465 | georg.brandl | 2010-04-25 12:29:17 +0200 (So, 25 Apr 2010) | 1 line Remove LaTeXy index entry syntax. ........ r80466 | georg.brandl | 2010-04-25 12:54:42 +0200 (So, 25 Apr 2010) | 1 line Patch from Tim Hatch: Better cross-referencing in socket and winreg docs. ........ r80467 | georg.brandl | 2010-04-25 12:55:16 +0200 (So, 25 Apr 2010) | 1 line Patch from Tim Hatch: Remove reference to winreg being the fabled high-level registry interface. ........ r80468 | georg.brandl | 2010-04-25 12:55:58 +0200 (So, 25 Apr 2010) | 1 line Patch from Tim Hatch: Minor spelling changes to _winreg docs. ........ r80469 | georg.brandl | 2010-04-25 12:56:41 +0200 (So, 25 Apr 2010) | 1 line Fix code example to have valid syntax so that it can be highlighted. ........ r80470 | georg.brandl | 2010-04-25 12:57:15 +0200 (So, 25 Apr 2010) | 1 line Patch from Tim Hatch: Make socket setblocking <-> settimeout examples symmetric. ........ r81059 | georg.brandl | 2010-05-10 23:02:51 +0200 (Mo, 10 Mai 2010) | 1 line #8642: fix wrong function name. ........ r81065 | georg.brandl | 2010-05-10 23:46:50 +0200 (Mo, 10 Mai 2010) | 1 line Fix reference direction. ........ r81066 | georg.brandl | 2010-05-10 23:50:57 +0200 (Mo, 10 Mai 2010) | 1 line Consolidate deprecation messages. ........ r81067 | georg.brandl | 2010-05-10 23:51:33 +0200 (Mo, 10 Mai 2010) | 1 line Fix typo. ........
		
			
				
	
	
		
			200 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			200 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
import pipes
 | 
						|
import os
 | 
						|
import string
 | 
						|
import unittest
 | 
						|
from test.support import TESTFN, run_unittest, unlink, reap_children
 | 
						|
 | 
						|
if os.name != 'posix':
 | 
						|
    raise unittest.SkipTest('pipes module only works on posix')
 | 
						|
 | 
						|
TESTFN2 = TESTFN + "2"
 | 
						|
 | 
						|
# tr a-z A-Z is not portable, so make the ranges explicit
 | 
						|
s_command = 'tr %s %s' % (string.ascii_lowercase, string.ascii_uppercase)
 | 
						|
 | 
						|
class SimplePipeTests(unittest.TestCase):
 | 
						|
    def tearDown(self):
 | 
						|
        for f in (TESTFN, TESTFN2):
 | 
						|
            unlink(f)
 | 
						|
 | 
						|
    def testSimplePipe1(self):
 | 
						|
        t = pipes.Template()
 | 
						|
        t.append(s_command, pipes.STDIN_STDOUT)
 | 
						|
        f = t.open(TESTFN, 'w')
 | 
						|
        f.write('hello world #1')
 | 
						|
        f.close()
 | 
						|
        self.assertEqual(open(TESTFN).read(), 'HELLO WORLD #1')
 | 
						|
 | 
						|
    def testSimplePipe2(self):
 | 
						|
        open(TESTFN, 'w').write('hello world #2')
 | 
						|
        t = pipes.Template()
 | 
						|
        t.append(s_command + ' < $IN > $OUT', pipes.FILEIN_FILEOUT)
 | 
						|
        t.copy(TESTFN, TESTFN2)
 | 
						|
        self.assertEqual(open(TESTFN2).read(), 'HELLO WORLD #2')
 | 
						|
 | 
						|
    def testSimplePipe3(self):
 | 
						|
        open(TESTFN, 'w').write('hello world #2')
 | 
						|
        t = pipes.Template()
 | 
						|
        t.append(s_command + ' < $IN', pipes.FILEIN_STDOUT)
 | 
						|
        f = t.open(TESTFN, 'r')
 | 
						|
        try:
 | 
						|
            self.assertEqual(f.read(), 'HELLO WORLD #2')
 | 
						|
        finally:
 | 
						|
            f.close()
 | 
						|
 | 
						|
    def testEmptyPipeline1(self):
 | 
						|
        # copy through empty pipe
 | 
						|
        d = 'empty pipeline test COPY'
 | 
						|
        open(TESTFN, 'w').write(d)
 | 
						|
        open(TESTFN2, 'w').write('')
 | 
						|
        t=pipes.Template()
 | 
						|
        t.copy(TESTFN, TESTFN2)
 | 
						|
        self.assertEqual(open(TESTFN2).read(), d)
 | 
						|
 | 
						|
    def testEmptyPipeline2(self):
 | 
						|
        # read through empty pipe
 | 
						|
        d = 'empty pipeline test READ'
 | 
						|
        open(TESTFN, 'w').write(d)
 | 
						|
        t=pipes.Template()
 | 
						|
        f = t.open(TESTFN, 'r')
 | 
						|
        try:
 | 
						|
            self.assertEqual(f.read(), d)
 | 
						|
        finally:
 | 
						|
            f.close()
 | 
						|
 | 
						|
    def testEmptyPipeline3(self):
 | 
						|
        # write through empty pipe
 | 
						|
        d = 'empty pipeline test WRITE'
 | 
						|
        t = pipes.Template()
 | 
						|
        t.open(TESTFN, 'w').write(d)
 | 
						|
        self.assertEqual(open(TESTFN).read(), d)
 | 
						|
 | 
						|
    def testQuoting(self):
 | 
						|
        safeunquoted = string.ascii_letters + string.digits + '@%_-+=:,./'
 | 
						|
        unsafe = '"`$\\!'
 | 
						|
 | 
						|
        self.assertEqual(pipes.quote(''), "''")
 | 
						|
        self.assertEqual(pipes.quote(safeunquoted), safeunquoted)
 | 
						|
        self.assertEqual(pipes.quote('test file name'), "'test file name'")
 | 
						|
        for u in unsafe:
 | 
						|
            self.assertEqual(pipes.quote('test%sname' % u),
 | 
						|
                              "'test%sname'" % u)
 | 
						|
        for u in unsafe:
 | 
						|
            self.assertEqual(pipes.quote("test%s'name'" % u),
 | 
						|
                             "'test%s'\"'\"'name'\"'\"''" % u)
 | 
						|
 | 
						|
    def testRepr(self):
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertEqual(repr(t), "<Template instance, steps=[]>")
 | 
						|
        t.append('tr a-z A-Z', pipes.STDIN_STDOUT)
 | 
						|
        self.assertEqual(repr(t),
 | 
						|
                    "<Template instance, steps=[('tr a-z A-Z', '--')]>")
 | 
						|
 | 
						|
    def testSetDebug(self):
 | 
						|
        t = pipes.Template()
 | 
						|
        t.debug(False)
 | 
						|
        self.assertEqual(t.debugging, False)
 | 
						|
        t.debug(True)
 | 
						|
        self.assertEqual(t.debugging, True)
 | 
						|
 | 
						|
    def testReadOpenSink(self):
 | 
						|
        # check calling open('r') on a pipe ending with
 | 
						|
        # a sink raises ValueError
 | 
						|
        t = pipes.Template()
 | 
						|
        t.append('boguscmd', pipes.SINK)
 | 
						|
        self.assertRaises(ValueError, t.open, 'bogusfile', 'r')
 | 
						|
 | 
						|
    def testWriteOpenSource(self):
 | 
						|
        # check calling open('w') on a pipe ending with
 | 
						|
        # a source raises ValueError
 | 
						|
        t = pipes.Template()
 | 
						|
        t.prepend('boguscmd', pipes.SOURCE)
 | 
						|
        self.assertRaises(ValueError, t.open, 'bogusfile', 'w')
 | 
						|
 | 
						|
    def testBadAppendOptions(self):
 | 
						|
        t = pipes.Template()
 | 
						|
 | 
						|
        # try a non-string command
 | 
						|
        self.assertRaises(TypeError, t.append, 7, pipes.STDIN_STDOUT)
 | 
						|
 | 
						|
        # try a type that isn't recognized
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd', 'xx')
 | 
						|
 | 
						|
        # shouldn't be able to append a source
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd', pipes.SOURCE)
 | 
						|
 | 
						|
        # check appending two sinks
 | 
						|
        t = pipes.Template()
 | 
						|
        t.append('boguscmd', pipes.SINK)
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd', pipes.SINK)
 | 
						|
 | 
						|
        # command needing file input but with no $IN
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd $OUT',
 | 
						|
                           pipes.FILEIN_FILEOUT)
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd',
 | 
						|
                           pipes.FILEIN_STDOUT)
 | 
						|
 | 
						|
        # command needing file output but with no $OUT
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd $IN',
 | 
						|
                           pipes.FILEIN_FILEOUT)
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.append, 'boguscmd',
 | 
						|
                           pipes.STDIN_FILEOUT)
 | 
						|
 | 
						|
 | 
						|
    def testBadPrependOptions(self):
 | 
						|
        t = pipes.Template()
 | 
						|
 | 
						|
        # try a non-string command
 | 
						|
        self.assertRaises(TypeError, t.prepend, 7, pipes.STDIN_STDOUT)
 | 
						|
 | 
						|
        # try a type that isn't recognized
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'tr a-z A-Z', 'xx')
 | 
						|
 | 
						|
        # shouldn't be able to prepend a sink
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'boguscmd', pipes.SINK)
 | 
						|
 | 
						|
        # check prepending two sources
 | 
						|
        t = pipes.Template()
 | 
						|
        t.prepend('boguscmd', pipes.SOURCE)
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'boguscmd', pipes.SOURCE)
 | 
						|
 | 
						|
        # command needing file input but with no $IN
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'boguscmd $OUT',
 | 
						|
                           pipes.FILEIN_FILEOUT)
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'boguscmd',
 | 
						|
                           pipes.FILEIN_STDOUT)
 | 
						|
 | 
						|
        # command needing file output but with no $OUT
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'boguscmd $IN',
 | 
						|
                           pipes.FILEIN_FILEOUT)
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.prepend, 'boguscmd',
 | 
						|
                           pipes.STDIN_FILEOUT)
 | 
						|
 | 
						|
    def testBadOpenMode(self):
 | 
						|
        t = pipes.Template()
 | 
						|
        self.assertRaises(ValueError, t.open, 'bogusfile', 'x')
 | 
						|
 | 
						|
    def testClone(self):
 | 
						|
        t = pipes.Template()
 | 
						|
        t.append('tr a-z A-Z', pipes.STDIN_STDOUT)
 | 
						|
 | 
						|
        u = t.clone()
 | 
						|
        self.assertNotEqual(id(t), id(u))
 | 
						|
        self.assertEqual(t.steps, u.steps)
 | 
						|
        self.assertNotEqual(id(t.steps), id(u.steps))
 | 
						|
        self.assertEqual(t.debugging, u.debugging)
 | 
						|
 | 
						|
def test_main():
 | 
						|
    run_unittest(SimplePipeTests)
 | 
						|
    reap_children()
 | 
						|
 | 
						|
if __name__ == "__main__":
 | 
						|
    test_main()
 |