Close #14846: Handle a sys.path entry going away
This commit is contained in:
parent
db7920b978
commit
48fec05391
|
@ -1367,7 +1367,11 @@ class FileFinder:
|
|||
def _fill_cache(self):
|
||||
"""Fill the cache of potential modules and packages for this directory."""
|
||||
path = self.path
|
||||
contents = _os.listdir(path)
|
||||
try:
|
||||
contents = _os.listdir(path)
|
||||
except FileNotFoundError:
|
||||
# Directory has been removed since last import
|
||||
contents = []
|
||||
# We store two cached versions, to handle runtime changes of the
|
||||
# PYTHONCASEOK environment variable.
|
||||
if not sys.platform.startswith('win'):
|
||||
|
|
|
@ -35,13 +35,15 @@ class FinderTests(abc.FinderTests):
|
|||
|
||||
"""
|
||||
|
||||
def import_(self, root, module):
|
||||
def get_finder(self, root):
|
||||
loader_details = [(machinery.SourceFileLoader,
|
||||
machinery.SOURCE_SUFFIXES),
|
||||
(machinery.SourcelessFileLoader,
|
||||
machinery.BYTECODE_SUFFIXES)]
|
||||
finder = machinery.FileFinder(root, *loader_details)
|
||||
return finder.find_module(module)
|
||||
return machinery.FileFinder(root, *loader_details)
|
||||
|
||||
def import_(self, root, module):
|
||||
return self.get_finder(root).find_module(module)
|
||||
|
||||
def run_test(self, test, create=None, *, compile_=None, unlink=None):
|
||||
"""Test the finding of 'test' with the creation of modules listed in
|
||||
|
@ -137,6 +139,13 @@ class FinderTests(abc.FinderTests):
|
|||
finder.invalidate_caches()
|
||||
self.assertEqual(finder._path_mtime, -1)
|
||||
|
||||
# Regression test for http://bugs.python.org/issue14846
|
||||
def test_dir_removal_handling(self):
|
||||
mod = 'mod'
|
||||
with source_util.create_modules(mod) as mapping:
|
||||
finder = self.get_finder(mapping['.root'])
|
||||
self.assertIsNotNone(finder.find_module(mod))
|
||||
self.assertIsNone(finder.find_module(mod))
|
||||
|
||||
def test_main():
|
||||
from test.support import run_unittest
|
||||
|
|
|
@ -13,6 +13,9 @@ Core and Builtins
|
|||
- Issue #15604: Update uses of PyObject_IsTrue() to check for and handle
|
||||
errors correctly. Patch by Serhiy Storchaka.
|
||||
|
||||
- Issue #14846: importlib.FileFinder now handles the case where the
|
||||
directory being searched is removed after a previous import attempt
|
||||
|
||||
Library
|
||||
-------
|
||||
|
||||
|
|
1870
Python/importlib.h
1870
Python/importlib.h
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue