From 7c573857c7ac63395cc19b4785e0a91acbb83742 Mon Sep 17 00:00:00 2001 From: Serhiy Storchaka Date: Fri, 6 Dec 2013 23:23:15 +0200 Subject: [PATCH] Issue #16373: Prevent infinite recursion for ABC Set class comparisons. --- Lib/_abcoll.py | 4 ++-- Lib/test/test_collections.py | 29 +++++++++++++++++++++++++++++ Misc/NEWS | 2 ++ 3 files changed, 33 insertions(+), 2 deletions(-) diff --git a/Lib/_abcoll.py b/Lib/_abcoll.py index 0438afda28..8b650a7763 100644 --- a/Lib/_abcoll.py +++ b/Lib/_abcoll.py @@ -165,12 +165,12 @@ class Set(Sized, Iterable, Container): def __gt__(self, other): if not isinstance(other, Set): return NotImplemented - return other < self + return other.__lt__(self) def __ge__(self, other): if not isinstance(other, Set): return NotImplemented - return other <= self + return other.__le__(self) def __eq__(self, other): if not isinstance(other, Set): diff --git a/Lib/test/test_collections.py b/Lib/test/test_collections.py index 3aaecb2a6f..784a31880e 100644 --- a/Lib/test/test_collections.py +++ b/Lib/test/test_collections.py @@ -594,6 +594,35 @@ class TestCollectionABCs(ABCTestCase): s |= s self.assertEqual(s, full) + def test_issue16373(self): + # Recursion error comparing comparable and noncomparable + # Set instances + class MyComparableSet(Set): + def __contains__(self, x): + return False + def __len__(self): + return 0 + def __iter__(self): + return iter([]) + class MyNonComparableSet(Set): + def __contains__(self, x): + return False + def __len__(self): + return 0 + def __iter__(self): + return iter([]) + def __le__(self, x): + return NotImplemented + def __lt__(self, x): + return NotImplemented + + cs = MyComparableSet() + ncs = MyNonComparableSet() + self.assertFalse(ncs < cs) + self.assertFalse(ncs <= cs) + self.assertFalse(cs > ncs) + self.assertFalse(cs >= ncs) + def test_Mapping(self): for sample in [dict]: self.assertIsInstance(sample(), Mapping) diff --git a/Misc/NEWS b/Misc/NEWS index 1b59bfdb48..059f7bfe09 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -15,6 +15,8 @@ Core and Builtins Library ------- +- Issue #16373: Prevent infinite recursion for ABC Set class comparisons. + - Issue #19138: doctest's IGNORE_EXCEPTION_DETAIL now allows a match when no exception detail exists (no colon following the exception's name, or a colon does follow but no text follows the colon). -- 2.50.1