diff options
author | Victor Stinner <victor.stinner@haypocalc.com> | 2011-07-03 23:45:39 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@haypocalc.com> | 2011-07-03 23:45:39 (GMT) |
commit | 6c471029821677e893a203a0127777735ff526c7 (patch) | |
tree | 2df9ccc41397a020f74b3677d49574d6dbec070d /Lib/test | |
parent | bbdc08ea6e5d3f2d9058991a65b6011dfbb8d233 (diff) | |
download | cpython-6c471029821677e893a203a0127777735ff526c7.zip cpython-6c471029821677e893a203a0127777735ff526c7.tar.gz cpython-6c471029821677e893a203a0127777735ff526c7.tar.bz2 |
Issue #12451: runpy: run_path() now opens the Python script in binary mode,
instead of text mode using the locale encoding, to support other encodings than
UTF-8 (scripts using the coding cookie).
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_runpy.py | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/Lib/test/test_runpy.py b/Lib/test/test_runpy.py index ad3ab39..7ffb6af 100644 --- a/Lib/test/test_runpy.py +++ b/Lib/test/test_runpy.py @@ -405,6 +405,16 @@ argv0 = sys.argv[0] msg = "recursion depth exceeded" self.assertRaisesRegex(RuntimeError, msg, run_path, zip_name) + def test_encoding(self): + with temp_dir() as script_dir: + filename = os.path.join(script_dir, 'script.py') + with open(filename, 'w', encoding='latin1') as f: + f.write(""" +#coding:latin1 +"non-ASCII: h\xe9" +""") + result = run_path(filename) + self.assertEqual(result['__doc__'], "non-ASCII: h\xe9") def test_main(): |