Commit f2f55e7f authored by Serhiy Storchaka's avatar Serhiy Storchaka Committed by GitHub

bpo-36282: Improved error message for too much positional arguments. (GH-12310)

parent d53fe5f4
...@@ -157,7 +157,7 @@ class CFunctionCallsErrorMessages(unittest.TestCase): ...@@ -157,7 +157,7 @@ class CFunctionCallsErrorMessages(unittest.TestCase):
self.assertRaisesRegex(TypeError, msg, {}.__contains__, 0, 1) self.assertRaisesRegex(TypeError, msg, {}.__contains__, 0, 1)
def test_varargs3(self): def test_varargs3(self):
msg = r"^from_bytes\(\) takes at most 2 positional arguments \(3 given\)" msg = r"^from_bytes\(\) takes exactly 2 positional arguments \(3 given\)"
self.assertRaisesRegex(TypeError, msg, int.from_bytes, b'a', 'little', False) self.assertRaisesRegex(TypeError, msg, int.from_bytes, b'a', 'little', False)
def test_varargs1min(self): def test_varargs1min(self):
......
Improved error message for too much positional arguments in some builtin
functions.
...@@ -2137,7 +2137,7 @@ vgetargskeywordsfast_impl(PyObject *const *args, Py_ssize_t nargs, ...@@ -2137,7 +2137,7 @@ vgetargskeywordsfast_impl(PyObject *const *args, Py_ssize_t nargs,
"%.200s%s takes %s %d positional argument%s (%d given)", "%.200s%s takes %s %d positional argument%s (%d given)",
(parser->fname == NULL) ? "function" : parser->fname, (parser->fname == NULL) ? "function" : parser->fname,
(parser->fname == NULL) ? "" : "()", (parser->fname == NULL) ? "" : "()",
(parser->min != INT_MAX) ? "at most" : "exactly", (parser->min < parser->max) ? "at most" : "exactly",
parser->max, parser->max,
parser->max == 1 ? "" : "s", parser->max == 1 ? "" : "s",
nargs); nargs);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment