]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-95196: Disable incorrect pickling of the C implemented classmethod descriptors...
authorSerhiy Storchaka <storchaka@gmail.com>
Wed, 5 Oct 2022 11:21:16 +0000 (14:21 +0300)
committerGitHub <noreply@github.com>
Wed, 5 Oct 2022 11:21:16 +0000 (14:21 +0300)
Lib/test/pickletester.py
Misc/NEWS.d/next/Core and Builtins/2022-08-29-13-06-58.gh-issue-95196.eGRR4b.rst [new file with mode: 0644]
Objects/descrobject.c

index 21419e11c87497a369aac2b73d491b4eb2285a68..499f80a15f342272721568e94d6b7549108310d2 100644 (file)
@@ -2776,6 +2776,15 @@ class AbstractPickleTests:
                     unpickled = self.loads(self.dumps(method, proto))
                     self.assertEqual(method(obj), unpickled(obj))
 
+        descriptors = (
+            PyMethodsTest.__dict__['cheese'],  # static method descriptor
+            PyMethodsTest.__dict__['wine'],  # class method descriptor
+        )
+        for proto in range(pickle.HIGHEST_PROTOCOL + 1):
+            for descr in descriptors:
+                with self.subTest(proto=proto, descr=descr):
+                    self.assertRaises(TypeError, self.dumps, descr, proto)
+
     def test_c_methods(self):
         global Subclass
         class Subclass(tuple):
@@ -2811,6 +2820,15 @@ class AbstractPickleTests:
                     unpickled = self.loads(self.dumps(method, proto))
                     self.assertEqual(method(*args), unpickled(*args))
 
+        descriptors = (
+            bytearray.__dict__['maketrans'],  # built-in static method descriptor
+            dict.__dict__['fromkeys'],  # built-in class method descriptor
+        )
+        for proto in range(pickle.HIGHEST_PROTOCOL + 1):
+            for descr in descriptors:
+                with self.subTest(proto=proto, descr=descr):
+                    self.assertRaises(TypeError, self.dumps, descr, proto)
+
     def test_compat_pickle(self):
         tests = [
             (range(1, 7), '__builtin__', 'xrange'),
diff --git a/Misc/NEWS.d/next/Core and Builtins/2022-08-29-13-06-58.gh-issue-95196.eGRR4b.rst b/Misc/NEWS.d/next/Core and Builtins/2022-08-29-13-06-58.gh-issue-95196.eGRR4b.rst
new file mode 100644 (file)
index 0000000..37534fa
--- /dev/null
@@ -0,0 +1 @@
+Disable incorrect pickling of the C implemented classmethod descriptors.
index 82570e085143ed5b8387ee2cf51e0f98ae2f0583..a2974f91aaaec30f6d37332ba58fd7444bf96118 100644 (file)
@@ -776,7 +776,7 @@ PyTypeObject PyClassMethodDescr_Type = {
     0,                                          /* tp_weaklistoffset */
     0,                                          /* tp_iter */
     0,                                          /* tp_iternext */
-    descr_methods,                              /* tp_methods */
+    0,                                          /* tp_methods */
     descr_members,                              /* tp_members */
     method_getset,                              /* tp_getset */
     0,                                          /* tp_base */