mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
Issue #2534: speed up isinstance() and issubclass() by 50-70%, so as to
match Python 2.5 speed despite the __instancecheck__ / __subclasscheck__ mechanism. In the process, fix a bug where isinstance() and issubclass(), when given a tuple of classes as second argument, were looking up __instancecheck__ / __subclasscheck__ on the tuple rather than on each type object. Reviewed by Benjamin Peterson and Raymond Hettinger.
This commit is contained in:
parent
14cb6bcf2b
commit
0668c62677
8 changed files with 211 additions and 88 deletions
|
@ -333,7 +333,19 @@ class ExceptionTests(unittest.TestCase):
|
|||
return g()
|
||||
except ValueError:
|
||||
return -1
|
||||
self.assertRaises(RuntimeError, g)
|
||||
|
||||
# The test prints an unraisable recursion error when
|
||||
# doing "except ValueError", this is because subclass
|
||||
# checking has recursion checking too.
|
||||
with captured_output("stderr"):
|
||||
try:
|
||||
g()
|
||||
except RuntimeError:
|
||||
pass
|
||||
except:
|
||||
self.fail("Should have raised KeyError")
|
||||
else:
|
||||
self.fail("Should have raised KeyError")
|
||||
|
||||
def testUnicodeStrUsage(self):
|
||||
# Make sure both instances and classes have a str and unicode
|
||||
|
@ -363,12 +375,20 @@ class ExceptionTests(unittest.TestCase):
|
|||
except KeyError:
|
||||
pass
|
||||
except:
|
||||
self.fail("Should have raised TypeError")
|
||||
self.fail("Should have raised KeyError")
|
||||
else:
|
||||
self.fail("Should have raised TypeError")
|
||||
self.assertEqual(stderr.getvalue(),
|
||||
"Exception ValueError: ValueError() in "
|
||||
"<type 'exceptions.KeyError'> ignored\n")
|
||||
self.fail("Should have raised KeyError")
|
||||
|
||||
with captured_output("stderr") as stderr:
|
||||
def g():
|
||||
try:
|
||||
return g()
|
||||
except RuntimeError:
|
||||
return sys.exc_info()
|
||||
e, v, tb = g()
|
||||
self.assert_(e is RuntimeError, e)
|
||||
self.assert_("maximum recursion depth exceeded" in str(v), v)
|
||||
|
||||
|
||||
def test_main():
|
||||
run_unittest(ExceptionTests)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue