mirror of
https://github.com/python/cpython.git
synced 2025-09-21 08:00:37 +00:00
bpo-30878: Fix error message when keyword arguments are passed (#2635)
to staticmethod() and classmethod().
This commit is contained in:
parent
aa6a4d6ed8
commit
9648088e6c
2 changed files with 12 additions and 4 deletions
|
@ -186,6 +186,14 @@ class CFunctionCallsErrorMessages(unittest.TestCase):
|
||||||
msg = r"^pack\(\) takes no keyword arguments$"
|
msg = r"^pack\(\) takes no keyword arguments$"
|
||||||
self.assertRaisesRegex(TypeError, msg, struct.Struct.pack, struct.Struct(""), x=2)
|
self.assertRaisesRegex(TypeError, msg, struct.Struct.pack, struct.Struct(""), x=2)
|
||||||
|
|
||||||
|
def test_varargs12_kw(self):
|
||||||
|
msg = r"^staticmethod\(\) takes no keyword arguments$"
|
||||||
|
self.assertRaisesRegex(TypeError, msg, staticmethod, func=id)
|
||||||
|
|
||||||
|
def test_varargs13_kw(self):
|
||||||
|
msg = r"^classmethod\(\) takes no keyword arguments$"
|
||||||
|
self.assertRaisesRegex(TypeError, msg, classmethod, func=id)
|
||||||
|
|
||||||
def test_oldargs0_1(self):
|
def test_oldargs0_1(self):
|
||||||
msg = r"keys\(\) takes no arguments \(1 given\)"
|
msg = r"keys\(\) takes no arguments \(1 given\)"
|
||||||
self.assertRaisesRegex(TypeError, msg, {}.keys, 0)
|
self.assertRaisesRegex(TypeError, msg, {}.keys, 0)
|
||||||
|
|
|
@ -702,10 +702,10 @@ cm_init(PyObject *self, PyObject *args, PyObject *kwds)
|
||||||
classmethod *cm = (classmethod *)self;
|
classmethod *cm = (classmethod *)self;
|
||||||
PyObject *callable;
|
PyObject *callable;
|
||||||
|
|
||||||
if (!PyArg_UnpackTuple(args, "classmethod", 1, 1, &callable))
|
|
||||||
return -1;
|
|
||||||
if (!_PyArg_NoKeywords("classmethod", kwds))
|
if (!_PyArg_NoKeywords("classmethod", kwds))
|
||||||
return -1;
|
return -1;
|
||||||
|
if (!PyArg_UnpackTuple(args, "classmethod", 1, 1, &callable))
|
||||||
|
return -1;
|
||||||
Py_INCREF(callable);
|
Py_INCREF(callable);
|
||||||
cm->cm_callable = callable;
|
cm->cm_callable = callable;
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -883,10 +883,10 @@ sm_init(PyObject *self, PyObject *args, PyObject *kwds)
|
||||||
staticmethod *sm = (staticmethod *)self;
|
staticmethod *sm = (staticmethod *)self;
|
||||||
PyObject *callable;
|
PyObject *callable;
|
||||||
|
|
||||||
if (!PyArg_UnpackTuple(args, "staticmethod", 1, 1, &callable))
|
|
||||||
return -1;
|
|
||||||
if (!_PyArg_NoKeywords("staticmethod", kwds))
|
if (!_PyArg_NoKeywords("staticmethod", kwds))
|
||||||
return -1;
|
return -1;
|
||||||
|
if (!PyArg_UnpackTuple(args, "staticmethod", 1, 1, &callable))
|
||||||
|
return -1;
|
||||||
Py_INCREF(callable);
|
Py_INCREF(callable);
|
||||||
sm->sm_callable = callable;
|
sm->sm_callable = callable;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue