mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 23:21:29 +00:00 
			
		
		
		
	module again. Also took the opportunity to stop accidentally exporting _imp.extension_suffixes() as public.
		
			
				
	
	
		
			79 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from importlib import machinery
 | 
						|
from . import util as ext_util
 | 
						|
from .. import abc
 | 
						|
from .. import util
 | 
						|
 | 
						|
import os.path
 | 
						|
import sys
 | 
						|
import unittest
 | 
						|
 | 
						|
 | 
						|
class LoaderTests(abc.LoaderTests):
 | 
						|
 | 
						|
    """Test load_module() for extension modules."""
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        self.loader = machinery.ExtensionFileLoader(ext_util.NAME,
 | 
						|
                                                     ext_util.FILEPATH)
 | 
						|
 | 
						|
    def load_module(self, fullname):
 | 
						|
        return self.loader.load_module(fullname)
 | 
						|
 | 
						|
    def test_load_module_API(self):
 | 
						|
        # Test the default argument for load_module().
 | 
						|
        self.loader.load_module()
 | 
						|
        self.loader.load_module(None)
 | 
						|
        with self.assertRaises(ImportError):
 | 
						|
            self.load_module('XXX')
 | 
						|
 | 
						|
 | 
						|
    def test_module(self):
 | 
						|
        with util.uncache(ext_util.NAME):
 | 
						|
            module = self.load_module(ext_util.NAME)
 | 
						|
            for attr, value in [('__name__', ext_util.NAME),
 | 
						|
                                ('__file__', ext_util.FILEPATH),
 | 
						|
                                ('__package__', '')]:
 | 
						|
                self.assertEqual(getattr(module, attr), value)
 | 
						|
            self.assertIn(ext_util.NAME, sys.modules)
 | 
						|
            self.assertIsInstance(module.__loader__,
 | 
						|
                                  machinery.ExtensionFileLoader)
 | 
						|
 | 
						|
    def test_package(self):
 | 
						|
        # No extension module as __init__ available for testing.
 | 
						|
        pass
 | 
						|
 | 
						|
    def test_lacking_parent(self):
 | 
						|
        # No extension module in a package available for testing.
 | 
						|
        pass
 | 
						|
 | 
						|
    def test_module_reuse(self):
 | 
						|
        with util.uncache(ext_util.NAME):
 | 
						|
            module1 = self.load_module(ext_util.NAME)
 | 
						|
            module2 = self.load_module(ext_util.NAME)
 | 
						|
            self.assertIs(module1, module2)
 | 
						|
 | 
						|
    def test_state_after_failure(self):
 | 
						|
        # No easy way to trigger a failure after a successful import.
 | 
						|
        pass
 | 
						|
 | 
						|
    def test_unloadable(self):
 | 
						|
        name = 'asdfjkl;'
 | 
						|
        with self.assertRaises(ImportError) as cm:
 | 
						|
            self.load_module(name)
 | 
						|
        self.assertEqual(cm.exception.name, name)
 | 
						|
 | 
						|
    def test_is_package(self):
 | 
						|
        self.assertFalse(self.loader.is_package(ext_util.NAME))
 | 
						|
        for suffix in machinery.EXTENSION_SUFFIXES:
 | 
						|
            path = os.path.join('some', 'path', 'pkg', '__init__' + suffix)
 | 
						|
            loader = machinery.ExtensionFileLoader('pkg', path)
 | 
						|
            self.assertTrue(loader.is_package('pkg'))
 | 
						|
 | 
						|
 | 
						|
def test_main():
 | 
						|
    from test.support import run_unittest
 | 
						|
    run_unittest(LoaderTests)
 | 
						|
 | 
						|
 | 
						|
if __name__ == '__main__':
 | 
						|
    test_main()
 |