mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 21:51:50 +00:00 
			
		
		
		
	 e549ead826
			
		
	
	
		e549ead826
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r70554 | benjamin.peterson | 2009-03-23 16:25:15 -0500 (Mon, 23 Mar 2009) | 1 line complain when there's no last exception ........ r70588 | benjamin.peterson | 2009-03-24 17:56:32 -0500 (Tue, 24 Mar 2009) | 1 line fix newline issue in test summary ........ r70589 | benjamin.peterson | 2009-03-24 18:07:07 -0500 (Tue, 24 Mar 2009) | 1 line another style nit ........ r70598 | benjamin.peterson | 2009-03-25 16:24:04 -0500 (Wed, 25 Mar 2009) | 1 line add shorthands for expected failures and unexpected success ........ r70605 | benjamin.peterson | 2009-03-26 11:32:23 -0500 (Thu, 26 Mar 2009) | 1 line remove uneeded function ........ r70611 | benjamin.peterson | 2009-03-26 13:35:37 -0500 (Thu, 26 Mar 2009) | 1 line add much better tests for python version information parsing ........ r70612 | benjamin.peterson | 2009-03-26 13:55:48 -0500 (Thu, 26 Mar 2009) | 1 line more and more implementations now support sys.subversion ........ r70613 | benjamin.peterson | 2009-03-26 13:58:30 -0500 (Thu, 26 Mar 2009) | 1 line roll old test in with new one ........ r70614 | benjamin.peterson | 2009-03-26 14:09:21 -0500 (Thu, 26 Mar 2009) | 1 line add support for PyPy ........ r70615 | benjamin.peterson | 2009-03-26 14:58:18 -0500 (Thu, 26 Mar 2009) | 5 lines add some useful utilities for skipping tests with unittest's new skipping ability most significantly apply a modified portion of the patch from #4242 with patches for skipping implementation details ........ r70616 | benjamin.peterson | 2009-03-26 15:05:50 -0500 (Thu, 26 Mar 2009) | 1 line rename TestCase.skip() to skipTest() because it causes annoying problems with trial #5571 ........ r70617 | benjamin.peterson | 2009-03-26 15:17:27 -0500 (Thu, 26 Mar 2009) | 1 line apply the second part of #4242's patch; classify all the implementation details in test_descr ........ r70618 | benjamin.peterson | 2009-03-26 15:48:25 -0500 (Thu, 26 Mar 2009) | 1 line remove test_support.TestSkipped and just use unittest.SkipTest ........ r70619 | benjamin.peterson | 2009-03-26 15:49:40 -0500 (Thu, 26 Mar 2009) | 1 line fix naming ........ r70620 | benjamin.peterson | 2009-03-26 16:10:30 -0500 (Thu, 26 Mar 2009) | 1 line fix incorrect auto-translation of TestSkipped -> unittest.SkipTest ........ r70621 | benjamin.peterson | 2009-03-26 16:11:16 -0500 (Thu, 26 Mar 2009) | 1 line must pass argument to get expected behavior ;) ........ r70623 | benjamin.peterson | 2009-03-26 16:30:10 -0500 (Thu, 26 Mar 2009) | 1 line add missing import ........ r70624 | benjamin.peterson | 2009-03-26 16:30:54 -0500 (Thu, 26 Mar 2009) | 1 line ** is required here ........ r70626 | benjamin.peterson | 2009-03-26 16:40:29 -0500 (Thu, 26 Mar 2009) | 1 line update email tests to use SkipTest ........ r70627 | benjamin.peterson | 2009-03-26 16:44:43 -0500 (Thu, 26 Mar 2009) | 1 line fix another name ........
		
			
				
	
	
		
			190 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			190 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import pipes
 | |
| import os
 | |
| import string
 | |
| import unittest
 | |
| from test.support import TESTFN, run_unittest, unlink
 | |
| 
 | |
| 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)
 | |
|         self.assertEqual(t.open(TESTFN, 'r').read(), 'HELLO WORLD #2')
 | |
| 
 | |
|     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()
 | |
|         self.assertEqual(t.open(TESTFN, 'r').read(), d)
 | |
| 
 | |
|     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(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)
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     test_main()
 |