]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[3.12] gh-127190: Fix local_setattro() error handling (GH-127366) (#127368)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Thu, 28 Nov 2024 17:32:50 +0000 (18:32 +0100)
committerGitHub <noreply@github.com>
Thu, 28 Nov 2024 17:32:50 +0000 (17:32 +0000)
gh-127190: Fix local_setattro() error handling (GH-127366)

Don't make the assumption that the 'name' argument is a string. Use
repr() to format the 'name' argument instead.
(cherry picked from commit 20657fbdb14d50ca4ec115da0cbef155871d8d33)

Co-authored-by: Victor Stinner <vstinner@python.org>
Lib/test/test_threading_local.py
Modules/_threadmodule.c

index f0b829a978feb5c16450448f3fa2a769c3260603..3a58afd8194a32735b38eea57d4a4b6cd1efd93c 100644 (file)
@@ -208,6 +208,21 @@ class BaseLocalTest:
 
         _testcapi.join_temporary_c_thread()
 
+    @support.cpython_only
+    def test_error(self):
+        class Loop(self._local):
+            attr = 1
+
+        # Trick the "if name == '__dict__':" test of __setattr__()
+        # to always be true
+        class NameCompareTrue:
+            def __eq__(self, other):
+                return True
+
+        loop = Loop()
+        with self.assertRaisesRegex(AttributeError, 'Loop.*read-only'):
+            loop.__setattr__(NameCompareTrue(), 2)
+
 
 class ThreadLocalTest(unittest.TestCase, BaseLocalTest):
     _local = _thread._local
index 518c246e98caf6d594c2b7b6c5809f5f73834ca1..366ee6186de0d5b480480eeb0e8db2e63b3d1bfb 100644 (file)
@@ -961,7 +961,7 @@ local_setattro(localobject *self, PyObject *name, PyObject *v)
     }
     if (r == 1) {
         PyErr_Format(PyExc_AttributeError,
-                     "'%.100s' object attribute '%U' is read-only",
+                     "'%.100s' object attribute %R is read-only",
                      Py_TYPE(self)->tp_name, name);
         return -1;
     }