12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418 |
- """
- Regression tests for the Test Client, especially the customized assertions.
- """
- from __future__ import unicode_literals
- import itertools
- import os
- from django.contrib.auth.models import User
- from django.contrib.auth.signals import user_logged_in, user_logged_out
- from django.http import HttpResponse
- from django.template import (
- Context, RequestContext, TemplateSyntaxError, engines,
- )
- from django.template.response import SimpleTemplateResponse
- from django.test import (
- Client, SimpleTestCase, TestCase, ignore_warnings, modify_settings,
- override_settings,
- )
- from django.test.client import RedirectCycleError, RequestFactory, encode_file
- from django.test.utils import ContextList, str_prefix
- from django.urls import NoReverseMatch, reverse
- from django.utils._os import upath
- from django.utils.deprecation import RemovedInDjango20Warning
- from django.utils.translation import ugettext_lazy
- from .models import CustomUser
- from .views import CustomTestException
- class TestDataMixin(object):
- @classmethod
- def setUpTestData(cls):
- cls.u1 = User.objects.create_user(username='testclient', password='password')
- cls.staff = User.objects.create_user(username='staff', password='password', is_staff=True)
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class AssertContainsTests(SimpleTestCase):
- def test_contains(self):
- "Responses can be inspected for content, including counting repeated substrings"
- response = self.client.get('/no_template_view/')
- self.assertNotContains(response, 'never')
- self.assertContains(response, 'never', 0)
- self.assertContains(response, 'once')
- self.assertContains(response, 'once', 1)
- self.assertContains(response, 'twice')
- self.assertContains(response, 'twice', 2)
- try:
- self.assertContains(response, 'text', status_code=999)
- except AssertionError as e:
- self.assertIn("Couldn't retrieve content: Response code was 200 (expected 999)", str(e))
- try:
- self.assertContains(response, 'text', status_code=999, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Couldn't retrieve content: Response code was 200 (expected 999)", str(e))
- try:
- self.assertNotContains(response, 'text', status_code=999)
- except AssertionError as e:
- self.assertIn("Couldn't retrieve content: Response code was 200 (expected 999)", str(e))
- try:
- self.assertNotContains(response, 'text', status_code=999, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Couldn't retrieve content: Response code was 200 (expected 999)", str(e))
- try:
- self.assertNotContains(response, 'once')
- except AssertionError as e:
- self.assertIn("Response should not contain 'once'", str(e))
- try:
- self.assertNotContains(response, 'once', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Response should not contain 'once'", str(e))
- try:
- self.assertContains(response, 'never', 1)
- except AssertionError as e:
- self.assertIn("Found 0 instances of 'never' in response (expected 1)", str(e))
- try:
- self.assertContains(response, 'never', 1, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Found 0 instances of 'never' in response (expected 1)", str(e))
- try:
- self.assertContains(response, 'once', 0)
- except AssertionError as e:
- self.assertIn("Found 1 instances of 'once' in response (expected 0)", str(e))
- try:
- self.assertContains(response, 'once', 0, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Found 1 instances of 'once' in response (expected 0)", str(e))
- try:
- self.assertContains(response, 'once', 2)
- except AssertionError as e:
- self.assertIn("Found 1 instances of 'once' in response (expected 2)", str(e))
- try:
- self.assertContains(response, 'once', 2, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Found 1 instances of 'once' in response (expected 2)", str(e))
- try:
- self.assertContains(response, 'twice', 1)
- except AssertionError as e:
- self.assertIn("Found 2 instances of 'twice' in response (expected 1)", str(e))
- try:
- self.assertContains(response, 'twice', 1, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Found 2 instances of 'twice' in response (expected 1)", str(e))
- try:
- self.assertContains(response, 'thrice')
- except AssertionError as e:
- self.assertIn("Couldn't find 'thrice' in response", str(e))
- try:
- self.assertContains(response, 'thrice', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Couldn't find 'thrice' in response", str(e))
- try:
- self.assertContains(response, 'thrice', 3)
- except AssertionError as e:
- self.assertIn("Found 0 instances of 'thrice' in response (expected 3)", str(e))
- try:
- self.assertContains(response, 'thrice', 3, msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Found 0 instances of 'thrice' in response (expected 3)", str(e))
- def test_unicode_contains(self):
- "Unicode characters can be found in template context"
-
- r = self.client.get('/check_unicode/')
- self.assertContains(r, 'さかき')
- self.assertContains(r, b'\xe5\xb3\xa0'.decode('utf-8'))
- def test_unicode_not_contains(self):
- "Unicode characters can be searched for, and not found in template context"
-
- r = self.client.get('/check_unicode/')
- self.assertNotContains(r, 'はたけ')
- self.assertNotContains(r, b'\xe3\x81\xaf\xe3\x81\x9f\xe3\x81\x91'.decode('utf-8'))
- def test_binary_contains(self):
- r = self.client.get('/check_binary/')
- self.assertContains(r, b'%PDF-1.4\r\n%\x93\x8c\x8b\x9e')
- with self.assertRaises(AssertionError):
- self.assertContains(r, b'%PDF-1.4\r\n%\x93\x8c\x8b\x9e', count=2)
- def test_binary_not_contains(self):
- r = self.client.get('/check_binary/')
- self.assertNotContains(r, b'%ODF-1.4\r\n%\x93\x8c\x8b\x9e')
- with self.assertRaises(AssertionError):
- self.assertNotContains(r, b'%PDF-1.4\r\n%\x93\x8c\x8b\x9e')
- def test_nontext_contains(self):
- r = self.client.get('/no_template_view/')
- self.assertContains(r, ugettext_lazy('once'))
- def test_nontext_not_contains(self):
- r = self.client.get('/no_template_view/')
- self.assertNotContains(r, ugettext_lazy('never'))
- def test_assert_contains_renders_template_response(self):
- """
- An unrendered SimpleTemplateResponse may be used in assertContains().
- """
- template = engines['django'].from_string('Hello')
- response = SimpleTemplateResponse(template)
- self.assertContains(response, 'Hello')
- def test_assert_contains_using_non_template_response(self):
- """ auto-rendering does not affect responses that aren't
- instances (or subclasses) of SimpleTemplateResponse.
- Refs #15826.
- """
- response = HttpResponse('Hello')
- self.assertContains(response, 'Hello')
- def test_assert_not_contains_renders_template_response(self):
- """
- An unrendered SimpleTemplateResponse may be used in assertNotContains().
- """
- template = engines['django'].from_string('Hello')
- response = SimpleTemplateResponse(template)
- self.assertNotContains(response, 'Bye')
- def test_assert_not_contains_using_non_template_response(self):
- """
- auto-rendering does not affect responses that aren't instances (or
- subclasses) of SimpleTemplateResponse.
- """
- response = HttpResponse('Hello')
- self.assertNotContains(response, 'Bye')
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class AssertTemplateUsedTests(TestDataMixin, TestCase):
- def test_no_context(self):
- "Template usage assertions work then templates aren't in use"
- response = self.client.get('/no_template_view/')
-
- self.assertTemplateNotUsed(response, 'GET Template')
- try:
- self.assertTemplateUsed(response, 'GET Template')
- except AssertionError as e:
- self.assertIn("No templates used to render the response", str(e))
- try:
- self.assertTemplateUsed(response, 'GET Template', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: No templates used to render the response", str(e))
- with self.assertRaises(AssertionError) as context:
- self.assertTemplateUsed(response, 'GET Template', count=2)
- self.assertIn(
- "No templates used to render the response",
- str(context.exception))
- def test_single_context(self):
- "Template assertions work when there is a single context"
- response = self.client.get('/post_view/', {})
- try:
- self.assertTemplateNotUsed(response, 'Empty GET Template')
- except AssertionError as e:
- self.assertIn("Template 'Empty GET Template' was used unexpectedly in rendering the response", str(e))
- try:
- self.assertTemplateNotUsed(response, 'Empty GET Template', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Template 'Empty GET Template' was used unexpectedly in rendering the response", str(e))
- try:
- self.assertTemplateUsed(response, 'Empty POST Template')
- except AssertionError as e:
- self.assertIn(
- "Template 'Empty POST Template' was not a template used to "
- "render the response. Actual template(s) used: Empty GET Template",
- str(e)
- )
- try:
- self.assertTemplateUsed(response, 'Empty POST Template', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn(
- "abc: Template 'Empty POST Template' was not a template used "
- "to render the response. Actual template(s) used: Empty GET Template",
- str(e)
- )
- with self.assertRaises(AssertionError) as context:
- self.assertTemplateUsed(response, 'Empty GET Template', count=2)
- self.assertIn(
- "Template 'Empty GET Template' was expected to be rendered 2 "
- "time(s) but was actually rendered 1 time(s).",
- str(context.exception))
- with self.assertRaises(AssertionError) as context:
- self.assertTemplateUsed(
- response, 'Empty GET Template', msg_prefix='abc', count=2)
- self.assertIn(
- "abc: Template 'Empty GET Template' was expected to be rendered 2 "
- "time(s) but was actually rendered 1 time(s).",
- str(context.exception))
- 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('/form_view_with_template/', post_data)
- self.assertContains(response, 'POST data OK')
- try:
- self.assertTemplateNotUsed(response, "form_view.html")
- except AssertionError as e:
- self.assertIn("Template 'form_view.html' was used unexpectedly in rendering the response", str(e))
- try:
- self.assertTemplateNotUsed(response, 'base.html')
- except AssertionError as e:
- self.assertIn("Template 'base.html' was used unexpectedly in rendering the response", str(e))
- try:
- self.assertTemplateUsed(response, "Valid POST Template")
- except AssertionError as e:
- self.assertIn(
- "Template 'Valid POST Template' was not a template used to "
- "render the response. Actual template(s) used: form_view.html, base.html",
- str(e)
- )
- with self.assertRaises(AssertionError) as context:
- self.assertTemplateUsed(response, 'base.html', count=2)
- self.assertIn(
- "Template 'base.html' was expected to be rendered 2 "
- "time(s) but was actually rendered 1 time(s).",
- str(context.exception))
- def test_template_rendered_multiple_times(self):
- """Template assertions work when a template is rendered multiple times."""
- response = self.client.get('/render_template_multiple_times/')
- self.assertTemplateUsed(response, 'base.html', count=2)
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class AssertRedirectsTests(SimpleTestCase):
- def test_redirect_page(self):
- "An assertion is raised if the original page couldn't be retrieved as expected"
-
- response = self.client.get('/permanent_redirect_view/')
- try:
- self.assertRedirects(response, '/get_view/')
- except AssertionError as e:
- self.assertIn("Response didn't redirect as expected: Response code was 301 (expected 302)", str(e))
- try:
- self.assertRedirects(response, '/get_view/', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Response didn't redirect as expected: Response code was 301 (expected 302)", str(e))
- def test_lost_query(self):
- "An assertion is raised if the redirect location doesn't preserve GET parameters"
- response = self.client.get('/redirect_view/', {'var': 'value'})
- try:
- self.assertRedirects(response, '/get_view/')
- except AssertionError as e:
- self.assertIn("Response redirected to '/get_view/?var=value', expected '/get_view/'", str(e))
- try:
- self.assertRedirects(response, '/get_view/', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Response redirected to '/get_view/?var=value', expected '/get_view/'", str(e))
- def test_incorrect_target(self):
- "An assertion is raised if the response redirects to another target"
- response = self.client.get('/permanent_redirect_view/')
- try:
-
- self.assertRedirects(response, '/some_view/')
- except AssertionError as e:
- self.assertIn("Response didn't redirect as expected: Response code was 301 (expected 302)", str(e))
- def test_target_page(self):
- "An assertion is raised if the response redirect target cannot be retrieved as expected"
- response = self.client.get('/double_redirect_view/')
- try:
-
- self.assertRedirects(response, 'http://testserver/permanent_redirect_view/')
- except AssertionError as e:
- self.assertIn(
- "Couldn't retrieve redirection page '/permanent_redirect_view/': "
- "response code was 301 (expected 200)",
- str(e)
- )
- try:
-
- self.assertRedirects(response, 'http://testserver/permanent_redirect_view/', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn(
- "abc: Couldn't retrieve redirection page '/permanent_redirect_view/': "
- "response code was 301 (expected 200)",
- str(e)
- )
- def test_redirect_chain(self):
- "You can follow a redirect chain of multiple redirects"
- response = self.client.get('/redirects/further/more/', {}, follow=True)
- self.assertRedirects(response, '/no_template_view/', status_code=302, target_status_code=200)
- self.assertEqual(len(response.redirect_chain), 1)
- self.assertEqual(response.redirect_chain[0], ('/no_template_view/', 302))
- def test_multiple_redirect_chain(self):
- "You can follow a redirect chain of multiple redirects"
- response = self.client.get('/redirects/', {}, follow=True)
- self.assertRedirects(response, '/no_template_view/', status_code=302, target_status_code=200)
- self.assertEqual(len(response.redirect_chain), 3)
- self.assertEqual(response.redirect_chain[0], ('/redirects/further/', 302))
- self.assertEqual(response.redirect_chain[1], ('/redirects/further/more/', 302))
- self.assertEqual(response.redirect_chain[2], ('/no_template_view/', 302))
- def test_redirect_chain_to_non_existent(self):
- "You can follow a chain to a non-existent view"
- response = self.client.get('/redirect_to_non_existent_view2/', {}, follow=True)
- self.assertRedirects(response, '/non_existent_view/', status_code=302, target_status_code=404)
- def test_redirect_chain_to_self(self):
- "Redirections to self are caught and escaped"
- with self.assertRaises(RedirectCycleError) as context:
- self.client.get('/redirect_to_self/', {}, follow=True)
- response = context.exception.last_response
-
- self.assertRedirects(response, '/redirect_to_self/', status_code=302, target_status_code=302)
- self.assertEqual(len(response.redirect_chain), 2)
- def test_redirect_to_self_with_changing_query(self):
- "Redirections don't loop forever even if query is changing"
- with self.assertRaises(RedirectCycleError):
- self.client.get('/redirect_to_self_with_changing_query_view/', {'counter': '0'}, follow=True)
- def test_circular_redirect(self):
- "Circular redirect chains are caught and escaped"
- with self.assertRaises(RedirectCycleError) as context:
- self.client.get('/circular_redirect_1/', {}, follow=True)
- response = context.exception.last_response
-
- self.assertRedirects(response, '/circular_redirect_2/', status_code=302, target_status_code=302)
- self.assertEqual(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('/redirects/', {'nothing': 'to_send'}, follow=True)
- self.assertRedirects(response, '/no_template_view/', 302, 200)
- self.assertEqual(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('/redirects/', {'nothing': 'to_send'}, follow=True)
- self.assertRedirects(response, '/no_template_view/', 302, 200)
- self.assertEqual(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('/redirects/', follow=True)
- self.assertRedirects(response, '/no_template_view/', 302, 200)
- self.assertEqual(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('/redirects/', follow=True)
- self.assertRedirects(response, '/no_template_view/', 302, 200)
- self.assertEqual(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('/redirects/', follow=True)
- self.assertRedirects(response, '/no_template_view/', 302, 200)
- self.assertEqual(len(response.redirect_chain), 3)
- @modify_settings(ALLOWED_HOSTS={'append': 'otherserver'})
- def test_redirect_to_different_host(self):
- "The test client will preserve scheme, host and port changes"
- response = self.client.get('/redirect_other_host/', follow=True)
- self.assertRedirects(
- response, 'https://otherserver:8443/no_template_view/',
- status_code=302, target_status_code=200
- )
-
-
- self.assertEqual(response.request.get('wsgi.url_scheme'), 'https')
- self.assertEqual(response.request.get('SERVER_NAME'), 'otherserver')
- self.assertEqual(response.request.get('SERVER_PORT'), '8443')
-
- response = self.client.get('/redirect_other_host/', follow=False)
- self.assertRedirects(
- response, 'https://otherserver:8443/no_template_view/',
- status_code=302, target_status_code=200
- )
- def test_redirect_chain_on_non_redirect_page(self):
- "An assertion is raised if the original page couldn't be retrieved as expected"
-
- response = self.client.get('/get_view/', follow=True)
- try:
- self.assertRedirects(response, '/get_view/')
- except AssertionError as e:
- self.assertIn("Response didn't redirect as expected: Response code was 200 (expected 302)", str(e))
- try:
- self.assertRedirects(response, '/get_view/', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Response didn't redirect as expected: Response code was 200 (expected 302)", str(e))
- def test_redirect_on_non_redirect_page(self):
- "An assertion is raised if the original page couldn't be retrieved as expected"
-
- response = self.client.get('/get_view/')
- try:
- self.assertRedirects(response, '/get_view/')
- except AssertionError as e:
- self.assertIn("Response didn't redirect as expected: Response code was 200 (expected 302)", str(e))
- try:
- self.assertRedirects(response, '/get_view/', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: Response didn't redirect as expected: Response code was 200 (expected 302)", str(e))
- def test_redirect_scheme(self):
- "An assertion is raised if the response doesn't have the scheme specified in expected_url"
-
- for follow, secure in itertools.product([True, False], repeat=2):
-
- response = self.client.get('/https_redirect_view/', follow=follow, secure=secure)
-
- self.assertRedirects(response, 'https://testserver/secure_view/', status_code=302)
- with self.assertRaises(AssertionError):
- self.assertRedirects(response, 'http://testserver/secure_view/', status_code=302)
- @ignore_warnings(category=RemovedInDjango20Warning)
- def test_full_path_in_expected_urls(self):
- """
- Specifying a full URL as assertRedirects expected_url still
- work as backwards compatible behavior until Django 2.0.
- """
- response = self.client.get('/redirect_view/')
- self.assertRedirects(response, 'http://testserver/get_view/')
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class AssertFormErrorTests(SimpleTestCase):
- 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('/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 as e:
- self.assertIn("The form 'wrong_form' was not used to render the response", str(e))
- try:
- self.assertFormError(response, 'wrong_form', 'some_field', 'Some error.', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: The form 'wrong_form' was not used to render the response", str(e))
- 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('/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 as e:
- self.assertIn("The form 'form' in context 0 does not contain the field 'some_field'", str(e))
- try:
- self.assertFormError(response, 'form', 'some_field', 'Some error.', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: The form 'form' in context 0 does not contain the field 'some_field'", str(e))
- 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('/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 as e:
- self.assertIn("The field 'value' on form 'form' in context 0 contains no errors", str(e))
- try:
- self.assertFormError(response, 'form', 'value', 'Some error.', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn("abc: The field 'value' on form 'form' in context 0 contains no errors", str(e))
- 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('/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 as e:
- self.assertIn(
- str_prefix(
- "The field 'email' on form 'form' in context 0 does not "
- "contain the error 'Some error.' (actual errors: "
- "[%(_)s'Enter a valid email address.'])"
- ), str(e)
- )
- try:
- self.assertFormError(response, 'form', 'email', 'Some error.', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn(
- str_prefix(
- "abc: The field 'email' on form 'form' in context 0 does "
- "not contain the error 'Some error.' (actual errors: "
- "[%(_)s'Enter a valid email address.'])",
- ), str(e)
- )
- def test_unknown_nonfield_error(self):
- """
- 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('/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 as e:
- self.assertIn(
- "The form 'form' in context 0 does not contain the non-field "
- "error 'Some error.' (actual errors: )",
- str(e)
- )
- try:
- self.assertFormError(response, 'form', None, 'Some error.', msg_prefix='abc')
- except AssertionError as e:
- self.assertIn(
- "abc: The form 'form' in context 0 does not contain the "
- "non-field error 'Some error.' (actual errors: )",
- str(e)
- )
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class AssertFormsetErrorTests(SimpleTestCase):
- msg_prefixes = [("", {}), ("abc: ", {"msg_prefix": "abc"})]
- def setUp(self):
- """Makes response object for testing field and non-field errors"""
-
- self.response_form_errors = self.getResponse({
- 'form-TOTAL_FORMS': '2',
- 'form-INITIAL_FORMS': '2',
- 'form-0-text': 'Raise non-field error',
- 'form-0-email': 'not an email address',
- 'form-0-value': 37,
- 'form-0-single': 'b',
- 'form-0-multi': ('b', 'c', 'e'),
- 'form-1-text': 'Hello World',
- 'form-1-email': 'email@domain.com',
- 'form-1-value': 37,
- 'form-1-single': 'b',
- 'form-1-multi': ('b', 'c', 'e'),
- })
-
- self.response_nonform_errors = self.getResponse({
- 'form-TOTAL_FORMS': '2',
- 'form-INITIAL_FORMS': '2',
- 'form-0-text': 'Hello World',
- 'form-0-email': 'email@domain.com',
- 'form-0-value': 37,
- 'form-0-single': 'b',
- 'form-0-multi': ('b', 'c', 'e'),
- 'form-1-text': 'Hello World',
- 'form-1-email': 'email@domain.com',
- 'form-1-value': 37,
- 'form-1-single': 'b',
- 'form-1-multi': ('b', 'c', 'e'),
- })
- def getResponse(self, post_data):
- response = self.client.post('/formset_view/', post_data)
- self.assertEqual(response.status_code, 200)
- self.assertTemplateUsed(response, "Invalid POST Template")
- return response
- def test_unknown_formset(self):
- "An assertion is raised if the formset name is unknown"
- for prefix, kwargs in self.msg_prefixes:
- msg = prefix + "The formset 'wrong_formset' was not used to render the response"
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(
- self.response_form_errors,
- 'wrong_formset', 0, 'Some_field', 'Some error.', **kwargs
- )
- def test_unknown_field(self):
- "An assertion is raised if the field name is unknown"
- for prefix, kwargs in self.msg_prefixes:
- msg = prefix + "The formset 'my_formset', form 0 in context 0 does not contain the field 'Some_field'"
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(
- self.response_form_errors,
- 'my_formset', 0, 'Some_field', 'Some error.', **kwargs
- )
- def test_no_error_field(self):
- "An assertion is raised if the field doesn't have any errors"
- for prefix, kwargs in self.msg_prefixes:
- msg = prefix + "The field 'value' on formset 'my_formset', form 1 in context 0 contains no errors"
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(self.response_form_errors, 'my_formset', 1, 'value', 'Some error.', **kwargs)
- def test_unknown_error(self):
- "An assertion is raised if the field doesn't contain the specified error"
- for prefix, kwargs in self.msg_prefixes:
- msg = str_prefix(
- prefix + "The field 'email' on formset 'my_formset', form 0 "
- "in context 0 does not contain the error 'Some error.' "
- "(actual errors: [%(_)s'Enter a valid email address.'])"
- )
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(self.response_form_errors, 'my_formset', 0, 'email', 'Some error.', **kwargs)
- def test_field_error(self):
- "No assertion is raised if the field contains the provided error"
- error_msg = ['Enter a valid email address.']
- for prefix, kwargs in self.msg_prefixes:
- self.assertFormsetError(self.response_form_errors, 'my_formset', 0, 'email', error_msg, **kwargs)
- def test_no_nonfield_error(self):
- "An assertion is raised if the formsets non-field errors doesn't contain any errors."
- for prefix, kwargs in self.msg_prefixes:
- msg = prefix + "The formset 'my_formset', form 1 in context 0 does not contain any non-field errors."
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(self.response_form_errors, 'my_formset', 1, None, 'Some error.', **kwargs)
- def test_unknown_nonfield_error(self):
- "An assertion is raised if the formsets non-field errors doesn't contain the provided error."
- for prefix, kwargs in self.msg_prefixes:
- msg = str_prefix(
- prefix + "The formset 'my_formset', form 0 in context 0 does not "
- "contain the non-field error 'Some error.' (actual errors: "
- "[%(_)s'Non-field error.'])"
- )
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(self.response_form_errors, 'my_formset', 0, None, 'Some error.', **kwargs)
- def test_nonfield_error(self):
- "No assertion is raised if the formsets non-field errors contains the provided error."
- for prefix, kwargs in self.msg_prefixes:
- self.assertFormsetError(self.response_form_errors, 'my_formset', 0, None, 'Non-field error.', **kwargs)
- def test_no_nonform_error(self):
- "An assertion is raised if the formsets non-form errors doesn't contain any errors."
- for prefix, kwargs in self.msg_prefixes:
- msg = prefix + "The formset 'my_formset' in context 0 does not contain any non-form errors."
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(self.response_form_errors, 'my_formset', None, None, 'Some error.', **kwargs)
- def test_unknown_nonform_error(self):
- "An assertion is raised if the formsets non-form errors doesn't contain the provided error."
- for prefix, kwargs in self.msg_prefixes:
- msg = str_prefix(
- prefix +
- "The formset 'my_formset' in context 0 does not contain the "
- "non-form error 'Some error.' (actual errors: [%(_)s'Forms "
- "in a set must have distinct email addresses.'])"
- )
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(
- self.response_nonform_errors,
- 'my_formset', None, None, 'Some error.', **kwargs
- )
- def test_nonform_error(self):
- "No assertion is raised if the formsets non-form errors contains the provided error."
- msg = 'Forms in a set must have distinct email addresses.'
- for prefix, kwargs in self.msg_prefixes:
- self.assertFormsetError(self.response_nonform_errors, 'my_formset', None, None, msg, **kwargs)
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class LoginTests(TestDataMixin, TestCase):
- def test_login_different_client(self):
- "Using a different test client doesn't violate authentication"
-
- c = Client()
- login = c.login(username='testclient', password='password')
- self.assertTrue(login, 'Could not log in')
-
- response = c.get("/login_protected_redirect_view/")
-
-
- self.assertRedirects(response, "/get_view/")
- @override_settings(
- SESSION_ENGINE='test_client_regress.session',
- ROOT_URLCONF='test_client_regress.urls',
- )
- class SessionEngineTests(TestDataMixin, TestCase):
- 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.assertTrue(login, 'Could not log in')
-
- response = self.client.get("/login_protected_view/")
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.context['user'].username, 'testclient')
- @override_settings(ROOT_URLCONF='test_client_regress.urls',)
- class URLEscapingTests(SimpleTestCase):
- 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, b'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, b'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, b'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, b'Hi, Arthur')
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class ExceptionTests(TestDataMixin, TestCase):
- def test_exception_cleared(self):
- "#5836 - A stale user exception isn't re-raised by the test client."
- login = self.client.login(username='testclient', password='password')
- self.assertTrue(login, 'Could not log in')
- with self.assertRaises(CustomTestException):
- self.client.get("/staff_only/")
-
-
- login = self.client.login(username='staff', password='password')
- self.assertTrue(login, 'Could not log in')
- self.client.get("/staff_only/")
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class TemplateExceptionTests(SimpleTestCase):
- @override_settings(TEMPLATES=[{
- 'BACKEND': 'django.template.backends.django.DjangoTemplates',
- 'DIRS': [os.path.join(os.path.dirname(upath(__file__)), 'bad_templates')],
- }])
- def test_bad_404_template(self):
- "Errors found when rendering 404 error templates are re-raised"
- with self.assertRaises(TemplateSyntaxError):
- self.client.get("/no_such_view/")
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class UrlconfSubstitutionTests(SimpleTestCase):
- def test_urlconf_was_changed(self):
- "TestCase can enforce a custom URLconf on a per-test basis"
- url = reverse('arg_view', args=['somename'])
- self.assertEqual(url, '/arg_view/somename/')
- class zzUrlconfSubstitutionTests(SimpleTestCase):
- def test_urlconf_was_reverted(self):
- """URLconf is reverted to original value after modification in a TestCase
- This will not find a match as the default ROOT_URLCONF is empty.
- """
- with self.assertRaises(NoReverseMatch):
- reverse('arg_view', args=['somename'])
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class ContextTests(TestDataMixin, TestCase):
- def test_single_context(self):
- "Context variables can be retrieved from a single context"
- response = self.client.get("/request_data/", data={'foo': 'whiz'})
- self.assertIsInstance(response.context, RequestContext)
- self.assertIn('get-foo', response.context)
- self.assertEqual(response.context['get-foo'], 'whiz')
- self.assertEqual(response.context['data'], 'sausage')
- with self.assertRaisesMessage(KeyError, 'does-not-exist'):
- response.context['does-not-exist']
- def test_inherited_context(self):
- "Context variables can be retrieved from a list of contexts"
- response = self.client.get("/request_data_extended/", data={'foo': 'whiz'})
- self.assertEqual(response.context.__class__, ContextList)
- self.assertEqual(len(response.context), 2)
- self.assertIn('get-foo', response.context)
- self.assertEqual(response.context['get-foo'], 'whiz')
- self.assertEqual(response.context['data'], 'bacon')
- with self.assertRaises(KeyError) as cm:
- response.context['does-not-exist']
- self.assertEqual(cm.exception.args[0], 'does-not-exist')
- def test_contextlist_keys(self):
- c1 = Context()
- c1.update({'hello': 'world', 'goodbye': 'john'})
- c1.update({'hello': 'dolly', 'dolly': 'parton'})
- c2 = Context()
- c2.update({'goodbye': 'world', 'python': 'rocks'})
- c2.update({'goodbye': 'dolly'})
- k = ContextList([c1, c2])
-
-
- self.assertEqual({'None', 'True', 'False', 'hello', 'goodbye', 'python', 'dolly'}, k.keys())
- def test_15368(self):
-
-
-
- with self.settings(TEMPLATES=[{
- 'BACKEND': 'django.template.backends.django.DjangoTemplates',
- 'APP_DIRS': True,
- 'OPTIONS': {
- 'context_processors': [
- 'test_client_regress.context_processors.special',
- ],
- },
- }]):
- response = self.client.get("/request_context_view/")
- self.assertContains(response, 'Path: /request_context_view/')
- def test_nested_requests(self):
- """
- response.context is not lost when view call another view.
- """
- response = self.client.get("/nested_view/")
- self.assertIsInstance(response.context, RequestContext)
- self.assertEqual(response.context['nested'], 'yes')
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class SessionTests(TestDataMixin, TestCase):
- def test_session(self):
- "The session isn't lost if a user logs in"
-
- response = self.client.get('/check_session/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'NO')
-
- response = self.client.get('/set_session/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'set_session')
-
- response = self.client.get('/check_session/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'YES')
-
- login = self.client.login(username='testclient', password='password')
- self.assertTrue(login, 'Could not log in')
-
- response = self.client.get('/check_session/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'YES')
- def test_session_initiated(self):
- session = self.client.session
- session['session_var'] = 'foo'
- session.save()
- response = self.client.get('/check_session/')
- self.assertEqual(response.content, b'foo')
- 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.assertTrue(login, 'Could not log in')
- self.client.logout()
- self.client.logout()
- def test_logout_with_user(self):
- """Logout should send user_logged_out signal if user was logged in."""
- def listener(*args, **kwargs):
- listener.executed = True
- self.assertEqual(kwargs['sender'], User)
- listener.executed = False
- user_logged_out.connect(listener)
- self.client.login(username='testclient', password='password')
- self.client.logout()
- user_logged_out.disconnect(listener)
- self.assertTrue(listener.executed)
- @override_settings(AUTH_USER_MODEL='test_client_regress.CustomUser')
- def test_logout_with_custom_user(self):
- """Logout should send user_logged_out signal if custom user was logged in."""
- def listener(*args, **kwargs):
- self.assertEqual(kwargs['sender'], CustomUser)
- listener.executed = True
- listener.executed = False
- u = CustomUser.custom_objects.create(email='test@test.com')
- u.set_password('password')
- u.save()
- user_logged_out.connect(listener)
- self.client.login(username='test@test.com', password='password')
- self.client.logout()
- user_logged_out.disconnect(listener)
- self.assertTrue(listener.executed)
- @override_settings(AUTHENTICATION_BACKENDS=(
- 'django.contrib.auth.backends.ModelBackend',
- 'test_client_regress.auth_backends.CustomUserBackend'))
- def test_logout_with_custom_auth_backend(self):
- "Request a logout after logging in with custom authentication backend"
- def listener(*args, **kwargs):
- self.assertEqual(kwargs['sender'], CustomUser)
- listener.executed = True
- listener.executed = False
- u = CustomUser.custom_objects.create(email='test@test.com')
- u.set_password('password')
- u.save()
- user_logged_out.connect(listener)
- self.client.login(username='test@test.com', password='password')
- self.client.logout()
- user_logged_out.disconnect(listener)
- self.assertTrue(listener.executed)
- def test_logout_without_user(self):
- """Logout should send signal even if user not authenticated."""
- def listener(user, *args, **kwargs):
- listener.user = user
- listener.executed = True
- listener.executed = False
- user_logged_out.connect(listener)
- self.client.login(username='incorrect', password='password')
- self.client.logout()
- user_logged_out.disconnect(listener)
- self.assertTrue(listener.executed)
- self.assertIsNone(listener.user)
- def test_login_with_user(self):
- """Login should send user_logged_in signal on successful login."""
- def listener(*args, **kwargs):
- listener.executed = True
- listener.executed = False
- user_logged_in.connect(listener)
- self.client.login(username='testclient', password='password')
- user_logged_out.disconnect(listener)
- self.assertTrue(listener.executed)
- def test_login_without_signal(self):
- """Login shouldn't send signal if user wasn't logged in"""
- def listener(*args, **kwargs):
- listener.executed = True
- listener.executed = False
- user_logged_in.connect(listener)
- self.client.login(username='incorrect', password='password')
- user_logged_in.disconnect(listener)
- self.assertFalse(listener.executed)
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class RequestMethodTests(SimpleTestCase):
- def test_get(self):
- "Request a view via request method GET"
- response = self.client.get('/request_methods/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: GET')
- def test_post(self):
- "Request a view via request method POST"
- response = self.client.post('/request_methods/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: POST')
- def test_head(self):
- "Request a view via request method HEAD"
- response = self.client.head('/request_methods/')
- self.assertEqual(response.status_code, 200)
-
- self.assertNotEqual(response.content, b'request method: HEAD')
- self.assertEqual(response.content, b'')
- def test_options(self):
- "Request a view via request method OPTIONS"
- response = self.client.options('/request_methods/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: OPTIONS')
- def test_put(self):
- "Request a view via request method PUT"
- response = self.client.put('/request_methods/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: PUT')
- def test_delete(self):
- "Request a view via request method DELETE"
- response = self.client.delete('/request_methods/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: DELETE')
- def test_patch(self):
- "Request a view via request method PATCH"
- response = self.client.patch('/request_methods/')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: PATCH')
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class RequestMethodStringDataTests(SimpleTestCase):
- def test_post(self):
- "Request a view with string data via request method POST"
-
- data = '{"test": "json"}'
- response = self.client.post('/request_methods/', data=data, content_type='application/json')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: POST')
- def test_put(self):
- "Request a view with string data via request method PUT"
-
- data = '{"test": "json"}'
- response = self.client.put('/request_methods/', data=data, content_type='application/json')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: PUT')
- def test_patch(self):
- "Request a view with string data via request method PATCH"
-
- data = '{"test": "json"}'
- response = self.client.patch('/request_methods/', data=data, content_type='application/json')
- self.assertEqual(response.status_code, 200)
- self.assertEqual(response.content, b'request method: PATCH')
- def test_empty_string_data(self):
- "Request a view with empty string data via request method GET/POST/HEAD"
-
- response = self.client.get('/body/', data='', content_type='application/json')
- self.assertEqual(response.content, b'')
- response = self.client.post('/body/', data='', content_type='application/json')
- self.assertEqual(response.content, b'')
- response = self.client.head('/body/', data='', content_type='application/json')
- self.assertEqual(response.content, b'')
- def test_json(self):
- response = self.client.get('/json_response/')
- self.assertEqual(response.json(), {'key': 'value'})
- def test_json_wrong_header(self):
- response = self.client.get('/body/')
- msg = 'Content-Type header is "text/html; charset=utf-8", not "application/json"'
- with self.assertRaisesMessage(ValueError, msg):
- self.assertEqual(response.json(), {'key': 'value'})
- @override_settings(ROOT_URLCONF='test_client_regress.urls',)
- class QueryStringTests(SimpleTestCase):
- def test_get_like_requests(self):
- for method_name in ('get', 'head'):
-
- method = getattr(self.client, method_name)
- response = method("/request_data/", data={'foo': 'whiz'})
- self.assertEqual(response.context['get-foo'], 'whiz')
-
- response = method("/request_data/?foo=whiz")
- self.assertEqual(response.context['get-foo'], 'whiz')
-
- response = method("/request_data/?foo=whiz", data={'foo': 'bang'})
- self.assertEqual(response.context['get-foo'], 'bang')
- response = method("/request_data/?foo=whiz", data={'bar': 'bang'})
- self.assertIsNone(response.context['get-foo'])
- self.assertEqual(response.context['get-bar'], 'bang')
- def test_post_like_requests(self):
-
- response = self.client.post("/request_data/", data={'foo': 'whiz'})
- self.assertIsNone(response.context['get-foo'])
- self.assertEqual(response.context['post-foo'], 'whiz')
-
- response = self.client.post("/request_data/?foo=whiz")
- self.assertEqual(response.context['get-foo'], 'whiz')
- self.assertIsNone(response.context['post-foo'])
-
- response = self.client.post("/request_data/?foo=whiz", data={'foo': 'bang'})
- self.assertEqual(response.context['get-foo'], 'whiz')
- self.assertEqual(response.context['post-foo'], 'bang')
- response = self.client.post("/request_data/?foo=whiz", data={'bar': 'bang'})
- self.assertEqual(response.context['get-foo'], 'whiz')
- self.assertIsNone(response.context['get-bar'])
- self.assertIsNone(response.context['post-foo'])
- self.assertEqual(response.context['post-bar'], 'bang')
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class UnicodePayloadTests(SimpleTestCase):
- def test_simple_unicode_payload(self):
- "A simple ASCII-only unicode JSON document can be POSTed"
-
- json = '{"english": "mountain pass"}'
- response = self.client.post("/parse_unicode_json/", json, content_type="application/json")
- self.assertEqual(response.content, json.encode())
- def test_unicode_payload_utf8(self):
- "A non-ASCII unicode data encoded as UTF-8 can be POSTed"
-
- json = '{"dog": "собака"}'
- response = self.client.post("/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"
-
- json = '{"dog": "собака"}'
- response = self.client.post("/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"
-
- json = '{"dog": "собака"}'
- response = self.client.post("/parse_unicode_json/", json, content_type="application/json; charset=koi8-r")
- self.assertEqual(response.content, json.encode('koi8-r'))
- class DummyFile(object):
- def __init__(self, filename):
- self.name = filename
- def read(self):
- return b'TEST_FILE_CONTENT'
- class UploadedFileEncodingTest(SimpleTestCase):
- def test_file_encoding(self):
- encoded_file = encode_file('TEST_BOUNDARY', 'TEST_KEY', DummyFile('test_name.bin'))
- self.assertEqual(b'--TEST_BOUNDARY', encoded_file[0])
- self.assertEqual(b'Content-Disposition: form-data; name="TEST_KEY"; filename="test_name.bin"', encoded_file[1])
- self.assertEqual(b'TEST_FILE_CONTENT', encoded_file[-1])
- def test_guesses_content_type_on_file_encoding(self):
- self.assertEqual(b'Content-Type: application/octet-stream',
- encode_file('IGNORE', 'IGNORE', DummyFile("file.bin"))[2])
- self.assertEqual(b'Content-Type: text/plain',
- encode_file('IGNORE', 'IGNORE', DummyFile("file.txt"))[2])
- self.assertIn(encode_file('IGNORE', 'IGNORE', DummyFile("file.zip"))[2], (
- b'Content-Type: application/x-compress',
- b'Content-Type: application/x-zip',
- b'Content-Type: application/x-zip-compressed',
- b'Content-Type: application/zip',))
- self.assertEqual(b'Content-Type: application/octet-stream',
- encode_file('IGNORE', 'IGNORE', DummyFile("file.unknown"))[2])
- @override_settings(ROOT_URLCONF='test_client_regress.urls',)
- class RequestHeadersTest(SimpleTestCase):
- def test_client_headers(self):
- "A test client can receive custom headers"
- response = self.client.get("/check_headers/", HTTP_X_ARG_CHECK='Testing 123')
- self.assertEqual(response.content, b"HTTP_X_ARG_CHECK: Testing 123")
- self.assertEqual(response.status_code, 200)
- def test_client_headers_redirect(self):
- "Test client headers are preserved through redirects"
- response = self.client.get("/check_headers_redirect/", follow=True, HTTP_X_ARG_CHECK='Testing 123')
- self.assertEqual(response.content, b"HTTP_X_ARG_CHECK: Testing 123")
- self.assertRedirects(response, '/check_headers/', status_code=302, target_status_code=200)
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class ReadLimitedStreamTest(SimpleTestCase):
- """
- HttpRequest.body, HttpRequest.read(), and HttpRequest.read(BUFFER) have
- proper LimitedStream behavior.
- Refs #14753, #15785
- """
- def test_body_from_empty_request(self):
- """HttpRequest.body on a test client GET request should return
- the empty string."""
- self.assertEqual(self.client.get("/body/").content, b'')
- def test_read_from_empty_request(self):
- """HttpRequest.read() on a test client GET request should return the
- empty string."""
- self.assertEqual(self.client.get("/read_all/").content, b'')
- def test_read_numbytes_from_empty_request(self):
- """HttpRequest.read(LARGE_BUFFER) on a test client GET request should
- return the empty string."""
- self.assertEqual(self.client.get("/read_buffer/").content, b'')
- def test_read_from_nonempty_request(self):
- """HttpRequest.read() on a test client PUT request with some payload
- should return that payload."""
- payload = b'foobar'
- self.assertEqual(self.client.put("/read_all/", data=payload, content_type='text/plain').content, payload)
- def test_read_numbytes_from_nonempty_request(self):
- """HttpRequest.read(LARGE_BUFFER) on a test client PUT request with
- some payload should return that payload."""
- payload = b'foobar'
- self.assertEqual(self.client.put("/read_buffer/", data=payload, content_type='text/plain').content, payload)
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class RequestFactoryStateTest(SimpleTestCase):
- """Regression tests for #15929."""
-
-
-
-
-
- def common_test_that_should_always_pass(self):
- request = RequestFactory().get('/')
- request.session = {}
- self.assertFalse(hasattr(request, 'user'))
- def test_request(self):
- self.common_test_that_should_always_pass()
- def test_request_after_client(self):
-
- self.client.get('/')
- self.common_test_that_should_always_pass()
- def test_request_after_client_2(self):
-
- self.common_test_that_should_always_pass()
- @override_settings(ROOT_URLCONF='test_client_regress.urls')
- class RequestFactoryEnvironmentTests(SimpleTestCase):
- """
- Regression tests for #8551 and #17067: ensure that environment variables
- are set correctly in RequestFactory.
- """
- def test_should_set_correct_env_variables(self):
- request = RequestFactory().get('/path/')
- 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_PORT'), '80')
- self.assertEqual(request.META.get('SERVER_PROTOCOL'), 'HTTP/1.1')
- self.assertEqual(request.META.get('SCRIPT_NAME') + request.META.get('PATH_INFO'), '/path/')
|