diff options
| author | Andrew Svetlov <andrew.svetlov@gmail.com> | 2012-12-14 17:04:59 +0200 | 
|---|---|---|
| committer | Andrew Svetlov <andrew.svetlov@gmail.com> | 2012-12-14 17:04:59 +0200 | 
| commit | 6b2cbeba58aeb0755bdefd02fb51a80ec66d6144 (patch) | |
| tree | 2634f036965fc3ebf737ef3ce1b830437de9a04f /Lib/test/test_imp.py | |
| parent | f76f0eea5c00ea20ac62d9a8437a19f23fd455c5 (diff) | |
| download | cpython-git-6b2cbeba58aeb0755bdefd02fb51a80ec66d6144.tar.gz | |
Issue #16421: allow to load multiple modules from the same shared object.
Patch by Václav Šmilauer.
Diffstat (limited to 'Lib/test/test_imp.py')
| -rw-r--r-- | Lib/test/test_imp.py | 14 | 
1 files changed, 14 insertions, 0 deletions
| diff --git a/Lib/test/test_imp.py b/Lib/test/test_imp.py index 65c9f25c83..bf2141fea0 100644 --- a/Lib/test/test_imp.py +++ b/Lib/test/test_imp.py @@ -217,6 +217,20 @@ class ImportTests(unittest.TestCase):          mod = imp.load_module(example, *x)          self.assertEqual(mod.__name__, example) +    def test_issue16421_multiple_modules_in_one_dll(self): +        # Issue 16421: loading several modules from the same compiled file fails +        m = '_testimportmultiple' +        fileobj, pathname, description = imp.find_module(m) +        fileobj.close() +        mod0 = imp.load_dynamic(m, pathname) +        mod1 = imp.load_dynamic('foo', pathname) +        mod2 = imp.load_dynamic('bar', pathname) +        self.assertEqual(mod0.__name__, m) +        self.assertEqual(mod1.__name__, 'foo') +        self.assertEqual(mod2.__name__, 'bar') +        with self.assertRaises(ImportError): +            imp.load_dynamic('nonexistent', pathname) +      def test_load_dynamic_ImportError_path(self):          # Issue #1559549 added `name` and `path` attributes to ImportError          # in order to provide better detail. Issue #10854 implemented those | 
