Fixed #28241 -- Allowed module_has_submodule()'s module_name arg to be a dotted path.
This commit is contained in:
parent
af69f14e7b
commit
f6bd00131e
|
@ -70,7 +70,14 @@ def module_has_submodule(package, module_name):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
full_module_name = package_name + '.' + module_name
|
full_module_name = package_name + '.' + module_name
|
||||||
|
try:
|
||||||
return importlib_find(full_module_name, package_path) is not None
|
return importlib_find(full_module_name, package_path) is not None
|
||||||
|
except (ImportError, AttributeError):
|
||||||
|
# When module_name is an invalid dotted path, Python raises ImportError
|
||||||
|
# (or ModuleNotFoundError in Python 3.6+). AttributeError may be raised
|
||||||
|
# if the penultimate part of the path is not a package.
|
||||||
|
# (http://bugs.python.org/issue30436)
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def module_dir(module):
|
def module_dir(module):
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
content = 'Grandchild Module'
|
|
@ -48,6 +48,18 @@ class DefaultLoader(unittest.TestCase):
|
||||||
with self.assertRaises(ImportError):
|
with self.assertRaises(ImportError):
|
||||||
import_module('utils_tests.test_no_submodule.anything')
|
import_module('utils_tests.test_no_submodule.anything')
|
||||||
|
|
||||||
|
def test_has_sumbodule_with_dotted_path(self):
|
||||||
|
"""Nested module existence can be tested."""
|
||||||
|
test_module = import_module('utils_tests.test_module')
|
||||||
|
# A grandchild that exists.
|
||||||
|
self.assertIs(module_has_submodule(test_module, 'child_module.grandchild_module'), True)
|
||||||
|
# A grandchild that doesn't exist.
|
||||||
|
self.assertIs(module_has_submodule(test_module, 'child_module.no_such_module'), False)
|
||||||
|
# A grandchild whose parent doesn't exist.
|
||||||
|
self.assertIs(module_has_submodule(test_module, 'no_such_module.grandchild_module'), False)
|
||||||
|
# A grandchild whose parent is not a package.
|
||||||
|
self.assertIs(module_has_submodule(test_module, 'good_module.no_such_module'), False)
|
||||||
|
|
||||||
|
|
||||||
class EggLoader(unittest.TestCase):
|
class EggLoader(unittest.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
|
|
Loading…
Reference in New Issue