Source

gsoc_import_engine / Lib / importlib / test / engine / test_fromlist.py

Full commit
"""Test that the semantics relating to the 'fromlist' argument are correct."""
from .. import util
from . import util as engine_util
import unittest

class ReturnValue(engine_util.EngineTests):

    """The use of fromlist influences what import returns.

    If direct ``import ...`` statement is used, the root module or package is
    returned [import return]. But if fromlist is set, then the specified module
    is actually returned (whether it is a relative import or not)
    [from return].

    """

    def test_return_from_import(self):
        # [import return]
        with util.mock_modules('pkg.__init__', 'pkg.module') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('pkg.module')
            self.assertEqual(module.__name__, 'pkg')

    def test_return_from_from_import(self):
        # [from return]
        with util.mock_modules('pkg.__init__', 'pkg.module') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('pkg.module', fromlist=['attr'])
            self.assertEqual(module.__name__, 'pkg.module')


class HandlingFromlist(engine_util.EngineTests):

    """Using fromlist triggers different actions based on what is being asked
    of it.

    If fromlist specifies an object on a module, nothing special happens
    [object case]. This is even true if the object does not exist [bad object].

    If a package is being imported, then what is listed in fromlist may be
    treated as a module to be imported [module]. But once again, even if
    something in fromlist does not exist as a module, no error is thrown
    [no module]. And this extends to what is contained in __all__ when '*' is
    imported [using *]. And '*' does not need to be the only name in the
    fromlist [using * with others].

    """

    def test_object(self):
        # [object case]
        with util.mock_modules('module') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('module', fromlist=['attr'])
            self.assertEqual(module.__name__, 'module')

    def test_unexistent_object(self):
        # [bad object]
        with util.mock_modules('module') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('module', fromlist=['non_existent'])
            self.assertEqual(module.__name__, 'module')
            self.assertTrue(not hasattr(module, 'non_existent'))

    def test_module_from_package(self):
        # [module]
        with util.mock_modules('pkg.__init__', 'pkg.module') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('pkg', fromlist=['module'])
            self.assertEqual(module.__name__, 'pkg')
            self.assertTrue(hasattr(module, 'module'))
            self.assertEqual(module.module.__name__, 'pkg.module')

    def test_no_module_from_package(self):
        # [no module]
        with util.mock_modules('pkg.__init__') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('pkg', fromlist='non_existent')
            self.assertEqual(module.__name__, 'pkg')
            self.assertTrue(not hasattr(module, 'non_existent'))

    def test_empty_string(self):
        with util.mock_modules('pkg.__init__', 'pkg.mod') as importer:
            self.engine.meta_path=[importer]
            module = self.engine.__import__('pkg.mod', fromlist=[''])
            self.assertEqual(module.__name__, 'pkg.mod')

    def basic_star_test(self, fromlist=['*']):
        # [using *]
        with util.mock_modules('pkg.__init__', 'pkg.module') as mock:
            self.engine.meta_path=[mock]
            mock['pkg'].__all__ = ['module']
            module = self.engine.__import__('pkg', fromlist=fromlist)
            self.assertEqual(module.__name__, 'pkg')
            self.assertTrue(hasattr(module, 'module'))
            self.assertEqual(module.module.__name__, 'pkg.module')

    def test_using_star(self):
        # [using *]
        self.basic_star_test()

    def test_fromlist_as_tuple(self):
        self.basic_star_test(('*',))

    def test_star_with_others(self):
        # [using * with others]
        context = util.mock_modules('pkg.__init__', 'pkg.module1', 'pkg.module2')
        with context as mock:
            self.engine.meta_path=[mock]
            mock['pkg'].__all__ = ['module1']
            module = self.engine.__import__('pkg', fromlist=['module2', '*'])
            self.assertEqual(module.__name__, 'pkg')
            self.assertTrue(hasattr(module, 'module1'))
            self.assertTrue(hasattr(module, 'module2'))
            self.assertEqual(module.module1.__name__, 'pkg.module1')
            self.assertEqual(module.module2.__name__, 'pkg.module2')


def test_main():
    from test.support import run_unittest
    run_unittest(ReturnValue, HandlingFromlist)

if __name__ == '__main__':
    test_main()