[Python-checkins] r80424 - python/branches/py3k/Lib/test/test_subprocess.py

victor.stinner python-checkins at python.org
Sat Apr 24 00:55:40 CEST 2010


Author: victor.stinner
Date: Sat Apr 24 00:55:39 2010
New Revision: 80424

Log:
Fix test_undecodable_env of test_subproces for non-ASCII directory

This test was introduced by r80421 (issue #8391).

The fix: copy the environment variables instead of starting Python in an empty
environement. In an empty environment, the locale is C and Python uses ASCII
for the default file system encoding. The non-ASCII directory will be encoded
using surrogates, but Python3 is unable to load a module or package with a
filename using surrogates.

See issue #8242 for more information about running Python3 with a non-ascii
directory in an empty environement.


Modified:
   python/branches/py3k/Lib/test/test_subprocess.py

Modified: python/branches/py3k/Lib/test/test_subprocess.py
==============================================================================
--- python/branches/py3k/Lib/test/test_subprocess.py	(original)
+++ python/branches/py3k/Lib/test/test_subprocess.py	Sat Apr 24 00:55:39 2010
@@ -807,9 +807,11 @@
 
             # test str with surrogates
             script = "import os; print(repr(os.getenv(%s)))" % repr(key)
+            env = os.environ.copy()
+            env[key] = value
             stdout = subprocess.check_output(
                 [sys.executable, "-c", script],
-                env={key: value})
+                env=env)
             stdout = stdout.rstrip(b'\n\r')
             self.assertEquals(stdout, value_repr)
 
@@ -817,9 +819,11 @@
             key = key.encode("ascii", "surrogateescape")
             value = value.encode("ascii", "surrogateescape")
             script = "import os; print(repr(os.getenv(%s)))" % repr(key)
+            env = os.environ.copy()
+            env[key] = value
             stdout = subprocess.check_output(
                 [sys.executable, "-c", script],
-                env={key: value})
+                env=env)
             stdout = stdout.rstrip(b'\n\r')
             self.assertEquals(stdout, value_repr)
 


More information about the Python-checkins mailing list