]> granicus.if.org Git - python/commitdiff
Issue #28189: dictitems_contains no longer swallows compare errors.
authorRaymond Hettinger <python@rcn.com>
Mon, 19 Sep 2016 04:45:11 +0000 (21:45 -0700)
committerRaymond Hettinger <python@rcn.com>
Mon, 19 Sep 2016 04:45:11 +0000 (21:45 -0700)
 (Patch by Xiang Zhang)

Lib/test/test_dictviews.py
Misc/NEWS
Objects/dictobject.c

index ab23ca1cf778b572bcf62c8dcabbc708fd0d8c71..0c996526d802ef13af3d83ce9db437cce8902b5c 100644 (file)
@@ -209,6 +209,32 @@ class DictSetTest(unittest.TestCase):
         self.assertRaises(TypeError, copy.copy, d.values())
         self.assertRaises(TypeError, copy.copy, d.items())
 
+    def test_compare_error(self):
+        class Exc(Exception):
+            pass
+
+        class BadEq:
+            def __hash__(self):
+                return 7
+            def __eq__(self, other):
+                raise Exc
+
+        k1, k2 = BadEq(), BadEq()
+        v1, v2 = BadEq(), BadEq()
+        d = {k1: v1}
+
+        self.assertIn(k1, d)
+        self.assertIn(k1, d.keys())
+        self.assertIn(v1, d.values())
+        self.assertIn((k1, v1), d.items())
+
+        self.assertRaises(Exc, d.__contains__, k2)
+        self.assertRaises(Exc, d.keys().__contains__, k2)
+        self.assertRaises(Exc, d.items().__contains__, (k2, v1))
+        self.assertRaises(Exc, d.items().__contains__, (k1, v2))
+        with self.assertRaises(Exc):
+            v2 in d.values()
+
     def test_pickle(self):
         d = {1: 10, "a": "ABC"}
         for proto in range(pickle.HIGHEST_PROTOCOL + 1):
index c23ec97dc3fd5903b8ca2a70ae3bbc4ce7150572..a0dccdbd30587e28b6c62d7f64e5aa1d6ba8ed94 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -19,6 +19,9 @@ Core and Builtins
 - Issue #25758: Prevents zipimport from unnecessarily encoding a filename
   (patch by Eryk Sun)
 
+- Issue #28189: dictitems_contains no longer swallows compare errors.
+  (Patch by Xiang Zhang)
+
 - Issue #27812: Properly clear out a generator's frame's backreference to the
   generator to prevent crashes in frame.clear().
 
index e04ab2b92f444fc99b9e32314ff51e75abb84086..e79ab36eb2cc15f47e2bdcce28ad84512ad0a622 100644 (file)
@@ -3654,7 +3654,7 @@ dictitems_contains(_PyDictViewObject *dv, PyObject *obj)
         return 0;
     key = PyTuple_GET_ITEM(obj, 0);
     value = PyTuple_GET_ITEM(obj, 1);
-    found = PyDict_GetItem((PyObject *)dv->dv_dict, key);
+    found = PyDict_GetItemWithError((PyObject *)dv->dv_dict, key);
     if (found == NULL) {
         if (PyErr_Occurred())
             return -1;