diff options
| author | Claude Paroz <claude@2xlibre.net> | 2015-01-12 12:00:27 +0100 |
|---|---|---|
| committer | Claude Paroz <claude@2xlibre.net> | 2015-01-12 22:51:22 +0100 |
| commit | f48e2258a96a08dcec843921206bcf7656e3ae45 (patch) | |
| tree | ee6c9a0afae7ceeb053d7cf2d76a4b50c9f3545b /tests/generic_views | |
| parent | 5f7230e12f0d237cdc19d8930006b0fc7d9dbaa6 (diff) | |
Fixed #24133 -- Replaced formatting syntax in success_url placeholders
Thanks Laurent Payot for the report, and Markus Holtermann, Tim Graham
for the reviews.
Diffstat (limited to 'tests/generic_views')
| -rw-r--r-- | tests/generic_views/test_edit.py | 42 | ||||
| -rw-r--r-- | tests/generic_views/urls.py | 13 |
2 files changed, 46 insertions, 9 deletions
diff --git a/tests/generic_views/test_edit.py b/tests/generic_views/test_edit.py index d8e0193574..b61a11086a 100644 --- a/tests/generic_views/test_edit.py +++ b/tests/generic_views/test_edit.py @@ -5,7 +5,7 @@ import warnings from django.core.exceptions import ImproperlyConfigured from django.core.urlresolvers import reverse from django import forms -from django.test import TestCase, override_settings +from django.test import TestCase, ignore_warnings, override_settings from django.test.client import RequestFactory from django.utils.deprecation import RemovedInDjango20Warning from django.views.generic.base import View @@ -143,13 +143,24 @@ class CreateViewTests(TestCase): self.assertRedirects(res, 'http://testserver/edit/authors/create/') self.assertQuerysetEqual(Author.objects.all(), ['<Author: Randall Munroe>']) + @ignore_warnings(category=RemovedInDjango20Warning) def test_create_with_interpolated_redirect(self): - res = self.client.post('/edit/authors/create/interpolate_redirect/', - {'name': 'Randall Munroe', 'slug': 'randall-munroe'}) + res = self.client.post( + '/edit/authors/create/interpolate_redirect/', + {'name': 'Randall Munroe', 'slug': 'randall-munroe'} + ) self.assertQuerysetEqual(Author.objects.all(), ['<Author: Randall Munroe>']) self.assertEqual(res.status_code, 302) - pk = Author.objects.all()[0].pk + pk = Author.objects.first().pk self.assertRedirects(res, 'http://testserver/edit/author/%d/update/' % pk) + # Also test with escaped chars in URL + res = self.client.post( + '/edit/authors/create/interpolate_redirect_nonascii/', + {'name': 'John Doe', 'slug': 'john-doe'} + ) + self.assertEqual(res.status_code, 302) + pk = Author.objects.get(name='John Doe').pk + self.assertRedirects(res, 'http://testserver/%C3%A9dit/author/{}/update/'.format(pk)) def test_create_with_special_properties(self): res = self.client.get('/edit/authors/create/special/') @@ -272,17 +283,28 @@ class UpdateViewTests(TestCase): self.assertRedirects(res, 'http://testserver/edit/authors/create/') self.assertQuerysetEqual(Author.objects.all(), ['<Author: Randall Munroe (author of xkcd)>']) + @ignore_warnings(category=RemovedInDjango20Warning) def test_update_with_interpolated_redirect(self): a = Author.objects.create( name='Randall Munroe', slug='randall-munroe', ) - res = self.client.post('/edit/author/%d/update/interpolate_redirect/' % a.pk, - {'name': 'Randall Munroe (author of xkcd)', 'slug': 'randall-munroe'}) + res = self.client.post( + '/edit/author/%d/update/interpolate_redirect/' % a.pk, + {'name': 'Randall Munroe (author of xkcd)', 'slug': 'randall-munroe'} + ) self.assertQuerysetEqual(Author.objects.all(), ['<Author: Randall Munroe (author of xkcd)>']) self.assertEqual(res.status_code, 302) - pk = Author.objects.all()[0].pk + pk = Author.objects.first().pk self.assertRedirects(res, 'http://testserver/edit/author/%d/update/' % pk) + # Also test with escaped chars in URL + res = self.client.post( + '/edit/author/%d/update/interpolate_redirect_nonascii/' % a.pk, + {'name': 'John Doe', 'slug': 'john-doe'} + ) + self.assertEqual(res.status_code, 302) + pk = Author.objects.get(name='John Doe').pk + self.assertRedirects(res, 'http://testserver/%C3%A9dit/author/{}/update/'.format(pk)) def test_update_with_special_properties(self): a = Author.objects.create( @@ -368,12 +390,18 @@ class DeleteViewTests(TestCase): self.assertRedirects(res, 'http://testserver/edit/authors/create/') self.assertQuerysetEqual(Author.objects.all(), []) + @ignore_warnings(category=RemovedInDjango20Warning) def test_delete_with_interpolated_redirect(self): a = Author.objects.create(**{'name': 'Randall Munroe', 'slug': 'randall-munroe'}) res = self.client.post('/edit/author/%d/delete/interpolate_redirect/' % a.pk) self.assertEqual(res.status_code, 302) self.assertRedirects(res, 'http://testserver/edit/authors/create/?deleted=%d' % a.pk) self.assertQuerysetEqual(Author.objects.all(), []) + # Also test with escaped chars in URL + a = Author.objects.create(**{'name': 'Randall Munroe', 'slug': 'randall-munroe'}) + res = self.client.post('/edit/author/{}/delete/interpolate_redirect_nonascii/'.format(a.pk)) + self.assertEqual(res.status_code, 302) + self.assertRedirects(res, 'http://testserver/%C3%A9dit/authors/create/?deleted={}'.format(a.pk)) def test_delete_with_special_properties(self): a = Author.objects.create(**{'name': 'Randall Munroe', 'slug': 'randall-munroe'}) diff --git a/tests/generic_views/urls.py b/tests/generic_views/urls.py index f4965e2317..1bef0a8b77 100644 --- a/tests/generic_views/urls.py +++ b/tests/generic_views/urls.py @@ -1,3 +1,6 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + from django.conf.urls import url from django.contrib.auth import views as auth_views from django.views.decorators.cache import cache_page @@ -74,9 +77,11 @@ urlpatterns = [ views.NaiveAuthorCreate.as_view(success_url='/edit/authors/create/')), url(r'^edit/authors/create/interpolate_redirect/$', views.NaiveAuthorCreate.as_view(success_url='/edit/author/%(id)d/update/')), + url(r'^edit/authors/create/interpolate_redirect_nonascii/$', + views.NaiveAuthorCreate.as_view(success_url='/%C3%A9dit/author/{id}/update/')), url(r'^edit/authors/create/restricted/$', views.AuthorCreateRestricted.as_view()), - url(r'^edit/authors/create/$', + url(r'^[eé]dit/authors/create/$', views.AuthorCreate.as_view()), url(r'^edit/authors/create/special/$', views.SpecializedAuthorCreate.as_view()), @@ -87,7 +92,9 @@ urlpatterns = [ views.NaiveAuthorUpdate.as_view(success_url='/edit/authors/create/')), url(r'^edit/author/(?P<pk>[0-9]+)/update/interpolate_redirect/$', views.NaiveAuthorUpdate.as_view(success_url='/edit/author/%(id)d/update/')), - url(r'^edit/author/(?P<pk>[0-9]+)/update/$', + url(r'^edit/author/(?P<pk>[0-9]+)/update/interpolate_redirect_nonascii/$', + views.NaiveAuthorUpdate.as_view(success_url='/%C3%A9dit/author/{id}/update/')), + url(r'^[eé]dit/author/(?P<pk>[0-9]+)/update/$', views.AuthorUpdate.as_view()), url(r'^edit/author/update/$', views.OneAuthorUpdate.as_view()), @@ -99,6 +106,8 @@ urlpatterns = [ views.NaiveAuthorDelete.as_view(success_url='/edit/authors/create/')), url(r'^edit/author/(?P<pk>[0-9]+)/delete/interpolate_redirect/$', views.NaiveAuthorDelete.as_view(success_url='/edit/authors/create/?deleted=%(id)s')), + url(r'^edit/author/(?P<pk>[0-9]+)/delete/interpolate_redirect_nonascii/$', + views.NaiveAuthorDelete.as_view(success_url='/%C3%A9dit/authors/create/?deleted={id}')), url(r'^edit/author/(?P<pk>[0-9]+)/delete/$', views.AuthorDelete.as_view()), url(r'^edit/author/(?P<pk>[0-9]+)/delete/special/$', |
