]> granicus.if.org Git - python/commitdiff
bpo-31492: Fix assertion failures in case of a module with a bad __name__ attribute...
authorOren Milman <orenmn@gmail.com>
Tue, 19 Sep 2017 11:23:01 +0000 (14:23 +0300)
committerSerhiy Storchaka <storchaka@gmail.com>
Tue, 19 Sep 2017 11:23:01 +0000 (14:23 +0300)
Lib/test/test_import/__init__.py
Misc/NEWS.d/next/Core and Builtins/2017-09-16-22-49-16.bpo-31492.RtyteL.rst [new file with mode: 0644]
Objects/moduleobject.c
Python/ceval.c

index ddef27d9cd4527b3a6fadb98890ad8e5664f24d0..5a610ba31268db4de7b1e18e88f783d460df579f 100644 (file)
@@ -400,6 +400,18 @@ class ImportTests(unittest.TestCase):
         self.assertEqual(str(cm.exception),
             "cannot import name 'does_not_exist' from '<unknown module name>' (unknown location)")
 
+    @cpython_only
+    def test_issue31492(self):
+        # There shouldn't be an assertion failure in case of failing to import
+        # from a module with a bad __name__ attribute, or in case of failing
+        # to access an attribute of such a module.
+        with swap_attr(os, '__name__', None):
+            with self.assertRaises(ImportError):
+                from os import does_not_exist
+
+            with self.assertRaises(AttributeError):
+                os.does_not_exist
+
     def test_concurrency(self):
         sys.path.insert(0, os.path.join(os.path.dirname(__file__), 'data'))
         try:
diff --git a/Misc/NEWS.d/next/Core and Builtins/2017-09-16-22-49-16.bpo-31492.RtyteL.rst b/Misc/NEWS.d/next/Core and Builtins/2017-09-16-22-49-16.bpo-31492.RtyteL.rst
new file mode 100644 (file)
index 0000000..a870473
--- /dev/null
@@ -0,0 +1,3 @@
+Fix assertion failures in case of failing to import from a module with a bad
+``__name__`` attribute, and in case of failing to access an attribute of such
+a module. Patch by Oren Milman.
index 2be49fbda389081d6c2c684dfb37c80ed0db8169..29732633da1184a720080eb65d3a912669cec1fa 100644 (file)
@@ -687,14 +687,11 @@ module_getattro(PyModuleObject *m, PyObject *name)
     if (m->md_dict) {
         _Py_IDENTIFIER(__name__);
         mod_name = _PyDict_GetItemId(m->md_dict, &PyId___name__);
-        if (mod_name) {
+        if (mod_name && PyUnicode_Check(mod_name)) {
             PyErr_Format(PyExc_AttributeError,
                         "module '%U' has no attribute '%U'", mod_name, name);
             return NULL;
         }
-        else if (PyErr_Occurred()) {
-            PyErr_Clear();
-        }
     }
     PyErr_Format(PyExc_AttributeError,
                 "module has no attribute '%U'", name);
index 8cc5094a3f46ef66768a8dca9ed7fd76bf5529f8..cf0c6c9ae2f1b5f5f2689a522b35f541fc149a1d 100644 (file)
@@ -4930,6 +4930,10 @@ import_from(PyObject *v, PyObject *name)
     if (pkgname == NULL) {
         goto error;
     }
+    if (!PyUnicode_Check(pkgname)) {
+        Py_CLEAR(pkgname);
+        goto error;
+    }
     fullmodname = PyUnicode_FromFormat("%U.%U", pkgname, name);
     if (fullmodname == NULL) {
         Py_DECREF(pkgname);