diff options
author | Florian Apolloner <florian@apolloner.eu> | 2013-02-26 09:53:47 +0100 |
---|---|---|
committer | Florian Apolloner <florian@apolloner.eu> | 2013-02-26 14:36:57 +0100 |
commit | 89f40e36246100df6a11316c31a76712ebc6c501 (patch) | |
tree | 6e65639683ddaf2027908d1ecb1739e0e2ff853b /tests/context_processors | |
parent | b3d2ccb5bfbaf6e7fe1f98843baaa48c35a70950 (diff) | |
download | django-89f40e36246100df6a11316c31a76712ebc6c501.tar.gz |
Merged regressiontests and modeltests into the test root.
Diffstat (limited to 'tests/context_processors')
-rw-r--r-- | tests/context_processors/__init__.py | 0 | ||||
-rw-r--r-- | tests/context_processors/models.py | 1 | ||||
-rw-r--r-- | tests/context_processors/templates/context_processors/request_attrs.html | 13 | ||||
-rw-r--r-- | tests/context_processors/tests.py | 37 | ||||
-rw-r--r-- | tests/context_processors/urls.py | 10 | ||||
-rw-r--r-- | tests/context_processors/views.py | 8 |
6 files changed, 69 insertions, 0 deletions
diff --git a/tests/context_processors/__init__.py b/tests/context_processors/__init__.py new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/tests/context_processors/__init__.py diff --git a/tests/context_processors/models.py b/tests/context_processors/models.py new file mode 100644 index 0000000000..cde172db68 --- /dev/null +++ b/tests/context_processors/models.py @@ -0,0 +1 @@ +# Models file for tests to run. diff --git a/tests/context_processors/templates/context_processors/request_attrs.html b/tests/context_processors/templates/context_processors/request_attrs.html new file mode 100644 index 0000000000..3978e9d680 --- /dev/null +++ b/tests/context_processors/templates/context_processors/request_attrs.html @@ -0,0 +1,13 @@ +{% if request %} +Have request +{% else %} +No request +{% endif %} + +{% if request.is_secure %} +Secure +{% else %} +Not secure +{% endif %} + +{{ request.path }} diff --git a/tests/context_processors/tests.py b/tests/context_processors/tests.py new file mode 100644 index 0000000000..1f2209efb0 --- /dev/null +++ b/tests/context_processors/tests.py @@ -0,0 +1,37 @@ +""" +Tests for Django's bundled context processors. +""" +from django.test import TestCase + + +class RequestContextProcessorTests(TestCase): + """ + Tests for the ``django.core.context_processors.request`` processor. + """ + + urls = 'regressiontests.context_processors.urls' + + def test_request_attributes(self): + """ + Test that the request object is available in the template and that its + attributes can't be overridden by GET and POST parameters (#3828). + """ + url = '/request_attrs/' + # We should have the request object in the template. + response = self.client.get(url) + self.assertContains(response, 'Have request') + # Test is_secure. + response = self.client.get(url) + self.assertContains(response, 'Not secure') + response = self.client.get(url, {'is_secure': 'blah'}) + self.assertContains(response, 'Not secure') + response = self.client.post(url, {'is_secure': 'blah'}) + self.assertContains(response, 'Not secure') + # Test path. + response = self.client.get(url) + self.assertContains(response, url) + response = self.client.get(url, {'path': '/blah/'}) + self.assertContains(response, url) + response = self.client.post(url, {'path': '/blah/'}) + self.assertContains(response, url) + diff --git a/tests/context_processors/urls.py b/tests/context_processors/urls.py new file mode 100644 index 0000000000..757017c9ca --- /dev/null +++ b/tests/context_processors/urls.py @@ -0,0 +1,10 @@ +from __future__ import absolute_import + +from django.conf.urls import patterns, url + +from . import views + + +urlpatterns = patterns('', + (r'^request_attrs/$', views.request_processor), +) diff --git a/tests/context_processors/views.py b/tests/context_processors/views.py new file mode 100644 index 0000000000..66e7132c05 --- /dev/null +++ b/tests/context_processors/views.py @@ -0,0 +1,8 @@ +from django.core import context_processors +from django.shortcuts import render_to_response +from django.template.context import RequestContext + + +def request_processor(request): + return render_to_response('context_processors/request_attrs.html', + RequestContext(request, {}, processors=[context_processors.request])) |