changeset: 101101:9b565815079a branch: 2.7 parent: 101099:8d6bd32a56a8 user: Serhiy Storchaka date: Sat Apr 23 10:53:28 2016 +0300 files: Lib/test/test_operator.py Misc/NEWS Modules/operator.c description: Issue #26822: itemgetter, attrgetter and methodcaller objects no longer silently ignore keyword arguments. diff -r 8d6bd32a56a8 -r 9b565815079a Lib/test/test_operator.py --- a/Lib/test/test_operator.py Fri Apr 22 23:43:10 2016 -0700 +++ b/Lib/test/test_operator.py Sat Apr 23 10:53:28 2016 +0300 @@ -371,6 +371,9 @@ a.name = 'arthur' f = operator.attrgetter('name') self.assertEqual(f(a), 'arthur') + self.assertRaises(TypeError, f) + self.assertRaises(TypeError, f, a, 'dent') + self.assertRaises(TypeError, f, a, surname='dent') f = operator.attrgetter('rank') self.assertRaises(AttributeError, f, a) f = operator.attrgetter(2) @@ -414,6 +417,9 @@ a = 'ABCDE' f = operator.itemgetter(2) self.assertEqual(f(a), 'C') + self.assertRaises(TypeError, f) + self.assertRaises(TypeError, f, a, 3) + self.assertRaises(TypeError, f, a, size=3) f = operator.itemgetter(10) self.assertRaises(IndexError, f, a) @@ -456,6 +462,9 @@ self.assertRaises(IndexError, f, a) f = operator.methodcaller('foo', 1, 2) self.assertEqual(f(a), 3) + self.assertRaises(TypeError, f) + self.assertRaises(TypeError, f, a, 3) + self.assertRaises(TypeError, f, a, spam=3) f = operator.methodcaller('bar') self.assertEqual(f(a), 42) self.assertRaises(TypeError, f, a, a) diff -r 8d6bd32a56a8 -r 9b565815079a Misc/NEWS --- a/Misc/NEWS Fri Apr 22 23:43:10 2016 -0700 +++ b/Misc/NEWS Sat Apr 23 10:53:28 2016 +0300 @@ -77,6 +77,9 @@ Library ------- +- Issue #26822: itemgetter, attrgetter and methodcaller objects no longer + silently ignore keyword arguments. + - Issue #26657: Fix directory traversal vulnerability with SimpleHTTPServer on Windows. This fixes a regression that was introduced in 2.7.7. Based on patch by Philipp Hagemeister. diff -r 8d6bd32a56a8 -r 9b565815079a Modules/operator.c --- a/Modules/operator.c Fri Apr 22 23:43:10 2016 -0700 +++ b/Modules/operator.c Sat Apr 23 10:53:28 2016 +0300 @@ -511,6 +511,8 @@ PyObject *obj, *result; Py_ssize_t i, nitems=ig->nitems; + if (!_PyArg_NoKeywords("itemgetter", kw)) + return NULL; if (!PyArg_UnpackTuple(args, "itemgetter", 1, 1, &obj)) return NULL; if (nitems == 1) @@ -691,6 +693,8 @@ PyObject *obj, *result; Py_ssize_t i, nattrs=ag->nattrs; + if (!_PyArg_NoKeywords("attrgetter", kw)) + return NULL; if (!PyArg_UnpackTuple(args, "attrgetter", 1, 1, &obj)) return NULL; if (ag->nattrs == 1) @@ -838,6 +842,8 @@ { PyObject *method, *obj, *result; + if (!_PyArg_NoKeywords("methodcaller", kw)) + return NULL; if (!PyArg_UnpackTuple(args, "methodcaller", 1, 1, &obj)) return NULL; method = PyObject_GetAttr(obj, mc->name);