summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2017-10-08 09:51:55 (GMT)
committerGitHub <noreply@github.com>2017-10-08 09:51:55 (GMT)
commit6f059ab80a351a7dd85cc57c5ca240f817a79c5d (patch)
treeca107824fb2992f89ea5764763d2a40fd161c89d /Lib/test
parentd13a4e50679c0861971cfae2bb226f35b8bf5142 (diff)
downloadcpython-6f059ab80a351a7dd85cc57c5ca240f817a79c5d.zip
cpython-6f059ab80a351a7dd85cc57c5ca240f817a79c5d.tar.gz
cpython-6f059ab80a351a7dd85cc57c5ca240f817a79c5d.tar.bz2
[3.6] bpo-31642: Restore blocking "from" import by setting None in sys.modules. (GH-3834). (#3923)
(cherry picked from commit f07e2b64df6304a36fb5e29397d3c77a7ba17704)
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_importlib/import_/test_api.py14
1 files changed, 14 insertions, 0 deletions
diff --git a/Lib/test/test_importlib/import_/test_api.py b/Lib/test/test_importlib/import_/test_api.py
index a7bf274..0cd9de4 100644
--- a/Lib/test/test_importlib/import_/test_api.py
+++ b/Lib/test/test_importlib/import_/test_api.py
@@ -82,6 +82,20 @@ class APITest:
self.__import__(PKG_NAME,
fromlist=[SUBMOD_NAME.rpartition('.')[-1]])
+ def test_blocked_fromlist(self):
+ # If fromlist entry is None, let a ModuleNotFoundError propagate.
+ # issue31642
+ mod = types.ModuleType(PKG_NAME)
+ mod.__path__ = []
+ with util.import_state(meta_path=[self.bad_finder_loader]):
+ with util.uncache(PKG_NAME, SUBMOD_NAME):
+ sys.modules[PKG_NAME] = mod
+ sys.modules[SUBMOD_NAME] = None
+ with self.assertRaises(ModuleNotFoundError) as cm:
+ self.__import__(PKG_NAME,
+ fromlist=[SUBMOD_NAME.rpartition('.')[-1]])
+ self.assertEqual(cm.exception.name, SUBMOD_NAME)
+
class OldAPITests(APITest):
bad_finder_loader = BadLoaderFinder