diff options
author | Guido van Rossum <guido@python.org> | 2002-10-29 19:08:29 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2002-10-29 19:08:29 (GMT) |
commit | 2c9590f62549ded76dbdf096ee106e7b43f004f5 (patch) | |
tree | 382ae7d63d0c446471898f354b2bb7fe9404880c | |
parent | f740bdf3379046701d23c8849d51aadd8377dc17 (diff) | |
download | cpython-2c9590f62549ded76dbdf096ee106e7b43f004f5.zip cpython-2c9590f62549ded76dbdf096ee106e7b43f004f5.tar.gz cpython-2c9590f62549ded76dbdf096ee106e7b43f004f5.tar.bz2 |
Added test for this fix to classobject.c:
Since properties are supported here, is possible that
instance_getattr2() raises an exception. Fix all code that made this
assumption.
Backport candidate.
-rw-r--r-- | Lib/test/test_class.py | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/Lib/test/test_class.py b/Lib/test/test_class.py index e90a790..3c3ea06 100644 --- a/Lib/test/test_class.py +++ b/Lib/test/test_class.py @@ -288,3 +288,30 @@ except RuntimeError: pass else: raise TestFailed, "how could this not have overflowed the stack?" + + +# Tests for exceptions raised in instance_getattr2(). + +def booh(self): + raise AttributeError, "booh" + +class A: + a = property(booh) +try: + A().a # Raised AttributeError: A instance has no attribute 'a' +except AttributeError, x: + if str(x) is not "booh": + print "attribute error for A().a got masked:", str(x) + +class E: + __eq__ = property(booh) +E() == E() # In debug mode, caused a C-level assert() to fail + +class I: + __init__ = property(booh) +try: + I() # In debug mode, printed XXX undetected error and raises AttributeError +except AttributeError, x: + pass +else: + print "attribute error for I.__init__ got masked" |