2009-04-07 20:06:05 +08:00
# -*- coding: utf-8 -*-
2007-05-10 21:46:15 +08:00
"""
Regression tests for the Test Client , especially the customized assertions .
"""
2008-08-22 21:59:41 +08:00
import os
from django . conf import settings
2008-08-02 13:56:57 +08:00
2007-05-10 21:46:15 +08:00
from django . test import Client , TestCase
2009-03-18 18:46:55 +08:00
from django . test . utils import ContextList
2008-03-20 14:50:54 +08:00
from django . core . urlresolvers import reverse
2008-06-07 14:25:59 +08:00
from django . core . exceptions import SuspiciousOperation
2009-03-18 18:46:55 +08:00
from django . template import TemplateDoesNotExist , TemplateSyntaxError , Context
2009-12-14 20:08:23 +08:00
from django . template import loader
2007-05-10 21:46:15 +08:00
2007-07-20 22:32:20 +08:00
class AssertContainsTests ( TestCase ) :
2009-04-07 20:06:05 +08:00
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
2007-07-20 22:32:20 +08:00
def test_contains ( self ) :
2007-07-20 23:40:54 +08:00
" Responses can be inspected for content, including counting repeated substrings "
2007-07-20 22:32:20 +08:00
response = self . client . get ( ' /test_client_regress/no_template_view/ ' )
2007-07-21 13:15:19 +08:00
2008-06-06 21:50:02 +08:00
self . assertNotContains ( response , ' never ' )
2007-07-21 13:15:19 +08:00
self . assertContains ( response , ' never ' , 0 )
2007-07-20 22:32:20 +08:00
self . assertContains ( response , ' once ' )
self . assertContains ( response , ' once ' , 1 )
self . assertContains ( response , ' twice ' )
self . assertContains ( response , ' twice ' , 2 )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' text ' , status_code = 999 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Couldn ' t retrieve page: Response code was 200 (expected 999) " )
try :
self . assertContains ( response , ' text ' , status_code = 999 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Couldn ' t retrieve page: Response code was 200 (expected 999) " )
try :
self . assertNotContains ( response , ' text ' , status_code = 999 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Couldn ' t retrieve page: Response code was 200 (expected 999) " )
try :
self . assertNotContains ( response , ' text ' , status_code = 999 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Couldn ' t retrieve page: Response code was 200 (expected 999) " )
2008-06-06 21:50:02 +08:00
try :
self . assertNotContains ( response , ' once ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Response should not contain ' once ' " )
2010-01-22 23:02:02 +08:00
try :
self . assertNotContains ( response , ' once ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Response should not contain ' once ' " )
2008-08-02 13:56:57 +08:00
2007-07-21 13:15:19 +08:00
try :
self . assertContains ( response , ' never ' , 1 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Found 0 instances of ' never ' in response (expected 1) " )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' never ' , 1 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Found 0 instances of ' never ' in response (expected 1) " )
2007-07-21 13:15:19 +08:00
try :
self . assertContains ( response , ' once ' , 0 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Found 1 instances of ' once ' in response (expected 0) " )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' once ' , 0 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Found 1 instances of ' once ' in response (expected 0) " )
2007-07-21 13:15:19 +08:00
2007-07-20 22:32:20 +08:00
try :
self . assertContains ( response , ' once ' , 2 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Found 1 instances of ' once ' in response (expected 2) " )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' once ' , 2 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Found 1 instances of ' once ' in response (expected 2) " )
2007-11-11 11:55:44 +08:00
2007-07-20 22:32:20 +08:00
try :
self . assertContains ( response , ' twice ' , 1 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Found 2 instances of ' twice ' in response (expected 1) " )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' twice ' , 1 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Found 2 instances of ' twice ' in response (expected 1) " )
2007-11-11 11:55:44 +08:00
2007-07-20 22:32:20 +08:00
try :
self . assertContains ( response , ' thrice ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Couldn ' t find ' thrice ' in response " )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' thrice ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Couldn ' t find ' thrice ' in response " )
2007-07-20 22:32:20 +08:00
try :
self . assertContains ( response , ' thrice ' , 3 )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Found 0 instances of ' thrice ' in response (expected 3) " )
2010-01-22 23:02:02 +08:00
try :
self . assertContains ( response , ' thrice ' , 3 , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Found 0 instances of ' thrice ' in response (expected 3) " )
2007-11-11 11:55:44 +08:00
2009-04-07 20:06:05 +08:00
def test_unicode_contains ( self ) :
" Unicode characters can be found in template context "
#Regression test for #10183
r = self . client . get ( ' /test_client_regress/check_unicode/ ' )
self . assertContains ( r , u ' さかき ' )
self . assertContains ( r , ' \xe5 \xb3 \xa0 ' . decode ( ' utf-8 ' ) )
def test_unicode_not_contains ( self ) :
" Unicode characters can be searched for, and not found in template context "
#Regression test for #10183
r = self . client . get ( ' /test_client_regress/check_unicode/ ' )
self . assertNotContains ( r , u ' はたけ ' )
self . assertNotContains ( r , ' \xe3 \x81 \xaf \xe3 \x81 \x9f \xe3 \x81 \x91 ' . decode ( ' utf-8 ' ) )
2010-01-22 23:02:02 +08:00
2007-05-10 21:46:15 +08:00
class AssertTemplateUsedTests ( TestCase ) :
fixtures = [ ' testdata.json ' ]
2007-11-11 11:55:44 +08:00
2007-05-10 21:46:15 +08:00
def test_no_context ( self ) :
" Template usage assertions work then templates aren ' t in use "
response = self . client . get ( ' /test_client_regress/no_template_view/ ' )
# Check that the no template case doesn't mess with the template assertions
self . assertTemplateNotUsed ( response , ' GET Template ' )
2007-11-11 11:55:44 +08:00
2007-05-10 21:46:15 +08:00
try :
self . assertTemplateUsed ( response , ' GET Template ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " No templates used to render the response " )
2010-01-22 23:02:02 +08:00
try :
self . assertTemplateUsed ( response , ' GET Template ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: No templates used to render the response " )
2007-11-11 11:55:44 +08:00
def test_single_context ( self ) :
2007-05-10 21:46:15 +08:00
" Template assertions work when there is a single context "
response = self . client . get ( ' /test_client/post_view/ ' , { } )
try :
self . assertTemplateNotUsed ( response , ' Empty GET Template ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Template ' Empty GET Template ' was used unexpectedly in rendering the response " )
2007-11-11 11:55:44 +08:00
2010-01-22 23:02:02 +08:00
try :
self . assertTemplateNotUsed ( response , ' Empty GET Template ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Template ' Empty GET Template ' was used unexpectedly in rendering the response " )
2007-05-10 21:46:15 +08:00
try :
2007-11-11 11:55:44 +08:00
self . assertTemplateUsed ( response , ' Empty POST Template ' )
2007-05-10 21:46:15 +08:00
except AssertionError , e :
2007-09-04 07:14:51 +08:00
self . assertEquals ( str ( e ) , " Template ' Empty POST Template ' was not a template used to render the response. Actual template(s) used: Empty GET Template " )
2007-11-11 11:55:44 +08:00
2010-01-22 23:02:02 +08:00
try :
self . assertTemplateUsed ( response , ' Empty POST Template ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Template ' Empty POST Template ' was not a template used to render the response. Actual template(s) used: Empty GET Template " )
2007-05-10 21:46:15 +08:00
def test_multiple_context ( self ) :
" Template assertions work when there are multiple contexts "
post_data = {
' text ' : ' Hello World ' ,
' email ' : ' foo@example.com ' ,
' value ' : 37 ,
' single ' : ' b ' ,
' multi ' : ( ' b ' , ' c ' , ' e ' )
}
response = self . client . post ( ' /test_client/form_view_with_template/ ' , post_data )
self . assertContains ( response , ' POST data OK ' )
try :
self . assertTemplateNotUsed ( response , " form_view.html " )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Template ' form_view.html ' was used unexpectedly in rendering the response " )
try :
self . assertTemplateNotUsed ( response , ' base.html ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Template ' base.html ' was used unexpectedly in rendering the response " )
try :
2007-11-11 11:55:44 +08:00
self . assertTemplateUsed ( response , " Valid POST Template " )
2007-05-10 21:46:15 +08:00
except AssertionError , e :
2007-09-04 07:14:51 +08:00
self . assertEquals ( str ( e ) , " Template ' Valid POST Template ' was not a template used to render the response. Actual template(s) used: form_view.html, base.html " )
2007-05-14 19:07:14 +08:00
class AssertRedirectsTests ( TestCase ) :
def test_redirect_page ( self ) :
2007-11-11 11:55:44 +08:00
" An assertion is raised if the original page couldn ' t be retrieved as expected "
2007-05-14 19:07:14 +08:00
# This page will redirect with code 301, not 302
2007-11-11 11:55:44 +08:00
response = self . client . get ( ' /test_client/permanent_redirect_view/ ' )
2007-05-14 19:07:14 +08:00
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' )
except AssertionError , e :
2007-07-06 12:04:42 +08:00
self . assertEquals ( str ( e ) , " Response didn ' t redirect as expected: Response code was 301 (expected 302) " )
2007-11-11 11:55:44 +08:00
2010-01-22 23:02:02 +08:00
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Response didn ' t redirect as expected: Response code was 301 (expected 302) " )
2007-08-31 19:37:28 +08:00
def test_lost_query ( self ) :
" An assertion is raised if the redirect location doesn ' t preserve GET parameters "
response = self . client . get ( ' /test_client/redirect_view/ ' , { ' var ' : ' value ' } )
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' )
except AssertionError , e :
2007-11-11 11:55:44 +08:00
self . assertEquals ( str ( e ) , " Response redirected to ' http://testserver/test_client/get_view/?var=value ' , expected ' http://testserver/test_client/get_view/ ' " )
2007-05-14 19:07:14 +08:00
2010-01-22 23:02:02 +08:00
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Response redirected to ' http://testserver/test_client/get_view/?var=value ' , expected ' http://testserver/test_client/get_view/ ' " )
2007-05-14 19:07:14 +08:00
def test_incorrect_target ( self ) :
" An assertion is raised if the response redirects to another target "
2007-11-11 11:55:44 +08:00
response = self . client . get ( ' /test_client/permanent_redirect_view/ ' )
2007-05-14 19:07:14 +08:00
try :
# Should redirect to get_view
self . assertRedirects ( response , ' /test_client/some_view/ ' )
except AssertionError , e :
2007-07-06 12:04:42 +08:00
self . assertEquals ( str ( e ) , " Response didn ' t redirect as expected: Response code was 301 (expected 302) " )
2007-11-11 11:55:44 +08:00
2007-05-14 19:07:14 +08:00
def test_target_page ( self ) :
2007-07-06 12:04:42 +08:00
" An assertion is raised if the response redirect target cannot be retrieved as expected "
2007-05-14 19:07:14 +08:00
response = self . client . get ( ' /test_client/double_redirect_view/ ' )
try :
# The redirect target responds with a 301 code, not 200
2007-09-14 14:05:54 +08:00
self . assertRedirects ( response , ' http://testserver/test_client/permanent_redirect_view/ ' )
2007-05-14 19:07:14 +08:00
except AssertionError , e :
self . assertEquals ( str ( e ) , " Couldn ' t retrieve redirection page ' /test_client/permanent_redirect_view/ ' : response code was 301 (expected 200) " )
2007-11-11 11:55:44 +08:00
2010-01-22 23:02:02 +08:00
try :
# The redirect target responds with a 301 code, not 200
self . assertRedirects ( response , ' http://testserver/test_client/permanent_redirect_view/ ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Couldn ' t retrieve redirection page ' /test_client/permanent_redirect_view/ ' : response code was 301 (expected 200) " )
2009-02-27 21:14:59 +08:00
def test_redirect_chain ( self ) :
" You can follow a redirect chain of multiple redirects "
response = self . client . get ( ' /test_client_regress/redirects/further/more/ ' , { } , follow = True )
self . assertRedirects ( response , ' /test_client_regress/no_template_view/ ' ,
status_code = 301 , target_status_code = 200 )
self . assertEquals ( len ( response . redirect_chain ) , 1 )
self . assertEquals ( response . redirect_chain [ 0 ] , ( ' http://testserver/test_client_regress/no_template_view/ ' , 301 ) )
def test_multiple_redirect_chain ( self ) :
" You can follow a redirect chain of multiple redirects "
response = self . client . get ( ' /test_client_regress/redirects/ ' , { } , follow = True )
self . assertRedirects ( response , ' /test_client_regress/no_template_view/ ' ,
status_code = 301 , target_status_code = 200 )
self . assertEquals ( len ( response . redirect_chain ) , 3 )
self . assertEquals ( response . redirect_chain [ 0 ] , ( ' http://testserver/test_client_regress/redirects/further/ ' , 301 ) )
self . assertEquals ( response . redirect_chain [ 1 ] , ( ' http://testserver/test_client_regress/redirects/further/more/ ' , 301 ) )
self . assertEquals ( response . redirect_chain [ 2 ] , ( ' http://testserver/test_client_regress/no_template_view/ ' , 301 ) )
def test_redirect_chain_to_non_existent ( self ) :
" You can follow a chain to a non-existent view "
response = self . client . get ( ' /test_client_regress/redirect_to_non_existent_view2/ ' , { } , follow = True )
self . assertRedirects ( response , ' /test_client_regress/non_existent_view/ ' ,
status_code = 301 , target_status_code = 404 )
def test_redirect_chain_to_self ( self ) :
" Redirections to self are caught and escaped "
response = self . client . get ( ' /test_client_regress/redirect_to_self/ ' , { } , follow = True )
# The chain of redirects stops once the cycle is detected.
self . assertRedirects ( response , ' /test_client_regress/redirect_to_self/ ' ,
status_code = 301 , target_status_code = 301 )
self . assertEquals ( len ( response . redirect_chain ) , 2 )
def test_circular_redirect ( self ) :
" Circular redirect chains are caught and escaped "
response = self . client . get ( ' /test_client_regress/circular_redirect_1/ ' , { } , follow = True )
# The chain of redirects will get back to the starting point, but stop there.
self . assertRedirects ( response , ' /test_client_regress/circular_redirect_2/ ' ,
status_code = 301 , target_status_code = 301 )
self . assertEquals ( len ( response . redirect_chain ) , 4 )
def test_redirect_chain_post ( self ) :
" A redirect chain will be followed from an initial POST post "
response = self . client . post ( ' /test_client_regress/redirects/ ' ,
{ ' nothing ' : ' to_send ' } , follow = True )
self . assertRedirects ( response ,
' /test_client_regress/no_template_view/ ' , 301 , 200 )
self . assertEquals ( len ( response . redirect_chain ) , 3 )
def test_redirect_chain_head ( self ) :
" A redirect chain will be followed from an initial HEAD request "
response = self . client . head ( ' /test_client_regress/redirects/ ' ,
{ ' nothing ' : ' to_send ' } , follow = True )
self . assertRedirects ( response ,
' /test_client_regress/no_template_view/ ' , 301 , 200 )
self . assertEquals ( len ( response . redirect_chain ) , 3 )
def test_redirect_chain_options ( self ) :
" A redirect chain will be followed from an initial OPTIONS request "
response = self . client . options ( ' /test_client_regress/redirects/ ' ,
{ ' nothing ' : ' to_send ' } , follow = True )
self . assertRedirects ( response ,
' /test_client_regress/no_template_view/ ' , 301 , 200 )
self . assertEquals ( len ( response . redirect_chain ) , 3 )
def test_redirect_chain_put ( self ) :
" A redirect chain will be followed from an initial PUT request "
response = self . client . put ( ' /test_client_regress/redirects/ ' ,
{ ' nothing ' : ' to_send ' } , follow = True )
self . assertRedirects ( response ,
' /test_client_regress/no_template_view/ ' , 301 , 200 )
self . assertEquals ( len ( response . redirect_chain ) , 3 )
def test_redirect_chain_delete ( self ) :
" A redirect chain will be followed from an initial DELETE request "
response = self . client . delete ( ' /test_client_regress/redirects/ ' ,
{ ' nothing ' : ' to_send ' } , follow = True )
self . assertRedirects ( response ,
' /test_client_regress/no_template_view/ ' , 301 , 200 )
self . assertEquals ( len ( response . redirect_chain ) , 3 )
def test_redirect_chain_on_non_redirect_page ( self ) :
" An assertion is raised if the original page couldn ' t be retrieved as expected "
# This page will redirect with code 301, not 302
response = self . client . get ( ' /test_client/get_view/ ' , follow = True )
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Response didn ' t redirect as expected: Response code was 200 (expected 302) " )
2010-01-22 23:02:02 +08:00
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Response didn ' t redirect as expected: Response code was 200 (expected 302) " )
2009-02-27 21:14:59 +08:00
def test_redirect_on_non_redirect_page ( self ) :
" An assertion is raised if the original page couldn ' t be retrieved as expected "
# This page will redirect with code 301, not 302
response = self . client . get ( ' /test_client/get_view/ ' )
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " Response didn ' t redirect as expected: Response code was 200 (expected 302) " )
2010-01-22 23:02:02 +08:00
try :
self . assertRedirects ( response , ' /test_client/get_view/ ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEquals ( str ( e ) , " abc: Response didn ' t redirect as expected: Response code was 200 (expected 302) " )
2009-02-27 21:14:59 +08:00
2007-05-10 21:46:15 +08:00
class AssertFormErrorTests ( TestCase ) :
def test_unknown_form ( self ) :
" An assertion is raised if the form name is unknown "
post_data = {
' text ' : ' Hello World ' ,
' email ' : ' not an email address ' ,
' value ' : 37 ,
' single ' : ' b ' ,
' multi ' : ( ' b ' , ' c ' , ' e ' )
}
response = self . client . post ( ' /test_client/form_view/ ' , post_data )
self . assertEqual ( response . status_code , 200 )
self . assertTemplateUsed ( response , " Invalid POST Template " )
try :
self . assertFormError ( response , ' wrong_form ' , ' some_field ' , ' Some error. ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " The form ' wrong_form ' was not used to render the response " )
2010-01-22 23:02:02 +08:00
try :
self . assertFormError ( response , ' wrong_form ' , ' some_field ' , ' Some error. ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " abc: The form ' wrong_form ' was not used to render the response " )
2007-11-11 11:55:44 +08:00
2007-05-10 21:46:15 +08:00
def test_unknown_field ( self ) :
" An assertion is raised if the field name is unknown "
post_data = {
' text ' : ' Hello World ' ,
' email ' : ' not an email address ' ,
' value ' : 37 ,
' single ' : ' b ' ,
' multi ' : ( ' b ' , ' c ' , ' e ' )
}
response = self . client . post ( ' /test_client/form_view/ ' , post_data )
self . assertEqual ( response . status_code , 200 )
self . assertTemplateUsed ( response , " Invalid POST Template " )
try :
self . assertFormError ( response , ' form ' , ' some_field ' , ' Some error. ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " The form ' form ' in context 0 does not contain the field ' some_field ' " )
2010-01-22 23:02:02 +08:00
try :
self . assertFormError ( response , ' form ' , ' some_field ' , ' Some error. ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " abc: The form ' form ' in context 0 does not contain the field ' some_field ' " )
2007-11-11 11:55:44 +08:00
2007-05-10 21:46:15 +08:00
def test_noerror_field ( self ) :
" An assertion is raised if the field doesn ' t have any errors "
post_data = {
' text ' : ' Hello World ' ,
' email ' : ' not an email address ' ,
' value ' : 37 ,
' single ' : ' b ' ,
' multi ' : ( ' b ' , ' c ' , ' e ' )
}
response = self . client . post ( ' /test_client/form_view/ ' , post_data )
self . assertEqual ( response . status_code , 200 )
self . assertTemplateUsed ( response , " Invalid POST Template " )
try :
self . assertFormError ( response , ' form ' , ' value ' , ' Some error. ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " The field ' value ' on form ' form ' in context 0 contains no errors " )
2010-01-22 23:02:02 +08:00
try :
self . assertFormError ( response , ' form ' , ' value ' , ' Some error. ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " abc: The field ' value ' on form ' form ' in context 0 contains no errors " )
2007-11-11 11:55:44 +08:00
2007-05-10 21:46:15 +08:00
def test_unknown_error ( self ) :
" An assertion is raised if the field doesn ' t contain the provided error "
post_data = {
' text ' : ' Hello World ' ,
' email ' : ' not an email address ' ,
' value ' : 37 ,
' single ' : ' b ' ,
' multi ' : ( ' b ' , ' c ' , ' e ' )
}
response = self . client . post ( ' /test_client/form_view/ ' , post_data )
self . assertEqual ( response . status_code , 200 )
self . assertTemplateUsed ( response , " Invalid POST Template " )
try :
self . assertFormError ( response , ' form ' , ' email ' , ' Some error. ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " The field ' email ' on form ' form ' in context 0 does not contain the error ' Some error. ' (actual errors: [u ' Enter a valid e-mail address. ' ]) " )
2010-01-22 23:02:02 +08:00
try :
self . assertFormError ( response , ' form ' , ' email ' , ' Some error. ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " abc: The field ' email ' on form ' form ' in context 0 does not contain the error ' Some error. ' (actual errors: [u ' Enter a valid e-mail address. ' ]) " )
2007-11-11 11:55:44 +08:00
2007-09-04 08:48:19 +08:00
def test_unknown_nonfield_error ( self ) :
"""
Checks that an assertion is raised if the form ' s non field errors
doesn ' t contain the provided error.
"""
post_data = {
' text ' : ' Hello World ' ,
' email ' : ' not an email address ' ,
' value ' : 37 ,
' single ' : ' b ' ,
' multi ' : ( ' b ' , ' c ' , ' e ' )
}
response = self . client . post ( ' /test_client/form_view/ ' , post_data )
self . assertEqual ( response . status_code , 200 )
self . assertTemplateUsed ( response , " Invalid POST Template " )
try :
self . assertFormError ( response , ' form ' , None , ' Some error. ' )
except AssertionError , e :
2007-11-11 11:55:44 +08:00
self . assertEqual ( str ( e ) , " The form ' form ' in context 0 does not contain the non-field error ' Some error. ' (actual errors: ) " )
2010-01-22 23:02:02 +08:00
try :
self . assertFormError ( response , ' form ' , None , ' Some error. ' , msg_prefix = ' abc ' )
except AssertionError , e :
self . assertEqual ( str ( e ) , " abc: The form ' form ' in context 0 does not contain the non-field error ' Some error. ' (actual errors: ) " )
2007-05-10 21:46:15 +08:00
2007-09-03 19:21:40 +08:00
class LoginTests ( TestCase ) :
fixtures = [ ' testdata ' ]
def test_login_different_client ( self ) :
" Check that using a different test client doesn ' t violate authentication "
# Create a second client, and log in.
c = Client ( )
login = c . login ( username = ' testclient ' , password = ' password ' )
2007-09-14 17:55:17 +08:00
self . failUnless ( login , ' Could not log in ' )
2007-09-03 19:21:40 +08:00
# Get a redirection page with the second client.
response = c . get ( " /test_client_regress/login_protected_redirect_view/ " )
2007-11-11 11:55:44 +08:00
# At this points, the self.client isn't logged in.
# Check that assertRedirects uses the original client, not the
2007-09-03 19:21:40 +08:00
# default client.
2007-09-14 14:05:54 +08:00
self . assertRedirects ( response , " http://testserver/test_client_regress/get_view/ " )
2008-03-20 14:50:54 +08:00
2010-03-19 13:42:13 +08:00
class SessionEngineTests ( TestCase ) :
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 ) :
" A session engine that modifies the session key can be used to log in "
login = self . client . login ( username = ' testclient ' , password = ' password ' )
self . failUnless ( login , ' Could not log in ' )
# Try to access a login protected page.
response = self . client . get ( " /test_client/login_protected_view/ " )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . context [ ' user ' ] . username , ' testclient ' )
2008-03-20 14:50:54 +08:00
class URLEscapingTests ( TestCase ) :
def test_simple_argument_get ( self ) :
" Get a view that has a simple string argument "
response = self . client . get ( reverse ( ' arg_view ' , args = [ ' Slartibartfast ' ] ) )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' Howdy, Slartibartfast ' )
def test_argument_with_space_get ( self ) :
" Get a view that has a string argument that requires escaping "
response = self . client . get ( reverse ( ' arg_view ' , args = [ ' Arthur Dent ' ] ) )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' Hi, Arthur ' )
def test_simple_argument_post ( self ) :
" Post for a view that has a simple string argument "
response = self . client . post ( reverse ( ' arg_view ' , args = [ ' Slartibartfast ' ] ) )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' Howdy, Slartibartfast ' )
def test_argument_with_space_post ( self ) :
" Post for a view that has a string argument that requires escaping "
response = self . client . post ( reverse ( ' arg_view ' , args = [ ' Arthur Dent ' ] ) )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' Hi, Arthur ' )
2008-06-07 14:25:59 +08:00
class ExceptionTests ( TestCase ) :
fixtures = [ ' testdata.json ' ]
2008-08-02 13:56:57 +08:00
2008-06-07 14:25:59 +08:00
def test_exception_cleared ( self ) :
" #5836 - A stale user exception isn ' t re-raised by the test client. "
2008-03-20 14:50:54 +08:00
2008-06-07 14:25:59 +08:00
login = self . client . login ( username = ' testclient ' , password = ' password ' )
self . failUnless ( login , ' Could not log in ' )
try :
response = self . client . get ( " /test_client_regress/staff_only/ " )
self . fail ( " General users should not be able to visit this page " )
except SuspiciousOperation :
pass
# At this point, an exception has been raised, and should be cleared.
2008-08-02 13:56:57 +08:00
2008-06-07 14:25:59 +08:00
# This next operation should be successful; if it isn't we have a problem.
login = self . client . login ( username = ' staff ' , password = ' password ' )
self . failUnless ( login , ' Could not log in ' )
try :
self . client . get ( " /test_client_regress/staff_only/ " )
except SuspiciousOperation :
self . fail ( " Staff should be able to visit this page " )
2008-11-12 19:22:05 +08:00
2008-08-22 21:59:41 +08:00
class TemplateExceptionTests ( TestCase ) :
def setUp ( self ) :
2009-12-14 20:08:23 +08:00
# Reset the loaders so they don't try to render cached templates.
if loader . template_source_loaders is not None :
for template_loader in loader . template_source_loaders :
if hasattr ( template_loader , ' reset ' ) :
template_loader . reset ( )
2008-08-22 21:59:41 +08:00
self . old_templates = settings . TEMPLATE_DIRS
settings . TEMPLATE_DIRS = ( )
2008-11-12 19:22:05 +08:00
2008-08-22 21:59:41 +08:00
def tearDown ( self ) :
settings . TEMPLATE_DIRS = self . old_templates
2008-11-12 19:22:05 +08:00
2008-08-22 21:59:41 +08:00
def test_no_404_template ( self ) :
2008-11-12 19:22:05 +08:00
" Missing templates are correctly reported by test client "
2008-08-22 21:59:41 +08:00
try :
response = self . client . get ( " /no_such_view/ " )
self . fail ( " Should get error about missing template " )
except TemplateDoesNotExist :
pass
2008-06-30 20:34:29 +08:00
2008-08-22 21:59:41 +08:00
def test_bad_404_template ( self ) :
" Errors found when rendering 404 error templates are re-raised "
settings . TEMPLATE_DIRS = ( os . path . join ( os . path . dirname ( __file__ ) , ' bad_templates ' ) , )
try :
response = self . client . get ( " /no_such_view/ " )
self . fail ( " Should get error about syntax error in template " )
except TemplateSyntaxError :
pass
2008-11-12 19:22:05 +08:00
2008-07-26 11:31:22 +08:00
# We need two different tests to check URLconf substitution - one to check
2008-06-30 20:34:29 +08:00
# it was changed, and another one (without self.urls) to check it was reverted on
# teardown. This pair of tests relies upon the alphabetical ordering of test execution.
class UrlconfSubstitutionTests ( TestCase ) :
urls = ' regressiontests.test_client_regress.urls '
def test_urlconf_was_changed ( self ) :
2009-04-01 00:07:07 +08:00
" TestCase can enforce a custom URLconf on a per-test basis "
2008-06-30 20:34:29 +08:00
url = reverse ( ' arg_view ' , args = [ ' somename ' ] )
self . assertEquals ( url , ' /arg_view/somename/ ' )
# This test needs to run *after* UrlconfSubstitutionTests; the zz prefix in the
# name is to ensure alphabetical ordering.
class zzUrlconfSubstitutionTests ( TestCase ) :
def test_urlconf_was_reverted ( self ) :
" URLconf is reverted to original value after modification in a TestCase "
url = reverse ( ' arg_view ' , args = [ ' somename ' ] )
self . assertEquals ( url , ' /test_client_regress/arg_view/somename/ ' )
2008-08-15 20:08:29 +08:00
2009-03-18 18:46:55 +08:00
class ContextTests ( TestCase ) :
fixtures = [ ' testdata ' ]
def test_single_context ( self ) :
" Context variables can be retrieved from a single context "
response = self . client . get ( " /test_client_regress/request_data/ " , data = { ' foo ' : ' whiz ' } )
self . assertEqual ( response . context . __class__ , Context )
2010-08-07 00:34:34 +08:00
self . assertTrue ( ' get-foo ' in response . context )
2009-03-18 18:46:55 +08:00
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' data ' ] , ' sausage ' )
2010-01-22 23:31:14 +08:00
try :
response . context [ ' does-not-exist ' ]
self . fail ( ' Should not be able to retrieve non-existent key ' )
except KeyError , e :
2010-02-15 04:29:42 +08:00
self . assertEquals ( e . args [ 0 ] , ' does-not-exist ' )
2010-01-22 23:31:14 +08:00
2009-03-18 18:46:55 +08:00
def test_inherited_context ( self ) :
" Context variables can be retrieved from a list of contexts "
response = self . client . get ( " /test_client_regress/request_data_extended/ " , data = { ' foo ' : ' whiz ' } )
self . assertEqual ( response . context . __class__ , ContextList )
self . assertEqual ( len ( response . context ) , 2 )
2010-08-07 00:34:34 +08:00
self . assertTrue ( ' get-foo ' in response . context )
2009-03-18 18:46:55 +08:00
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' data ' ] , ' bacon ' )
2010-01-22 23:31:14 +08:00
try :
response . context [ ' does-not-exist ' ]
self . fail ( ' Should not be able to retrieve non-existent key ' )
except KeyError , e :
2010-02-15 04:29:42 +08:00
self . assertEquals ( e . args [ 0 ] , ' does-not-exist ' )
2010-01-22 23:31:14 +08:00
2008-08-15 20:08:29 +08:00
class SessionTests ( TestCase ) :
fixtures = [ ' testdata.json ' ]
def test_session ( self ) :
" The session isn ' t lost if a user logs in "
# The session doesn't exist to start.
response = self . client . get ( ' /test_client_regress/check_session/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' NO ' )
# This request sets a session variable.
response = self . client . get ( ' /test_client_regress/set_session/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' set_session ' )
# Check that the session has been modified
response = self . client . get ( ' /test_client_regress/check_session/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' YES ' )
# Log in
login = self . client . login ( username = ' testclient ' , password = ' password ' )
self . failUnless ( login , ' Could not log in ' )
# Session should still contain the modified value
response = self . client . get ( ' /test_client_regress/check_session/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' YES ' )
2008-10-07 17:23:40 +08:00
2009-03-31 06:52:48 +08:00
def test_logout ( self ) :
""" Logout should work whether the user is logged in or not (#9978). """
self . client . logout ( )
login = self . client . login ( username = ' testclient ' , password = ' password ' )
self . failUnless ( login , ' Could not log in ' )
self . client . logout ( )
self . client . logout ( )
2008-10-07 17:23:40 +08:00
class RequestMethodTests ( TestCase ) :
def test_get ( self ) :
" Request a view via request method GET "
response = self . client . get ( ' /test_client_regress/request_methods/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: GET ' )
def test_post ( self ) :
" Request a view via request method POST "
response = self . client . post ( ' /test_client_regress/request_methods/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: POST ' )
def test_head ( self ) :
" Request a view via request method HEAD "
response = self . client . head ( ' /test_client_regress/request_methods/ ' )
self . assertEqual ( response . status_code , 200 )
# A HEAD request doesn't return any content.
self . assertNotEqual ( response . content , ' request method: HEAD ' )
self . assertEqual ( response . content , ' ' )
def test_options ( self ) :
" Request a view via request method OPTIONS "
response = self . client . options ( ' /test_client_regress/request_methods/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: OPTIONS ' )
def test_put ( self ) :
" Request a view via request method PUT "
response = self . client . put ( ' /test_client_regress/request_methods/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: PUT ' )
def test_delete ( self ) :
" Request a view via request method DELETE "
response = self . client . delete ( ' /test_client_regress/request_methods/ ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: DELETE ' )
2008-11-12 19:22:05 +08:00
2009-10-26 23:02:54 +08:00
class RequestMethodStringDataTests ( TestCase ) :
def test_post ( self ) :
" Request a view with string data via request method POST "
# Regression test for #11371
data = u ' { " test " : " json " } '
response = self . client . post ( ' /test_client_regress/request_methods/ ' , data = data , content_type = ' application/json ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: POST ' )
def test_put ( self ) :
" Request a view with string data via request method PUT "
# Regression test for #11371
data = u ' { " test " : " json " } '
response = self . client . put ( ' /test_client_regress/request_methods/ ' , data = data , content_type = ' application/json ' )
self . assertEqual ( response . status_code , 200 )
self . assertEqual ( response . content , ' request method: PUT ' )
2008-11-12 19:22:05 +08:00
class QueryStringTests ( TestCase ) :
def test_get_like_requests ( self ) :
for method_name in ( ' get ' , ' head ' , ' options ' , ' put ' , ' delete ' ) :
# A GET-like request can pass a query string as data
method = getattr ( self . client , method_name )
response = method ( " /test_client_regress/request_data/ " , data = { ' foo ' : ' whiz ' } )
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' whiz ' )
# A GET-like request can pass a query string as part of the URL
response = method ( " /test_client_regress/request_data/?foo=whiz " )
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' whiz ' )
# Data provided in the URL to a GET-like request is overridden by actual form data
response = method ( " /test_client_regress/request_data/?foo=whiz " , data = { ' foo ' : ' bang ' } )
self . assertEqual ( response . context [ ' get-foo ' ] , ' bang ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' bang ' )
response = method ( " /test_client_regress/request_data/?foo=whiz " , data = { ' bar ' : ' bang ' } )
self . assertEqual ( response . context [ ' get-foo ' ] , None )
self . assertEqual ( response . context [ ' get-bar ' ] , ' bang ' )
self . assertEqual ( response . context [ ' request-foo ' ] , None )
self . assertEqual ( response . context [ ' request-bar ' ] , ' bang ' )
def test_post_like_requests ( self ) :
# A POST-like request can pass a query string as data
response = self . client . post ( " /test_client_regress/request_data/ " , data = { ' foo ' : ' whiz ' } )
self . assertEqual ( response . context [ ' get-foo ' ] , None )
self . assertEqual ( response . context [ ' post-foo ' ] , ' whiz ' )
# A POST-like request can pass a query string as part of the URL
response = self . client . post ( " /test_client_regress/request_data/?foo=whiz " )
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' post-foo ' ] , None )
self . assertEqual ( response . context [ ' request-foo ' ] , ' whiz ' )
# POST data provided in the URL augments actual form data
response = self . client . post ( " /test_client_regress/request_data/?foo=whiz " , data = { ' foo ' : ' bang ' } )
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' post-foo ' ] , ' bang ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' bang ' )
response = self . client . post ( " /test_client_regress/request_data/?foo=whiz " , data = { ' bar ' : ' bang ' } )
self . assertEqual ( response . context [ ' get-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' get-bar ' ] , None )
self . assertEqual ( response . context [ ' post-foo ' ] , None )
self . assertEqual ( response . context [ ' post-bar ' ] , ' bang ' )
self . assertEqual ( response . context [ ' request-foo ' ] , ' whiz ' )
self . assertEqual ( response . context [ ' request-bar ' ] , ' bang ' )
2009-04-11 17:20:10 +08:00
class UnicodePayloadTests ( TestCase ) :
def test_simple_unicode_payload ( self ) :
" A simple ASCII-only unicode JSON document can be POSTed "
# Regression test for #10571
json = u ' { " english " : " mountain pass " } '
response = self . client . post ( " /test_client_regress/parse_unicode_json/ " , json ,
content_type = " application/json " )
self . assertEqual ( response . content , json )
def test_unicode_payload_utf8 ( self ) :
" A non-ASCII unicode data encoded as UTF-8 can be POSTed "
# Regression test for #10571
json = u ' { " dog " : " собака " } '
response = self . client . post ( " /test_client_regress/parse_unicode_json/ " , json ,
content_type = " application/json; charset=utf-8 " )
self . assertEqual ( response . content , json . encode ( ' utf-8 ' ) )
def test_unicode_payload_utf16 ( self ) :
" A non-ASCII unicode data encoded as UTF-16 can be POSTed "
# Regression test for #10571
json = u ' { " dog " : " собака " } '
response = self . client . post ( " /test_client_regress/parse_unicode_json/ " , json ,
content_type = " application/json; charset=utf-16 " )
self . assertEqual ( response . content , json . encode ( ' utf-16 ' ) )
def test_unicode_payload_non_utf ( self ) :
" A non-ASCII unicode data as a non-UTF based encoding can be POSTed "
#Regression test for #10571
json = u ' { " dog " : " собака " } '
response = self . client . post ( " /test_client_regress/parse_unicode_json/ " , json ,
content_type = " application/json; charset=koi8-r " )
self . assertEqual ( response . content , json . encode ( ' koi8-r ' ) )