summaryrefslogtreecommitdiff
path: root/django/test/testcases.py
diff options
context:
space:
mode:
authorSimon Charette <charette.s@gmail.com>2013-03-01 15:29:39 -0500
committerSimon Charette <charette.s@gmail.com>2013-03-02 02:41:14 -0500
commit952ba5237ea62e7647cdd5214b1df79c0e7cea38 (patch)
tree57c656fcca1a01a033fde08e7013d63a8738ad0d /django/test/testcases.py
parent203c17c21ec2d4a45fd40a027b32f3f545c6dce4 (diff)
Added a context manager to capture queries while testing.
Also made some import cleanups while I was there. Refs #10399.
Diffstat (limited to 'django/test/testcases.py')
-rw-r--r--django/test/testcases.py35
1 files changed, 11 insertions, 24 deletions
diff --git a/django/test/testcases.py b/django/test/testcases.py
index f9d028bb72..345e4b191b 100644
--- a/django/test/testcases.py
+++ b/django/test/testcases.py
@@ -24,31 +24,30 @@ from django.core.exceptions import ValidationError, ImproperlyConfigured
from django.core.handlers.wsgi import WSGIHandler
from django.core.management import call_command
from django.core.management.color import no_style
-from django.core.signals import request_started
from django.core.servers.basehttp import (WSGIRequestHandler, WSGIServer,
WSGIServerException)
from django.core.urlresolvers import clear_url_caches
from django.core.validators import EMPTY_VALUES
-from django.db import (transaction, connection, connections, DEFAULT_DB_ALIAS,
- reset_queries)
+from django.db import connection, connections, DEFAULT_DB_ALIAS, transaction
from django.forms.fields import CharField
from django.http import QueryDict
from django.test import _doctest as doctest
from django.test.client import Client
from django.test.html import HTMLParseError, parse_html
from django.test.signals import template_rendered
-from django.test.utils import (override_settings, compare_xml, strip_quotes)
-from django.test.utils import ContextList
-from django.utils import unittest as ut2
+from django.test.utils import (CaptureQueriesContext, ContextList,
+ override_settings, compare_xml, strip_quotes)
+from django.utils import six, unittest as ut2
from django.utils.encoding import force_text
-from django.utils import six
+from django.utils.unittest import skipIf # Imported here for backward compatibility
from django.utils.unittest.util import safe_repr
-from django.utils.unittest import skipIf
from django.views.static import serve
+
__all__ = ('DocTestRunner', 'OutputChecker', 'TestCase', 'TransactionTestCase',
'SimpleTestCase', 'skipIfDBFeature', 'skipUnlessDBFeature')
+
normalize_long_ints = lambda s: re.sub(r'(?<![\w])(\d+)L(?![\w])', '\\1', s)
normalize_decimals = lambda s: re.sub(r"Decimal\('(\d+(\.\d*)?)'\)",
lambda m: "Decimal(\"%s\")" % m.groups()[0], s)
@@ -168,28 +167,17 @@ class DocTestRunner(doctest.DocTestRunner):
transaction.rollback_unless_managed(using=conn)
-class _AssertNumQueriesContext(object):
+class _AssertNumQueriesContext(CaptureQueriesContext):
def __init__(self, test_case, num, connection):
self.test_case = test_case
self.num = num
- self.connection = connection
-
- def __enter__(self):
- self.old_debug_cursor = self.connection.use_debug_cursor
- self.connection.use_debug_cursor = True
- self.starting_queries = len(self.connection.queries)
- request_started.disconnect(reset_queries)
- return self
+ super(_AssertNumQueriesContext, self).__init__(connection)
def __exit__(self, exc_type, exc_value, traceback):
- self.connection.use_debug_cursor = self.old_debug_cursor
- request_started.connect(reset_queries)
if exc_type is not None:
return
-
- final_queries = len(self.connection.queries)
- executed = final_queries - self.starting_queries
-
+ super(_AssertNumQueriesContext, self).__exit__(exc_type, exc_value, traceback)
+ executed = len(self)
self.test_case.assertEqual(
executed, self.num, "%d queries executed, %d expected" % (
executed, self.num
@@ -1051,7 +1039,6 @@ class LiveServerThread(threading.Thread):
http requests.
"""
if self.connections_override:
- from django.db import connections
# Override this thread's database connections with the ones
# provided by the main thread.
for alias, conn in self.connections_override.items():