diff options
author | Barry Warsaw <barry@python.org> | 2014-12-01 22:10:10 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2014-12-01 22:10:10 (GMT) |
commit | 2a413853f15755060996ba20ab7cdeedb7caff22 (patch) | |
tree | 078df44e04e76f6c7861f813df2e9adc18ebea78 /Lib | |
parent | b491e0521fd6e1a2e6f3e6354a2a296c7c8a2915 (diff) | |
download | cpython-2a413853f15755060996ba20ab7cdeedb7caff22.zip cpython-2a413853f15755060996ba20ab7cdeedb7caff22.tar.gz cpython-2a413853f15755060996ba20ab7cdeedb7caff22.tar.bz2 |
- Issue #22966: Fix __pycache__ pyc file name clobber when pyc_compile is
asked to compile a source file containing multiple dots in the source file
name.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/importlib/_bootstrap.py | 4 | ||||
-rw-r--r-- | Lib/test/test_py_compile.py | 16 |
2 files changed, 18 insertions, 2 deletions
diff --git a/Lib/importlib/_bootstrap.py b/Lib/importlib/_bootstrap.py index b8836c1..5b91c05 100644 --- a/Lib/importlib/_bootstrap.py +++ b/Lib/importlib/_bootstrap.py @@ -453,11 +453,11 @@ def cache_from_source(path, debug_override=None): else: suffixes = OPTIMIZED_BYTECODE_SUFFIXES head, tail = _path_split(path) - base_filename, sep, _ = tail.partition('.') + base, sep, rest = tail.rpartition('.') tag = sys.implementation.cache_tag if tag is None: raise NotImplementedError('sys.implementation.cache_tag is None') - filename = ''.join([base_filename, sep, tag, suffixes[0]]) + filename = ''.join([(base if base else rest), sep, tag, suffixes[0]]) return _path_join(head, _PYCACHE, filename) diff --git a/Lib/test/test_py_compile.py b/Lib/test/test_py_compile.py index 138f173..148ab80 100644 --- a/Lib/test/test_py_compile.py +++ b/Lib/test/test_py_compile.py @@ -99,5 +99,21 @@ class PyCompileTests(unittest.TestCase): self.assertFalse(os.path.exists( importlib.util.cache_from_source(bad_coding))) + def test_double_dot_no_clobber(self): + # http://bugs.python.org/issue22966 + # py_compile foo.bar.py -> __pycache__/foo.cpython-34.pyc + weird_path = os.path.join(self.directory, 'foo.bar.py') + cache_path = importlib.util.cache_from_source(weird_path) + pyc_path = weird_path + 'c' + self.assertEqual( + '/'.join(cache_path.split('/')[-2:]), + '__pycache__/foo.bar.cpython-34.pyc') + with open(weird_path, 'w') as file: + file.write('x = 123\n') + py_compile.compile(weird_path) + self.assertTrue(os.path.exists(cache_path)) + self.assertFalse(os.path.exists(pyc_path)) + + if __name__ == "__main__": unittest.main() |