mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Ensure that assertNumQueries doesn't swallow exceptions inside the function.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@14405 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -524,7 +524,10 @@ class TransactionTestCase(ut2.TestCase):
|
||||
context.__enter__()
|
||||
try:
|
||||
func(*args, **kwargs)
|
||||
finally:
|
||||
except:
|
||||
context.__exit__(*sys.exc_info())
|
||||
raise
|
||||
else:
|
||||
context.__exit__(*sys.exc_info())
|
||||
|
||||
def connections_support_transactions():
|
||||
|
@@ -8,6 +8,14 @@ if sys.version_info >= (2, 5):
|
||||
|
||||
|
||||
class SkippingTestCase(TestCase):
|
||||
def test_assert_num_queries(self):
|
||||
def test_func():
|
||||
raise ValueError
|
||||
|
||||
self.assertRaises(ValueError,
|
||||
self.assertNumQueries, 2, test_func
|
||||
)
|
||||
|
||||
def test_skip_unless_db_feature(self):
|
||||
"A test that might be skipped is actually called."
|
||||
# Total hack, but it works, just want an attribute that's always true.
|
||||
|
Reference in New Issue
Block a user