mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 05:31:20 +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 ........
		
			
				
	
	
		
			107 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """Tests for distutils.text_file."""
 | |
| import os
 | |
| import unittest
 | |
| from distutils.text_file import TextFile
 | |
| from distutils.tests import support
 | |
| from test.support import run_unittest
 | |
| 
 | |
| TEST_DATA = """# test file
 | |
| 
 | |
| line 3 \\
 | |
| # intervening comment
 | |
|   continues on next line
 | |
| """
 | |
| 
 | |
| class TextFileTestCase(support.TempdirManager, unittest.TestCase):
 | |
| 
 | |
|     def test_class(self):
 | |
|         # old tests moved from text_file.__main__
 | |
|         # so they are really called by the buildbots
 | |
| 
 | |
|         # result 1: no fancy options
 | |
|         result1 = ['# test file\n', '\n', 'line 3 \\\n',
 | |
|                    '# intervening comment\n',
 | |
|                    '  continues on next line\n']
 | |
| 
 | |
|         # result 2: just strip comments
 | |
|         result2 = ["\n",
 | |
|                    "line 3 \\\n",
 | |
|                    "  continues on next line\n"]
 | |
| 
 | |
|         # result 3: just strip blank lines
 | |
|         result3 = ["# test file\n",
 | |
|                    "line 3 \\\n",
 | |
|                    "# intervening comment\n",
 | |
|                    "  continues on next line\n"]
 | |
| 
 | |
|         # result 4: default, strip comments, blank lines,
 | |
|         # and trailing whitespace
 | |
|         result4 = ["line 3 \\",
 | |
|                    "  continues on next line"]
 | |
| 
 | |
|         # result 5: strip comments and blanks, plus join lines (but don't
 | |
|         # "collapse" joined lines
 | |
|         result5 = ["line 3   continues on next line"]
 | |
| 
 | |
|         # result 6: strip comments and blanks, plus join lines (and
 | |
|         # "collapse" joined lines
 | |
|         result6 = ["line 3 continues on next line"]
 | |
| 
 | |
|         def test_input(count, description, file, expected_result):
 | |
|             result = file.readlines()
 | |
|             self.assertEqual(result, expected_result)
 | |
| 
 | |
|         tmpdir = self.mkdtemp()
 | |
|         filename = os.path.join(tmpdir, "test.txt")
 | |
|         out_file = open(filename, "w")
 | |
|         try:
 | |
|             out_file.write(TEST_DATA)
 | |
|         finally:
 | |
|             out_file.close()
 | |
| 
 | |
|         in_file = TextFile(filename, strip_comments=0, skip_blanks=0,
 | |
|                            lstrip_ws=0, rstrip_ws=0)
 | |
|         try:
 | |
|             test_input(1, "no processing", in_file, result1)
 | |
|         finally:
 | |
|             in_file.close()
 | |
| 
 | |
|         in_file = TextFile(filename, strip_comments=1, skip_blanks=0,
 | |
|                            lstrip_ws=0, rstrip_ws=0)
 | |
|         try:
 | |
|             test_input(2, "strip comments", in_file, result2)
 | |
|         finally:
 | |
|             in_file.close()
 | |
| 
 | |
|         in_file = TextFile(filename, strip_comments=0, skip_blanks=1,
 | |
|                            lstrip_ws=0, rstrip_ws=0)
 | |
|         try:
 | |
|             test_input(3, "strip blanks", in_file, result3)
 | |
|         finally:
 | |
|             in_file.close()
 | |
| 
 | |
|         in_file = TextFile(filename)
 | |
|         try:
 | |
|             test_input(4, "default processing", in_file, result4)
 | |
|         finally:
 | |
|             in_file.close()
 | |
| 
 | |
|         in_file = TextFile(filename, strip_comments=1, skip_blanks=1,
 | |
|                            join_lines=1, rstrip_ws=1)
 | |
|         try:
 | |
|             test_input(5, "join lines without collapsing", in_file, result5)
 | |
|         finally:
 | |
|             in_file.close()
 | |
| 
 | |
|         in_file = TextFile(filename, strip_comments=1, skip_blanks=1,
 | |
|                            join_lines=1, rstrip_ws=1, collapse_join=1)
 | |
|         try:
 | |
|             test_input(6, "join lines with collapsing", in_file, result6)
 | |
|         finally:
 | |
|             in_file.close()
 | |
| 
 | |
| def test_suite():
 | |
|     return unittest.makeSuite(TextFileTestCase)
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     run_unittest(test_suite())
 |