mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 02:43:41 +00:00 
			
		
		
		
	Workaround issue #8611 in test_undecodable_code() of test_sys
Write test.support.workaroundIssue8611() function so it will be easier to remove this workaround from all tests.
This commit is contained in:
		
							parent
							
								
									1b6372a1d1
								
							
						
					
					
						commit
						c44abb127b
					
				
					 3 changed files with 36 additions and 31 deletions
				
			
		|  | @ -1277,3 +1277,11 @@ def strip_python_stderr(stderr): | |||
|     """ | ||||
|     stderr = re.sub(br"\[\d+ refs\]\r?\n?$", b"", stderr).strip() | ||||
|     return stderr | ||||
| 
 | ||||
| def workaroundIssue8611(): | ||||
|     try: | ||||
|         sys.executable.encode('ascii') | ||||
|     except UnicodeEncodeError: | ||||
|         raise unittest.SkipTest( | ||||
|             "Issue #8611: Python doesn't support ascii locale encoding " | ||||
|             "with an non-ascii path") | ||||
|  |  | |||
|  | @ -1175,13 +1175,10 @@ def check(encoding, bytesfn, unicodefn): | |||
|             self.assertEqual(decoded, repr(unicodefn)) | ||||
| 
 | ||||
|         check('utf-8', b'\xc3\xa9\x80', '\xe9\udc80') | ||||
|         try: | ||||
|             sys.executable.encode("ascii") | ||||
|         except UnicodeEncodeError: | ||||
|             # Python doesn't start with ASCII locale if its path is not ASCII, | ||||
|             # see issue #8611 | ||||
|             pass | ||||
|         else: | ||||
| 
 | ||||
|         # Raise SkipTest() if sys.executable is not encodable to ascii | ||||
|         support.workaroundIssue8611() | ||||
| 
 | ||||
|         check('ascii', b'abc\xff', 'abc\udcff') | ||||
|         check('iso-8859-15', b'\xef\xa4', '\xef\u20ac') | ||||
| 
 | ||||
|  |  | |||
|  | @ -496,11 +496,16 @@ def __hash__(self): | |||
|         self.assertRaises(TypeError, sys.intern, S("abc")) | ||||
| 
 | ||||
|     def test_undecodable_code(self): | ||||
|         non_decodable = b"\xff" | ||||
|         # Raise SkipTest() if sys.executable is not encodable to ascii | ||||
|         test.support.workaroundIssue8611() | ||||
| 
 | ||||
|         undecodable = b"\xff" | ||||
|         env = os.environ.copy() | ||||
|         env['LANG'] = 'C' | ||||
|         code = b'import locale; ' | ||||
|         code += b'print(ascii("' + non_decodable + b'"), locale.getpreferredencoding())' | ||||
|         code = ( | ||||
|             b'import locale; ' | ||||
|             b'print(ascii("' + undecodable + b'"), ' | ||||
|                 b'locale.getpreferredencoding())') | ||||
|         p = subprocess.Popen( | ||||
|             [sys.executable, "-c", code], | ||||
|             stdout=subprocess.PIPE, stderr=subprocess.STDOUT, | ||||
|  | @ -587,13 +592,9 @@ def get_fsencoding(env): | |||
|                 env=env) | ||||
|             return output.rstrip().decode('ascii') | ||||
| 
 | ||||
|         try: | ||||
|             sys.executable.encode('ascii') | ||||
|         except UnicodeEncodeError: | ||||
|             # Python doesn't start with ASCII locale if its path is not ASCII, | ||||
|             # see issue #8611 | ||||
|             pass | ||||
|         else: | ||||
|         # Raise SkipTest() if sys.executable is not encodable to ascii | ||||
|         test.support.workaroundIssue8611() | ||||
| 
 | ||||
|         # Even in C locale | ||||
|         env = os.environ.copy() | ||||
|         env['LANG'] = 'C' | ||||
|  | @ -609,7 +610,6 @@ def get_fsencoding(env): | |||
|             env['PYTHONFSENCODING'] = encoding | ||||
|             self.check_fsencoding(get_fsencoding(env), encoding) | ||||
| 
 | ||||
| 
 | ||||
|     def test_setfilesystemencoding(self): | ||||
|         old = sys.getfilesystemencoding() | ||||
|         try: | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Victor Stinner
						Victor Stinner