]> granicus.if.org Git - python/commitdiff
Raise TypeError if the name given to importlib.__import__() lacks an rpartition
authorBrett Cannon <bcannon@gmail.com>
Sun, 30 Aug 2009 19:08:58 +0000 (19:08 +0000)
committerBrett Cannon <bcannon@gmail.com>
Sun, 30 Aug 2009 19:08:58 +0000 (19:08 +0000)
attribute. Was throwing AttributeError before. Discovered when running
test_builtin against importlib.

This exception change is specific to importlib.__import__() and does not apply to
import_module() as it is being done for compatibility reasons only.

Lib/importlib/_bootstrap.py
Lib/importlib/test/import_/test_api.py [new file with mode: 0644]
Lib/importlib/test/regrtest.py
Misc/NEWS

index 95fea3365ed8be2f3e0b420301bed6a64ef08923..063f603f6da6efb7633f74602cfb0d4cd867e66d 100644 (file)
@@ -917,6 +917,8 @@ def __import__(name, globals={}, locals={}, fromlist=[], level=0):
     import (e.g. ``from ..pkg import mod`` would have a 'level' of 2).
 
     """
+    if not hasattr(name, 'rpartition'):
+        raise TypeError("module name must be str, not {}".format(type(name)))
     if level == 0:
         module = _gcd_import(name)
     else:
diff --git a/Lib/importlib/test/import_/test_api.py b/Lib/importlib/test/import_/test_api.py
new file mode 100644 (file)
index 0000000..9075d42
--- /dev/null
@@ -0,0 +1,22 @@
+from . import util
+import unittest
+
+
+class APITest(unittest.TestCase):
+
+    """Test API-specific details for __import__ (e.g. raising the right
+    exception when passing in an int for the module name)."""
+
+    def test_name_requires_rparition(self):
+        # Raise TypeError if a non-string is passed in for the module name.
+        with self.assertRaises(TypeError):
+            util.import_(42)
+
+
+def test_main():
+    from test.support import run_unittest
+    run_unittest(APITest)
+
+
+if __name__ == '__main__':
+    test_main()
index 17e7f4ef79df06d4756c7aede1300be2bf6f6cd2..aedc338c52d8164ae2508dc27c5752482b7e1291 100644 (file)
@@ -6,7 +6,6 @@ Otherwise all command-line options valid for test.regrtest are also valid for
 this script.
 
 XXX FAILING
-    test_builtin  # Wanting a TypeError for an integer name
     test_import  # execution bit, exception name differing, file name differing
                     between code and module (?)
     test_importhooks  # package not set in _gcd_import() but level > 0
index d6d7dc3187a02344cd2e6e9c6f9673b190d3a128..6f73e73e49035b15013265a350cc6fcee2c9719e 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -68,6 +68,10 @@ C-API
 Library
 -------
 
+- Raise a TypeError when the name of a module to be imported for
+  importlib.__import__ is not a string (was raising an
+  AttributeError before).
+
 - Allow the fromlist passed into importlib.__import__ to be any iterable.
 
 - Have importlib raise ImportError if None is found in sys.modules.