summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Lib/compileall.py11
-rw-r--r--Lib/test/test_compileall.py13
2 files changed, 19 insertions, 5 deletions
diff --git a/Lib/compileall.py b/Lib/compileall.py
index be9e2ad05f..ea2ee7fbb6 100644
--- a/Lib/compileall.py
+++ b/Lib/compileall.py
@@ -91,13 +91,14 @@ def compile_file(fullname, ddir=None, force=0, rx=None, quiet=False,
else:
cfile = imp.cache_from_source(fullname)
cache_dir = os.path.dirname(cfile)
- try:
- os.mkdir(cache_dir)
- except OSError as error:
- if error.errno != errno.EEXIST:
- raise
head, tail = name[:-3], name[-3:]
if tail == '.py':
+ if not legacy:
+ try:
+ os.mkdir(cache_dir)
+ except OSError as error:
+ if error.errno != errno.EEXIST:
+ raise
if not force:
try:
mtime = int(os.stat(fullname).st_mtime)
diff --git a/Lib/test/test_compileall.py b/Lib/test/test_compileall.py
index fe26026bd7..4ad0061f43 100644
--- a/Lib/test/test_compileall.py
+++ b/Lib/test/test_compileall.py
@@ -75,6 +75,18 @@ class CompileallTests(unittest.TestCase):
os.unlink(self.bc_path)
os.unlink(self.bc_path2)
+ def test_no_pycache_in_non_package(self):
+ # Bug 8563 reported that __pycache__ directories got created by
+ # compile_file() for non-.py files.
+ data_dir = os.path.join(self.directory, 'data')
+ data_file = os.path.join(data_dir, 'file')
+ os.mkdir(data_dir)
+ # touch data/file
+ with open(data_file, 'w'):
+ pass
+ compileall.compile_file(data_file)
+ self.assertFalse(os.path.exists(os.path.join(data_dir, '__pycache__')))
+
class EncodingTest(unittest.TestCase):
"""Issue 6716: compileall should escape source code when printing errors
@@ -98,6 +110,7 @@ class EncodingTest(unittest.TestCase):
finally:
sys.stdout = orig_stdout
+
class CommandLineTests(unittest.TestCase):
"""Test some aspects of compileall's CLI."""