Commit 658af313 authored by Eric Snow's avatar Eric Snow

Issue #21200: Return None from pkgutil.get_loader() when __spec__ is missing.

parent bddecc38
......@@ -461,6 +461,8 @@ def get_loader(module_or_name):
loader = getattr(module, '__loader__', None)
if loader is not None:
return loader
if getattr(module, '__spec__', None) is None:
return None
fullname = module.__name__
else:
fullname = module_or_name
......
from test.support import run_unittest, unload, check_warnings
from test.support import run_unittest, unload, check_warnings, CleanImport
import unittest
import sys
import importlib
......@@ -345,6 +345,23 @@ class ImportlibMigrationTests(unittest.TestCase):
finally:
__loader__ = this_loader
def test_get_loader_handles_missing_spec_attribute(self):
name = 'spam'
mod = type(sys)(name)
del mod.__spec__
with CleanImport(name):
sys.modules[name] = mod
loader = pkgutil.get_loader(name)
self.assertIsNone(loader)
def test_get_loader_handles_spec_attribute_none(self):
name = 'spam'
mod = type(sys)(name)
mod.__spec__ = None
with CleanImport(name):
sys.modules[name] = mod
loader = pkgutil.get_loader(name)
self.assertIsNone(loader)
def test_find_loader_avoids_emulation(self):
with check_warnings() as w:
......
......@@ -86,6 +86,8 @@ Library
:func:`tempfile.NamedTemporaryFile`, close the file descriptor if
:func:`io.open` fails
- Issue #21200: Return None from pkgutil.get_loader() when __spec__ is missing.
- Issue #21013: Enhance ssl.create_default_context() when used for server side
sockets to provide better security by default.
......
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