Commit 04b5684d authored by Barry Warsaw's avatar Barry Warsaw

Repair test failure. Bug 8727.

parent 2b80fa69
......@@ -494,8 +494,16 @@ class _PyPycFileLoader(PyPycLoader, _PyFileLoader):
if ext_type == imp.PY_COMPILED:
# We don't really care what the extension on self._base_path is,
# as long as it has exactly one dot.
bytecode_path = imp.cache_from_source(self._base_path + '.py')
return (bytecode_path if _path_exists(bytecode_path) else None)
source_path = self._base_path + '.py'
pycache_path = imp.cache_from_source(source_path)
legacy_path = self._base_path + '.pyc'
# The rule is: if the source file exists, then Python always uses
# the __pycache__/foo.<tag>.pyc file. If the source file does not
# exist, then Python uses the legacy path.
pyc_path = (pycache_path
if _path_exists(source_path)
else legacy_path)
return (pyc_path if _path_exists(pyc_path) else None)
return super()._find_path(ext_type)
@_check_name
......
......@@ -10,6 +10,8 @@ import stat
import sys
import unittest
from test.support import make_legacy_pyc
class SimpleTest(unittest.TestCase):
......@@ -136,6 +138,7 @@ class BadBytecodeTest(unittest.TestCase):
file.write(new_bc)
if del_source:
os.unlink(mapping[name])
make_legacy_pyc(mapping[name])
return bytecode_path
@source_util.writes_bytecode_files
......
......@@ -142,7 +142,6 @@ class ImportTests(unittest.TestCase):
self.assertIs(orig_path, new_os.path)
self.assertIsNot(orig_getenv, new_os.getenv)
@unittest.expectedFailure # Issue 8727 is tracking the fix.
def test_module_with_large_stack(self, module='longlist'):
# Regression test for http://bugs.python.org/issue561858.
filename = module + '.py'
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment