mirror of
https://github.com/python/cpython.git
synced 2025-11-25 21:11:09 +00:00
Merge testing ABCs for importlib into importlib.test.abc.
This commit is contained in:
parent
b18b936e79
commit
f254a75176
6 changed files with 45 additions and 47 deletions
98
Lib/importlib/test/abc.py
Normal file
98
Lib/importlib/test/abc.py
Normal file
|
|
@ -0,0 +1,98 @@
|
|||
import abc
|
||||
import unittest
|
||||
|
||||
|
||||
class FinderTests(unittest.TestCase, metaclass=abc.ABCMeta):
|
||||
|
||||
"""Basic tests for a finder to pass."""
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_module(self):
|
||||
# Test importing a top-level module.
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_package(self):
|
||||
# Test importing a package.
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_module_in_package(self):
|
||||
# Test importing a module contained within a package.
|
||||
# A value for 'path' should be used if for a meta_path finder.
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_package_in_package(self):
|
||||
# Test importing a subpackage.
|
||||
# A value for 'path' should be used if for a meta_path finder.
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_package_over_module(self):
|
||||
# Test that packages are chosen over modules.
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_failure(self):
|
||||
# Test trying to find a module that cannot be handled.
|
||||
pass
|
||||
|
||||
|
||||
class LoaderTests(unittest.TestCase, metaclass=abc.ABCMeta):
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_module(self):
|
||||
"""A module should load without issue.
|
||||
|
||||
After the loader returns the module should be in sys.modules.
|
||||
|
||||
Attributes to verify:
|
||||
|
||||
* __file__
|
||||
* __loader__
|
||||
* __name__
|
||||
* No __path__
|
||||
|
||||
"""
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_package(self):
|
||||
"""Loading a package should work.
|
||||
|
||||
After the loader returns the module should be in sys.modules.
|
||||
|
||||
Attributes to verify:
|
||||
|
||||
* __file__
|
||||
* __loader__
|
||||
* __name__
|
||||
* __path__
|
||||
|
||||
"""
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_lacking_parent(self):
|
||||
"""A loader should not be dependent on it's parent package being
|
||||
imported."""
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_module_reuse(self):
|
||||
"""If a module is already in sys.modules, it should be reused."""
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_state_after_failure(self):
|
||||
"""If a module is already in sys.modules and a reload fails
|
||||
(e.g. a SyntaxError), the module should be in the state it was before
|
||||
the reload began."""
|
||||
pass
|
||||
|
||||
@abc.abstractmethod
|
||||
def test_unloadable(self):
|
||||
"""Test ImportError is raised when the loader is asked to load a module
|
||||
it can't."""
|
||||
pass
|
||||
Loading…
Add table
Add a link
Reference in a new issue