Kaydet (Commit) 35184edd authored tarafından Michael Foord's avatar Michael Foord

Issue 9732: __class__ no longer checked on objects by getattr_static

üst e516265b
......@@ -1080,6 +1080,13 @@ def _check_class(klass, attr):
pass
return _sentinel
def _is_type(obj):
try:
_static_getmro(obj)
except TypeError:
return False
return True
def getattr_static(obj, attr, default=_sentinel):
"""Retrieve attributes without triggering dynamic lookup via the
......@@ -1093,7 +1100,7 @@ def getattr_static(obj, attr, default=_sentinel):
documentation for details.
"""
instance_result = _sentinel
if not isinstance(obj, type):
if not _is_type(obj):
instance_result = _check_instance(obj, attr)
klass = type(obj)
else:
......
......@@ -860,11 +860,15 @@ class TestGetattrStatic(unittest.TestCase):
foo = 3
class Something(Base):
executed = False
@property
def __class__(self):
self.executed = True
return object
self.assertEqual(inspect.getattr_static(Something(), 'foo'), 3)
instance = Something()
self.assertEqual(inspect.getattr_static(instance, 'foo'), 3)
self.assertFalse(instance.executed)
self.assertEqual(inspect.getattr_static(Something, 'foo'), 3)
def test_mro_as_property(self):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment