diff options
author | Jeffrey Yasskin <jyasskin@gmail.com> | 2008-03-17 16:31:21 (GMT) |
---|---|---|
committer | Jeffrey Yasskin <jyasskin@gmail.com> | 2008-03-17 16:31:21 (GMT) |
commit | b9e15f7555ed6596fa0af15f457389827ecab8f6 (patch) | |
tree | 52c49b8205f1c41e65909ac66f5daf2536cd4899 /Lib | |
parent | 1b4e45bab940d385386e9442de5f5fbc7983dd50 (diff) | |
download | cpython-b9e15f7555ed6596fa0af15f457389827ecab8f6.zip cpython-b9e15f7555ed6596fa0af15f457389827ecab8f6.tar.gz cpython-b9e15f7555ed6596fa0af15f457389827ecab8f6.tar.bz2 |
Make isinstance(OldstyleClass, NewstyleClass) return False instead of raising
an exception. Issue reported by Joseph Armbruster.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/abc.py | 10 | ||||
-rw-r--r-- | Lib/test/test_abc.py | 11 |
2 files changed, 16 insertions, 5 deletions
@@ -116,18 +116,18 @@ class ABCMeta(type): def __instancecheck__(cls, instance): """Override for isinstance(instance, cls).""" - # Inline the cache checking for new-style classes. - subclass = instance.__class__ + # Inline the cache checking when it's simple. + subclass = getattr(instance, '__class__', None) if subclass in cls._abc_cache: return True subtype = type(instance) - if subtype is subclass: + if subtype is subclass or subclass is None: if (cls._abc_negative_cache_version == ABCMeta._abc_invalidation_counter and - subclass in cls._abc_negative_cache): + subtype in cls._abc_negative_cache): return False # Fall back to the subclass check. - return cls.__subclasscheck__(subclass) + return cls.__subclasscheck__(subtype) return (cls.__subclasscheck__(subclass) or cls.__subclasscheck__(subtype)) diff --git a/Lib/test/test_abc.py b/Lib/test/test_abc.py index f1c0c3b..8fed220 100644 --- a/Lib/test/test_abc.py +++ b/Lib/test/test_abc.py @@ -70,6 +70,17 @@ class TestABC(unittest.TestCase): self.assertFalse(issubclass(OldstyleClass, A)) 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): class A: __metaclass__ = abc.ABCMeta |