Cleaned up test_client_regress tests

This commit is contained in:
Claude Paroz 2012-05-31 17:41:31 +02:00
parent 4553f51155
commit ea4e0aad9e
2 changed files with 13 additions and 31 deletions

View File

@ -17,14 +17,10 @@ from django.template.response import SimpleTemplateResponse
from django.http import HttpResponse from django.http import HttpResponse
@override_settings(
TEMPLATE_DIRS=(os.path.join(os.path.dirname(__file__), 'templates'),)
)
class AssertContainsTests(TestCase): class AssertContainsTests(TestCase):
def setUp(self):
self.old_templates = settings.TEMPLATE_DIRS
settings.TEMPLATE_DIRS = (os.path.join(os.path.dirname(__file__), 'templates'),)
def tearDown(self):
settings.TEMPLATE_DIRS = self.old_templates
def test_contains(self): def test_contains(self):
"Responses can be inspected for content, including counting repeated substrings" "Responses can be inspected for content, including counting repeated substrings"
response = self.client.get('/test_client_regress/no_template_view/') response = self.client.get('/test_client_regress/no_template_view/')
@ -544,17 +540,13 @@ class LoginTests(TestCase):
self.assertRedirects(response, "http://testserver/test_client_regress/get_view/") self.assertRedirects(response, "http://testserver/test_client_regress/get_view/")
@override_settings(PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',)) @override_settings(
PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',),
SESSION_ENGINE='regressiontests.test_client_regress.session'
)
class SessionEngineTests(TestCase): class SessionEngineTests(TestCase):
fixtures = ['testdata'] fixtures = ['testdata']
def setUp(self):
self.old_SESSION_ENGINE = settings.SESSION_ENGINE
settings.SESSION_ENGINE = 'regressiontests.test_client_regress.session'
def tearDown(self):
settings.SESSION_ENGINE = self.old_SESSION_ENGINE
def test_login(self): def test_login(self):
"A session engine that modifies the session key can be used to log in" "A session engine that modifies the session key can be used to log in"
login = self.client.login(username='testclient', password='password') login = self.client.login(username='testclient', password='password')
@ -616,6 +608,8 @@ class ExceptionTests(TestCase):
except SuspiciousOperation: except SuspiciousOperation:
self.fail("Staff should be able to visit this page") self.fail("Staff should be able to visit this page")
@override_settings(TEMPLATE_DIRS=())
class TemplateExceptionTests(TestCase): class TemplateExceptionTests(TestCase):
def setUp(self): def setUp(self):
# Reset the loaders so they don't try to render cached templates. # Reset the loaders so they don't try to render cached templates.
@ -623,11 +617,6 @@ class TemplateExceptionTests(TestCase):
for template_loader in loader.template_source_loaders: for template_loader in loader.template_source_loaders:
if hasattr(template_loader, 'reset'): if hasattr(template_loader, 'reset'):
template_loader.reset() template_loader.reset()
self.old_templates = settings.TEMPLATE_DIRS
settings.TEMPLATE_DIRS = ()
def tearDown(self):
settings.TEMPLATE_DIRS = self.old_templates
def test_no_404_template(self): def test_no_404_template(self):
"Missing templates are correctly reported by test client" "Missing templates are correctly reported by test client"
@ -980,11 +969,8 @@ class RequestFactoryStateTest(TestCase):
# run the tests individually, and if any are failing it is confusing to run # run the tests individually, and if any are failing it is confusing to run
# them with any other set of tests. # them with any other set of tests.
def setUp(self):
self.factory = RequestFactory()
def common_test_that_should_always_pass(self): def common_test_that_should_always_pass(self):
request = self.factory.get('/') request = RequestFactory().get('/')
request.session = {} request.session = {}
self.assertFalse(hasattr(request, 'user')) self.assertFalse(hasattr(request, 'user'))
@ -1007,11 +993,8 @@ class RequestFactoryEnvironmentTests(TestCase):
are set correctly in RequestFactory. are set correctly in RequestFactory.
""" """
def setUp(self):
self.factory = RequestFactory()
def test_should_set_correct_env_variables(self): def test_should_set_correct_env_variables(self):
request = self.factory.get('/path/') request = RequestFactory().get('/path/')
self.assertEqual(request.META.get('REMOTE_ADDR'), '127.0.0.1') self.assertEqual(request.META.get('REMOTE_ADDR'), '127.0.0.1')
self.assertEqual(request.META.get('SERVER_NAME'), 'testserver') self.assertEqual(request.META.get('SERVER_NAME'), 'testserver')

View File

@ -5,7 +5,6 @@ from django.contrib.auth.decorators import login_required
from django.http import HttpResponse, HttpResponseRedirect from django.http import HttpResponse, HttpResponseRedirect
from django.core.exceptions import SuspiciousOperation from django.core.exceptions import SuspiciousOperation
from django.shortcuts import render_to_response from django.shortcuts import render_to_response
from django.utils.encoding import smart_str
from django.core.serializers.json import DjangoJSONEncoder from django.core.serializers.json import DjangoJSONEncoder
from django.test.client import CONTENT_TYPE_RE from django.test.client import CONTENT_TYPE_RE
from django.template import RequestContext from django.template import RequestContext
@ -84,8 +83,8 @@ def return_json_file(request):
obj_json = json.dumps(obj_dict, encoding=charset, obj_json = json.dumps(obj_dict, encoding=charset,
cls=DjangoJSONEncoder, cls=DjangoJSONEncoder,
ensure_ascii=False) ensure_ascii=False)
response = HttpResponse(smart_str(obj_json, encoding=charset), status=200, response = HttpResponse(obj_json.encode(charset), status=200,
mimetype='application/json; charset=' + charset) mimetype='application/json; charset=%s' % charset)
response['Content-Disposition'] = 'attachment; filename=testfile.json' response['Content-Disposition'] = 'attachment; filename=testfile.json'
return response return response