summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorBarry Warsaw <barry@python.org>2014-12-01 22:10:10 (GMT)
committerBarry Warsaw <barry@python.org>2014-12-01 22:10:10 (GMT)
commit2a413853f15755060996ba20ab7cdeedb7caff22 (patch)
tree078df44e04e76f6c7861f813df2e9adc18ebea78 /Lib
parentb491e0521fd6e1a2e6f3e6354a2a296c7c8a2915 (diff)
downloadcpython-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.py4
-rw-r--r--Lib/test/test_py_compile.py16
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()