mirror of
https://github.com/python/cpython.git
synced 2025-07-31 07:04:42 +00:00
Make isinstance(OldstyleClass, NewstyleClass) return False instead of raising
an exception. Issue reported by Joseph Armbruster.
This commit is contained in:
parent
1b4e45bab9
commit
b9e15f7555
2 changed files with 16 additions and 5 deletions
10
Lib/abc.py
10
Lib/abc.py
|
@ -116,18 +116,18 @@ class ABCMeta(type):
|
||||||
|
|
||||||
def __instancecheck__(cls, instance):
|
def __instancecheck__(cls, instance):
|
||||||
"""Override for isinstance(instance, cls)."""
|
"""Override for isinstance(instance, cls)."""
|
||||||
# Inline the cache checking for new-style classes.
|
# Inline the cache checking when it's simple.
|
||||||
subclass = instance.__class__
|
subclass = getattr(instance, '__class__', None)
|
||||||
if subclass in cls._abc_cache:
|
if subclass in cls._abc_cache:
|
||||||
return True
|
return True
|
||||||
subtype = type(instance)
|
subtype = type(instance)
|
||||||
if subtype is subclass:
|
if subtype is subclass or subclass is None:
|
||||||
if (cls._abc_negative_cache_version ==
|
if (cls._abc_negative_cache_version ==
|
||||||
ABCMeta._abc_invalidation_counter and
|
ABCMeta._abc_invalidation_counter and
|
||||||
subclass in cls._abc_negative_cache):
|
subtype in cls._abc_negative_cache):
|
||||||
return False
|
return False
|
||||||
# Fall back to the subclass check.
|
# Fall back to the subclass check.
|
||||||
return cls.__subclasscheck__(subclass)
|
return cls.__subclasscheck__(subtype)
|
||||||
return (cls.__subclasscheck__(subclass) or
|
return (cls.__subclasscheck__(subclass) or
|
||||||
cls.__subclasscheck__(subtype))
|
cls.__subclasscheck__(subtype))
|
||||||
|
|
||||||
|
|
|
@ -70,6 +70,17 @@ class TestABC(unittest.TestCase):
|
||||||
self.assertFalse(issubclass(OldstyleClass, A))
|
self.assertFalse(issubclass(OldstyleClass, A))
|
||||||
self.assertFalse(issubclass(A, OldstyleClass))
|
self.assertFalse(issubclass(A, OldstyleClass))
|
||||||
|
|
||||||
|
def test_isinstance_class(self):
|
||||||
|
class A:
|
||||||
|
__metaclass__ = abc.ABCMeta
|
||||||
|
class OldstyleClass:
|
||||||
|
pass
|
||||||
|
self.assertFalse(isinstance(OldstyleClass, A))
|
||||||
|
self.assertTrue(isinstance(OldstyleClass, type(OldstyleClass)))
|
||||||
|
self.assertFalse(isinstance(A, OldstyleClass))
|
||||||
|
# This raises a recursion depth error, but is low-priority:
|
||||||
|
# self.assertTrue(isinstance(A, abc.ABCMeta))
|
||||||
|
|
||||||
def test_registration_basics(self):
|
def test_registration_basics(self):
|
||||||
class A:
|
class A:
|
||||||
__metaclass__ = abc.ABCMeta
|
__metaclass__ = abc.ABCMeta
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue