Issue 9732: __class__ no longer checked on objects by getattr_static
This commit is contained in:
parent
e516265bbc
commit
35184edd3d
|
@ -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):
|
||||
|
|
Loading…
Reference in New Issue