From 29642fa76fa5c8087c49d2f37511450419fa8cf7 Mon Sep 17 00:00:00 2001 From: Russell Keith-Magee Date: Sat, 2 Apr 2011 13:27:40 +0000 Subject: [PATCH] Refactored views regression tests to isolate generic views from the root URL space. git-svn-id: http://code.djangoproject.com/svn/django/trunk@16000 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- tests/regressiontests/views/generic_urls.py | 117 ++++++++++++++++++ tests/regressiontests/views/tests/debug.py | 12 -- .../views/tests/generic/create_update.py | 45 +++---- .../views/tests/generic/date_based.py | 38 +++--- .../views/tests/generic/object_list.py | 20 +-- .../views/tests/generic/simple.py | 24 ++-- .../regressiontests/views/tests/shortcuts.py | 20 +-- tests/regressiontests/views/tests/specials.py | 20 ++- tests/regressiontests/views/urls.py | 114 +---------------- tests/regressiontests/views/views.py | 2 +- 10 files changed, 219 insertions(+), 193 deletions(-) create mode 100644 tests/regressiontests/views/generic_urls.py diff --git a/tests/regressiontests/views/generic_urls.py b/tests/regressiontests/views/generic_urls.py new file mode 100644 index 0000000000..c608cc1c7f --- /dev/null +++ b/tests/regressiontests/views/generic_urls.py @@ -0,0 +1,117 @@ +# -*- coding:utf-8 -*- +from django.conf.urls.defaults import patterns, url + +from models import * + +import views + + +date_based_info_dict = { + 'queryset': Article.objects.all(), + 'date_field': 'date_created', + 'month_format': '%m', +} + +object_list_dict = { + 'queryset': Article.objects.all(), + 'paginate_by': 2, +} + +object_list_no_paginate_by = { + 'queryset': Article.objects.all(), +} + +numeric_days_info_dict = dict(date_based_info_dict, day_format='%d') + +date_based_datefield_info_dict = dict(date_based_info_dict, queryset=DateArticle.objects.all()) + +urlpatterns = patterns('', + (r'^accounts/login/$', 'django.contrib.auth.views.login', {'template_name': 'login.html'}), + (r'^accounts/logout/$', 'django.contrib.auth.views.logout'), + + # Special URLs for particular regression cases. + url(u'^中文/$', 'regressiontests.views.views.redirect'), + url(u'^中文/target/$', 'regressiontests.views.views.index_page'), +) + +# Date-based generic views. +urlpatterns += patterns('django.views.generic.date_based', + (r'^date_based/object_detail/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})/(?P[-\w]+)/$', + 'object_detail', + dict(slug_field='slug', **date_based_info_dict)), + (r'^date_based/object_detail/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})/(?P[-\w]+)/allow_future/$', + 'object_detail', + dict(allow_future=True, slug_field='slug', **date_based_info_dict)), + (r'^date_based/archive_day/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})/$', + 'archive_day', + numeric_days_info_dict), + (r'^date_based/archive_month/(?P\d{4})/(?P\d{1,2})/$', + 'archive_month', + date_based_info_dict), + (r'^date_based/datefield/archive_month/(?P\d{4})/(?P\d{1,2})/$', + 'archive_month', + date_based_datefield_info_dict), +) + +# crud generic views. +urlpatterns += patterns('django.views.generic.create_update', + (r'^create_update/member/create/article/$', 'create_object', + dict(login_required=True, model=Article)), + (r'^create_update/create/article/$', 'create_object', + dict(post_save_redirect='/create_update/view/article/%(slug)s/', + model=Article)), + (r'^create_update/update/article/(?P[-\w]+)/$', 'update_object', + dict(post_save_redirect='/create_update/view/article/%(slug)s/', + slug_field='slug', model=Article)), + (r'^create_update/create_custom/article/$', views.custom_create), + (r'^create_update/delete/article/(?P[-\w]+)/$', 'delete_object', + dict(post_delete_redirect='/create_update/', slug_field='slug', + model=Article)), + + # No post_save_redirect and no get_absolute_url on model. + (r'^create_update/no_redirect/create/article/$', 'create_object', + dict(model=Article)), + (r'^create_update/no_redirect/update/article/(?P[-\w]+)/$', + 'update_object', dict(slug_field='slug', model=Article)), + + # get_absolute_url on model, but no passed post_save_redirect. + (r'^create_update/no_url/create/article/$', 'create_object', + dict(model=UrlArticle)), + (r'^create_update/no_url/update/article/(?P[-\w]+)/$', + 'update_object', dict(slug_field='slug', model=UrlArticle)), +) + +urlpatterns += patterns('django.views.generic.list_detail', + (r'^object_list/page(?P[\w]*)/$', 'object_list', object_list_dict), + (r'^object_list_no_paginate_by/page(?P[0-9]+)/$', 'object_list', + object_list_no_paginate_by), +) + +# rediriects, both temporary and permanent, with non-ASCII targets +urlpatterns += patterns('django.views.generic.simple', + ('^nonascii_redirect/$', 'redirect_to', + {'url': u'/中文/target/', 'permanent': False}), + ('^permanent_nonascii_redirect/$', 'redirect_to', + {'url': u'/中文/target/', 'permanent': True}), +) + +urlpatterns += patterns('regressiontests.views.views', + (r'^shortcuts/render_to_response/$', 'render_to_response_view'), + (r'^shortcuts/render_to_response/request_context/$', 'render_to_response_view_with_request_context'), + (r'^shortcuts/render_to_response/mimetype/$', 'render_to_response_view_with_mimetype'), + (r'^shortcuts/render/$', 'render_view'), + (r'^shortcuts/render/base_context/$', 'render_view_with_base_context'), + (r'^shortcuts/render/content_type/$', 'render_view_with_content_type'), + (r'^shortcuts/render/status/$', 'render_view_with_status'), + (r'^shortcuts/render/current_app/$', 'render_view_with_current_app'), + (r'^shortcuts/render/current_app_conflict/$', 'render_view_with_current_app_conflict'), +) + +# simple generic views. +urlpatterns += patterns('django.views.generic.simple', + (r'^simple/redirect_to/$', 'redirect_to', dict(url='/simple/target/')), + (r'^simple/redirect_to_temp/$', 'redirect_to', dict(url='/simple/target/', permanent=False)), + (r'^simple/redirect_to_none/$', 'redirect_to', dict(url=None)), + (r'^simple/redirect_to_arg/(?P\d+)/$', 'redirect_to', dict(url='/simple/target_arg/%(id)s/')), + (r'^simple/redirect_to_query/$', 'redirect_to', dict(url='/simple/target/', query_string=True)), +) diff --git a/tests/regressiontests/views/tests/debug.py b/tests/regressiontests/views/tests/debug.py index 559852e663..9aba3039ac 100644 --- a/tests/regressiontests/views/tests/debug.py +++ b/tests/regressiontests/views/tests/debug.py @@ -1,6 +1,5 @@ import inspect import sys -import warnings from django.conf import settings from django.core.files.uploadedfile import SimpleUploadedFile @@ -14,16 +13,6 @@ from regressiontests.views import BrokenException, except_args class DebugViewTests(TestCase): def setUp(self): - self.save_warnings_state() - warnings.filterwarnings('ignore', category=DeprecationWarning, - module='django.views.generic.simple') - warnings.filterwarnings('ignore', category=DeprecationWarning, - module='django.views.generic.create_update') - warnings.filterwarnings('ignore', category=DeprecationWarning, - module='django.views.generic.date_based') - warnings.filterwarnings('ignore', category=DeprecationWarning, - module='django.views.generic.list_detail') - self.old_debug = settings.DEBUG settings.DEBUG = True self.old_template_debug = settings.TEMPLATE_DEBUG @@ -32,7 +21,6 @@ class DebugViewTests(TestCase): def tearDown(self): settings.DEBUG = self.old_debug settings.TEMPLATE_DEBUG = self.old_template_debug - self.restore_warnings_state() def test_files(self): response = self.client.get('/views/raises/') diff --git a/tests/regressiontests/views/tests/generic/create_update.py b/tests/regressiontests/views/tests/generic/create_update.py index 4a50ee3a95..902ba667da 100644 --- a/tests/regressiontests/views/tests/generic/create_update.py +++ b/tests/regressiontests/views/tests/generic/create_update.py @@ -6,8 +6,8 @@ from django.core.exceptions import ImproperlyConfigured from regressiontests.views.models import Article, UrlArticle class CreateObjectTest(TestCase): - fixtures = ['testdata.json'] + urls = 'regressiontests.views.generic_urls' def setUp(self): self.save_warnings_state() @@ -23,7 +23,7 @@ class CreateObjectTest(TestCase): login_required view gets redirected to the login page and that an authenticated user is let through. """ - view_url = '/views/create_update/member/create/article/' + view_url = '/create_update/member/create/article/' response = self.client.get(view_url) self.assertRedirects(response, '/accounts/login/?next=%s' % view_url) # Now login and try again. @@ -37,7 +37,7 @@ class CreateObjectTest(TestCase): """ Ensures the generic view returned the page and contains a form. """ - view_url = '/views/create_update/create/article/' + view_url = '/create_update/create/article/' response = self.client.get(view_url) self.assertEqual(response.status_code, 200) self.assertTemplateUsed(response, 'views/article_form.html') @@ -48,7 +48,7 @@ class CreateObjectTest(TestCase): """ POSTs a form that contains validation errors. """ - view_url = '/views/create_update/create/article/' + view_url = '/create_update/create/article/' num_articles = Article.objects.count() response = self.client.post(view_url, { 'title': 'My First Article', @@ -63,7 +63,7 @@ class CreateObjectTest(TestCase): Creates a new article using a custom form class with a save method that alters the slug entered. """ - view_url = '/views/create_update/create_custom/article/' + view_url = '/create_update/create_custom/article/' response = self.client.post(view_url, { 'title': 'Test Article', 'slug': 'this-should-get-replaced', @@ -71,12 +71,12 @@ class CreateObjectTest(TestCase): 'date_created': datetime.datetime(2007, 6, 25), }) self.assertRedirects(response, - '/views/create_update/view/article/some-other-slug/', + '/create_update/view/article/some-other-slug/', target_status_code=404) class UpdateDeleteObjectTest(TestCase): - fixtures = ['testdata.json'] + urls = 'regressiontests.views.generic_urls' def setUp(self): self.save_warnings_state() @@ -90,7 +90,7 @@ class UpdateDeleteObjectTest(TestCase): """ Verifies that the form was created properly and with initial values. """ - response = self.client.get('/views/create_update/update/article/old_article/') + response = self.client.get('/create_update/update/article/old_article/') self.assertTemplateUsed(response, 'views/article_form.html') self.assertEqual(unicode(response.context['form']['title']), u'') @@ -99,7 +99,7 @@ class UpdateDeleteObjectTest(TestCase): """ Verifies the updating of an Article. """ - response = self.client.post('/views/create_update/update/article/old_article/', { + response = self.client.post('/create_update/update/article/old_article/', { 'title': 'Another Article', 'slug': 'another-article-slug', 'author': 1, @@ -112,14 +112,14 @@ class UpdateDeleteObjectTest(TestCase): """ Verifies the confirm deletion page is displayed using a GET. """ - response = self.client.get('/views/create_update/delete/article/old_article/') + response = self.client.get('/create_update/delete/article/old_article/') self.assertTemplateUsed(response, 'views/article_confirm_delete.html') def test_delete_object(self): """ Verifies the object actually gets deleted on a POST. """ - view_url = '/views/create_update/delete/article/old_article/' + view_url = '/create_update/delete/article/old_article/' response = self.client.post(view_url) try: Article.objects.get(slug='old_article') @@ -137,14 +137,15 @@ class PostSaveRedirectTests(TestCase): fixtures = ['testdata.json'] article_model = Article + urls = 'regressiontests.views.generic_urls' - create_url = '/views/create_update/create/article/' - update_url = '/views/create_update/update/article/old_article/' - delete_url = '/views/create_update/delete/article/old_article/' + create_url = '/create_update/create/article/' + update_url = '/create_update/update/article/old_article/' + delete_url = '/create_update/delete/article/old_article/' - create_redirect = '/views/create_update/view/article/my-first-article/' - update_redirect = '/views/create_update/view/article/another-article-slug/' - delete_redirect = '/views/create_update/' + create_redirect = '/create_update/view/article/my-first-article/' + update_redirect = '/create_update/view/article/another-article-slug/' + delete_redirect = '/create_update/' def setUp(self): self.save_warnings_state() @@ -194,9 +195,10 @@ class NoPostSaveNoAbsoluteUrl(PostSaveRedirectTests): method exists on the Model that the view raises an ImproperlyConfigured error. """ + urls = 'regressiontests.views.generic_urls' - create_url = '/views/create_update/no_redirect/create/article/' - update_url = '/views/create_update/no_redirect/update/article/old_article/' + create_url = '/create_update/no_redirect/create/article/' + update_url = '/create_update/no_redirect/update/article/old_article/' def setUp(self): self.save_warnings_state() @@ -226,12 +228,13 @@ class AbsoluteUrlNoPostSave(PostSaveRedirectTests): Tests that the views redirect to the Model's get_absolute_url when no post_save_redirect is passed. """ + urls = 'regressiontests.views.generic_urls' # Article model with get_absolute_url method. article_model = UrlArticle - create_url = '/views/create_update/no_url/create/article/' - update_url = '/views/create_update/no_url/update/article/old_article/' + create_url = '/create_update/no_url/create/article/' + update_url = '/create_update/no_url/update/article/old_article/' create_redirect = '/urlarticles/my-first-article/' update_redirect = '/urlarticles/another-article-slug/' diff --git a/tests/regressiontests/views/tests/generic/date_based.py b/tests/regressiontests/views/tests/generic/date_based.py index 7815497b34..96555e5a9f 100644 --- a/tests/regressiontests/views/tests/generic/date_based.py +++ b/tests/regressiontests/views/tests/generic/date_based.py @@ -8,6 +8,8 @@ from regressiontests.views.models import Article, Author, DateArticle class ObjectDetailTest(TestCase): fixtures = ['testdata.json'] + urls = 'regressiontests.views.generic_urls' + def setUp(self): self.save_warnings_state() warnings.filterwarnings('ignore', category=DeprecationWarning, @@ -22,29 +24,31 @@ class ObjectDetailTest(TestCase): def test_finds_past(self): "date_based.object_detail can view a page in the past" - response = self.client.get('/views/date_based/object_detail/2001/01/01/old_article/') + response = self.client.get('/date_based/object_detail/2001/01/01/old_article/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['object'].title, "Old Article") def test_object_detail_finds_today(self): "date_based.object_detail can view a page from today" today_url = datetime.now().strftime('%Y/%m/%d') - response = self.client.get('/views/date_based/object_detail/%s/current_article/' % today_url) + response = self.client.get('/date_based/object_detail/%s/current_article/' % today_url) self.assertEqual(response.status_code, 200) self.assertEqual(response.context['object'].title, "Current Article") def test_object_detail_ignores_future(self): "date_based.object_detail can view a page from the future, but only if allowed." - response = self.client.get('/views/date_based/object_detail/3000/01/01/future_article/') + response = self.client.get('/date_based/object_detail/3000/01/01/future_article/') self.assertEqual(response.status_code, 404) def test_object_detail_allowed_future_if_enabled(self): "date_based.object_detail can view a page from the future if explicitly allowed." - response = self.client.get('/views/date_based/object_detail/3000/01/01/future_article/allow_future/') + response = self.client.get('/date_based/object_detail/3000/01/01/future_article/allow_future/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['object'].title, "Future Article") class MonthArchiveTest(TestCase): + urls = 'regressiontests.views.generic_urls' + def setUp(self): self.save_warnings_state() warnings.filterwarnings('ignore', category=DeprecationWarning, @@ -66,52 +70,52 @@ class MonthArchiveTest(TestCase): article.date_created = first_second_of_feb article.save() - response = self.client.get('/views/date_based/archive_month/2004/02/') + response = self.client.get('/date_based/archive_month/2004/02/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['next_month'], date(2004, 3, 1)) self.assertEqual(response.context['previous_month'], date(2004, 1, 1)) article.date_created = first_second_of_feb-two_seconds article.save() - response = self.client.get('/views/date_based/archive_month/2004/02/') + response = self.client.get('/date_based/archive_month/2004/02/') self.assertEqual(response.status_code, 404) article.date_created = first_second_of_mar-two_seconds article.save() - response = self.client.get('/views/date_based/archive_month/2004/02/') + response = self.client.get('/date_based/archive_month/2004/02/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['next_month'], date(2004, 3, 1)) self.assertEqual(response.context['previous_month'], date(2004, 1, 1)) article.date_created = first_second_of_mar article.save() - response = self.client.get('/views/date_based/archive_month/2004/02/') + response = self.client.get('/date_based/archive_month/2004/02/') self.assertEqual(response.status_code, 404) article2 = DateArticle(title="example", author=author) article2.date_created = first_second_of_feb.date() article2.save() - response = self.client.get('/views/date_based/datefield/archive_month/2004/02/') + response = self.client.get('/date_based/datefield/archive_month/2004/02/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['next_month'], date(2004, 3, 1)) self.assertEqual(response.context['previous_month'], date(2004, 1, 1)) article2.date_created = (first_second_of_feb-two_seconds).date() article2.save() - response = self.client.get('/views/date_based/datefield/archive_month/2004/02/') + response = self.client.get('/date_based/datefield/archive_month/2004/02/') self.assertEqual(response.status_code, 404) article2.date_created = (first_second_of_mar-two_seconds).date() article2.save() - response = self.client.get('/views/date_based/datefield/archive_month/2004/02/') + response = self.client.get('/date_based/datefield/archive_month/2004/02/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['next_month'], date(2004, 3, 1)) self.assertEqual(response.context['previous_month'], date(2004, 1, 1)) article2.date_created = first_second_of_mar.date() article2.save() - response = self.client.get('/views/date_based/datefield/archive_month/2004/02/') + response = self.client.get('/date_based/datefield/archive_month/2004/02/') self.assertEqual(response.status_code, 404) now = datetime.now() @@ -122,7 +126,7 @@ class MonthArchiveTest(TestCase): prev_month = prev_month.replace(month=prev_month.month-1) article2.date_created = now article2.save() - response = self.client.get('/views/date_based/datefield/archive_month/%s/' % now.strftime('%Y/%m')) + response = self.client.get('/date_based/datefield/archive_month/%s/' % now.strftime('%Y/%m')) self.assertEqual(response.status_code, 200) self.assertEqual(response.context['next_month'], None) self.assertEqual(response.context['previous_month'], prev_month) @@ -134,16 +138,18 @@ class MonthArchiveTest(TestCase): date2 = datetime(2010, 1, 2, 0, 0, 0) Article.objects.create(title='example1', author=author, date_created=date1) Article.objects.create(title='example2', author=author, date_created=date2) - response = self.client.get('/views/date_based/archive_month/2010/1/') + response = self.client.get('/date_based/archive_month/2010/1/') self.assertEqual(response.status_code, 200) self.assertEqual(len(response.context['date_list']), 2) self.assertEqual(response.context['date_list'][0], date1) # Checks that the same date is not included more than once in the list Article.objects.create(title='example2', author=author, date_created=date2) - response = self.client.get('/views/date_based/archive_month/2010/1/') + response = self.client.get('/date_based/archive_month/2010/1/') self.assertEqual(len(response.context['date_list']), 2) class DayArchiveTests(TestCase): + urls = 'regressiontests.views.generic_urls' + def setUp(self): self.save_warnings_state() warnings.filterwarnings('ignore', category=DeprecationWarning, @@ -160,6 +166,6 @@ class DayArchiveTests(TestCase): """ author = Author.objects.create(name="John Smith") article = Article.objects.create(title="example", author=author, date_created=datetime(2004, 1, 21, 0, 0, 1)) - response = self.client.get('/views/date_based/archive_day/2004/1/21/') + response = self.client.get('/date_based/archive_day/2004/1/21/') self.assertEqual(response.status_code, 200) self.assertEqual(response.context['object_list'][0], article) diff --git a/tests/regressiontests/views/tests/generic/object_list.py b/tests/regressiontests/views/tests/generic/object_list.py index 834ead5dde..3fa871a84d 100644 --- a/tests/regressiontests/views/tests/generic/object_list.py +++ b/tests/regressiontests/views/tests/generic/object_list.py @@ -5,10 +5,12 @@ from django.test import TestCase class ObjectListTest(TestCase): fixtures = ['testdata.json'] + urls = 'regressiontests.views.generic_urls' + def setUp(self): self.save_warnings_state() warnings.filterwarnings('ignore', category=DeprecationWarning, - module='django.views.generic.object_list') + module='django.views.generic.list_detail') def tearDown(self): self.restore_warnings_state() @@ -26,20 +28,20 @@ class ObjectListTest(TestCase): def test_finds_pages(self): # Check page count doesn't start at 0. - self.check_pagination('/views/object_list/page0/', 404) + self.check_pagination('/object_list/page0/', 404) # Check basic pages. - self.check_pagination('/views/object_list/page/', 200, 2) - self.check_pagination('/views/object_list/page1/', 200, 2) - self.check_pagination('/views/object_list/page2/', 200, 1) - self.check_pagination('/views/object_list/page3/', 404) + self.check_pagination('/object_list/page/', 200, 2) + self.check_pagination('/object_list/page1/', 200, 2) + self.check_pagination('/object_list/page2/', 200, 1) + self.check_pagination('/object_list/page3/', 404) # Check the special "last" page. - self.check_pagination('/views/object_list/pagelast/', 200, 1) - self.check_pagination('/views/object_list/pagenotlast/', 404) + self.check_pagination('/object_list/pagelast/', 200, 1) + self.check_pagination('/object_list/pagenotlast/', 404) def test_no_paginate_by(self): # Ensure that the view isn't paginated by default. - url = '/views/object_list_no_paginate_by/page1/' + url = '/object_list_no_paginate_by/page1/' response = self.check_pagination(url, 200) self.assertEqual(response.context['is_paginated'], False) diff --git a/tests/regressiontests/views/tests/generic/simple.py b/tests/regressiontests/views/tests/generic/simple.py index 8329229b8c..6bf6f50832 100644 --- a/tests/regressiontests/views/tests/generic/simple.py +++ b/tests/regressiontests/views/tests/generic/simple.py @@ -4,6 +4,8 @@ import warnings from django.test import TestCase class RedirectToTest(TestCase): + urls = 'regressiontests.views.generic_urls' + def setUp(self): self.save_warnings_state() warnings.filterwarnings('ignore', category=DeprecationWarning, @@ -14,34 +16,34 @@ class RedirectToTest(TestCase): def test_redirect_to_returns_permanent_redirect(self): "simple.redirect_to returns a permanent redirect (301) by default" - response = self.client.get('/views/simple/redirect_to/') + response = self.client.get('/simple/redirect_to/') self.assertEqual(response.status_code, 301) - self.assertEqual('http://testserver/views/simple/target/', response['Location']) + self.assertEqual('http://testserver/simple/target/', response['Location']) def test_redirect_to_can_return_a_temporary_redirect(self): "simple.redirect_to returns a temporary redirect (302) when explicitely asked to" - response = self.client.get('/views/simple/redirect_to_temp/') + response = self.client.get('/simple/redirect_to_temp/') self.assertEqual(response.status_code, 302) - self.assertEqual('http://testserver/views/simple/target/', response['Location']) + self.assertEqual('http://testserver/simple/target/', response['Location']) def test_redirect_to_on_empty_url_returns_gone(self): "simple.redirect_to returns resource gone (410) when given a None url" - response = self.client.get('/views/simple/redirect_to_none/') + response = self.client.get('/simple/redirect_to_none/') self.assertEqual(response.status_code, 410) def test_redirect_to_allows_formatted_url_string(self): "simple.redirect_to uses string interpolation on target url for keyword args" - response = self.client.get('/views/simple/redirect_to_arg/42/') + response = self.client.get('/simple/redirect_to_arg/42/') self.assertEqual(response.status_code, 301) - self.assertEqual('http://testserver/views/simple/target_arg/42/', response['Location']) + self.assertEqual('http://testserver/simple/target_arg/42/', response['Location']) def test_redirect_to_allows_query_string_to_be_passed(self): "simple.redirect_to configured with query_string=True passes on any query string" # the default is to not forward the query string - response = self.client.get('/views/simple/redirect_to/?param1=foo¶m2=bar') + response = self.client.get('/simple/redirect_to/?param1=foo¶m2=bar') self.assertEqual(response.status_code, 301) - self.assertEqual('http://testserver/views/simple/target/', response['Location']) + self.assertEqual('http://testserver/simple/target/', response['Location']) # views configured with query_string=True however passes the query string along - response = self.client.get('/views/simple/redirect_to_query/?param1=foo¶m2=bar') + response = self.client.get('/simple/redirect_to_query/?param1=foo¶m2=bar') self.assertEqual(response.status_code, 301) - self.assertEqual('http://testserver/views/simple/target/?param1=foo¶m2=bar', response['Location']) + self.assertEqual('http://testserver/simple/target/?param1=foo¶m2=bar', response['Location']) diff --git a/tests/regressiontests/views/tests/shortcuts.py b/tests/regressiontests/views/tests/shortcuts.py index 4dc2f2e99e..24bf6bbae4 100644 --- a/tests/regressiontests/views/tests/shortcuts.py +++ b/tests/regressiontests/views/tests/shortcuts.py @@ -4,6 +4,8 @@ from django.conf import settings from django.test import TestCase class ShortcutTests(TestCase): + urls = 'regressiontests.views.generic_urls' + def setUp(self): self.save_warnings_state() warnings.filterwarnings('ignore', category=DeprecationWarning, @@ -25,51 +27,51 @@ class ShortcutTests(TestCase): settings.TEMPLATE_CONTEXT_PROCESSORS = self.old_TEMPLATE_CONTEXT_PROCESSORS def test_render_to_response(self): - response = self.client.get('/views/shortcuts/render_to_response/') + response = self.client.get('/shortcuts/render_to_response/') self.assertEqual(response.status_code, 200) self.assertEqual(response.content, 'FOO.BAR..\n') self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8') def test_render_to_response_with_request_context(self): - response = self.client.get('/views/shortcuts/render_to_response/request_context/') + response = self.client.get('/shortcuts/render_to_response/request_context/') self.assertEqual(response.status_code, 200) self.assertEqual(response.content, 'FOO.BAR../path/to/static/media/\n') self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8') def test_render_to_response_with_mimetype(self): - response = self.client.get('/views/shortcuts/render_to_response/mimetype/') + response = self.client.get('/shortcuts/render_to_response/mimetype/') self.assertEqual(response.status_code, 200) self.assertEqual(response.content, 'FOO.BAR..\n') self.assertEqual(response['Content-Type'], 'application/x-rendertest') def test_render(self): - response = self.client.get('/views/shortcuts/render/') + response = self.client.get('/shortcuts/render/') self.assertEqual(response.status_code, 200) self.assertEqual(response.content, 'FOO.BAR../path/to/static/media/\n') self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8') self.assertEqual(response.context.current_app, None) def test_render_with_base_context(self): - response = self.client.get('/views/shortcuts/render/base_context/') + response = self.client.get('/shortcuts/render/base_context/') self.assertEqual(response.status_code, 200) self.assertEqual(response.content, 'FOO.BAR..\n') self.assertEqual(response['Content-Type'], 'text/html; charset=utf-8') def test_render_with_content_type(self): - response = self.client.get('/views/shortcuts/render/content_type/') + response = self.client.get('/shortcuts/render/content_type/') self.assertEqual(response.status_code, 200) self.assertEqual(response.content, 'FOO.BAR../path/to/static/media/\n') self.assertEqual(response['Content-Type'], 'application/x-rendertest') def test_render_with_status(self): - response = self.client.get('/views/shortcuts/render/status/') + response = self.client.get('/shortcuts/render/status/') self.assertEqual(response.status_code, 403) self.assertEqual(response.content, 'FOO.BAR../path/to/static/media/\n') def test_render_with_current_app(self): - response = self.client.get('/views/shortcuts/render/current_app/') + response = self.client.get('/shortcuts/render/current_app/') self.assertEqual(response.context.current_app, "foobar_app") def test_render_with_current_app_conflict(self): - self.assertRaises(ValueError, self.client.get, '/views/shortcuts/render/current_app_conflict/') + self.assertRaises(ValueError, self.client.get, '/shortcuts/render/current_app_conflict/') diff --git a/tests/regressiontests/views/tests/specials.py b/tests/regressiontests/views/tests/specials.py index bcdffca9cd..7855704bed 100644 --- a/tests/regressiontests/views/tests/specials.py +++ b/tests/regressiontests/views/tests/specials.py @@ -1,11 +1,23 @@ # coding: utf-8 +import warnings + from django.test import TestCase + class URLHandling(TestCase): """ Tests for URL handling in views and responses. """ - redirect_target = "/views/%E4%B8%AD%E6%96%87/target/" + urls = 'regressiontests.views.generic_urls' + redirect_target = "/%E4%B8%AD%E6%96%87/target/" + + def setUp(self): + self.save_warnings_state() + warnings.filterwarnings('ignore', category=DeprecationWarning, + module='django.views.generic.simple') + + def tearDown(self): + self.restore_warnings_state() def test_combining_redirect(self): """ @@ -15,14 +27,14 @@ class URLHandling(TestCase): characters so this test ensures the creation of the full path with a base non-ASCII part is handled correctly. """ - response = self.client.get(u'/views/中文/') + response = self.client.get(u'/中文/') self.assertRedirects(response, self.redirect_target) def test_nonascii_redirect(self): """ Tests that a non-ASCII argument to HttpRedirect is handled properly. """ - response = self.client.get('/views/nonascii_redirect/') + response = self.client.get('/nonascii_redirect/') self.assertRedirects(response, self.redirect_target) def test_permanent_nonascii_redirect(self): @@ -30,6 +42,6 @@ class URLHandling(TestCase): Tests that a non-ASCII argument to HttpPermanentRedirect is handled properly. """ - response = self.client.get('/views/permanent_nonascii_redirect/') + response = self.client.get('/permanent_nonascii_redirect/') self.assertRedirects(response, self.redirect_target, status_code=301) diff --git a/tests/regressiontests/views/urls.py b/tests/regressiontests/views/urls.py index b7ff3efbdc..32f03b444e 100644 --- a/tests/regressiontests/views/urls.py +++ b/tests/regressiontests/views/urls.py @@ -3,7 +3,6 @@ from os import path from django.conf.urls.defaults import * -from models import * import views @@ -31,25 +30,6 @@ js_info_dict_multi_packages2 = { 'packages': ('regressiontests.views.app3', 'regressiontests.views.app4'), } -date_based_info_dict = { - 'queryset': Article.objects.all(), - 'date_field': 'date_created', - 'month_format': '%m', -} - -object_list_dict = { - 'queryset': Article.objects.all(), - 'paginate_by': 2, -} - -object_list_no_paginate_by = { - 'queryset': Article.objects.all(), -} - -numeric_days_info_dict = dict(date_based_info_dict, day_format='%d') - -date_based_datefield_info_dict = dict(date_based_info_dict, queryset=DateArticle.objects.all()) - urlpatterns = patterns('', (r'^$', views.index_page), @@ -58,6 +38,10 @@ urlpatterns = patterns('', (r'^non_existing_url/', 'django.views.defaults.page_not_found'), (r'^server_error/', 'django.views.defaults.server_error'), + # a view that raises an exception for the debug view + (r'^raises/$', views.raises), + (r'^raises404/$', views.raises404), + # i18n views (r'^i18n/', include('django.conf.urls.i18n')), (r'^jsi18n/$', 'django.views.i18n.javascript_catalog', js_info_dict), @@ -67,100 +51,10 @@ urlpatterns = patterns('', # Static views (r'^site_media/(?P.*)$', 'django.views.static.serve', {'document_root': media_dir}), - - # Special URLs for particular regression cases. - url(u'^中文/$', 'regressiontests.views.views.redirect'), - url(u'^中文/target/$', 'regressiontests.views.views.index_page'), -) - -# Date-based generic views. -urlpatterns += patterns('django.views.generic.date_based', - (r'^date_based/object_detail/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})/(?P[-\w]+)/$', - 'object_detail', - dict(slug_field='slug', **date_based_info_dict)), - (r'^date_based/object_detail/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})/(?P[-\w]+)/allow_future/$', - 'object_detail', - dict(allow_future=True, slug_field='slug', **date_based_info_dict)), - (r'^date_based/archive_day/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})/$', - 'archive_day', - numeric_days_info_dict), - (r'^date_based/archive_month/(?P\d{4})/(?P\d{1,2})/$', - 'archive_month', - date_based_info_dict), - (r'^date_based/datefield/archive_month/(?P\d{4})/(?P\d{1,2})/$', - 'archive_month', - date_based_datefield_info_dict), -) - -# crud generic views. -urlpatterns += patterns('django.views.generic.create_update', - (r'^create_update/member/create/article/$', 'create_object', - dict(login_required=True, model=Article)), - (r'^create_update/create/article/$', 'create_object', - dict(post_save_redirect='/views/create_update/view/article/%(slug)s/', - model=Article)), - (r'^create_update/update/article/(?P[-\w]+)/$', 'update_object', - dict(post_save_redirect='/views/create_update/view/article/%(slug)s/', - slug_field='slug', model=Article)), - (r'^create_update/create_custom/article/$', views.custom_create), - (r'^create_update/delete/article/(?P[-\w]+)/$', 'delete_object', - dict(post_delete_redirect='/views/create_update/', slug_field='slug', - model=Article)), - - # No post_save_redirect and no get_absolute_url on model. - (r'^create_update/no_redirect/create/article/$', 'create_object', - dict(model=Article)), - (r'^create_update/no_redirect/update/article/(?P[-\w]+)/$', - 'update_object', dict(slug_field='slug', model=Article)), - - # get_absolute_url on model, but no passed post_save_redirect. - (r'^create_update/no_url/create/article/$', 'create_object', - dict(model=UrlArticle)), - (r'^create_update/no_url/update/article/(?P[-\w]+)/$', - 'update_object', dict(slug_field='slug', model=UrlArticle)), -) - -urlpatterns += patterns('django.views.generic.list_detail', - (r'^object_list/page(?P[\w]*)/$', 'object_list', object_list_dict), - (r'^object_list_no_paginate_by/page(?P[0-9]+)/$', 'object_list', - object_list_no_paginate_by), -) - -# a view that raises an exception for the debug view -urlpatterns += patterns('', - (r'^raises/$', views.raises), - (r'^raises404/$', views.raises404), -) - -# rediriects, both temporary and permanent, with non-ASCII targets -urlpatterns += patterns('django.views.generic.simple', - ('^nonascii_redirect/$', 'redirect_to', - {'url': u'/views/中文/target/', 'permanent': False}), - ('^permanent_nonascii_redirect/$', 'redirect_to', - {'url': u'/views/中文/target/', 'permanent': True}), ) urlpatterns += patterns('regressiontests.views.views', url(r'view_exception/(?P\d+)/$', 'view_exception', name='view_exception'), url(r'template_exception/(?P\d+)/$', 'template_exception', name='template_exception'), url(r'^raises_template_does_not_exist/$', 'raises_template_does_not_exist', name='raises_template_does_not_exist'), - - (r'^shortcuts/render_to_response/$', 'render_to_response_view'), - (r'^shortcuts/render_to_response/request_context/$', 'render_to_response_view_with_request_context'), - (r'^shortcuts/render_to_response/mimetype/$', 'render_to_response_view_with_mimetype'), - (r'^shortcuts/render/$', 'render_view'), - (r'^shortcuts/render/base_context/$', 'render_view_with_base_context'), - (r'^shortcuts/render/content_type/$', 'render_view_with_content_type'), - (r'^shortcuts/render/status/$', 'render_view_with_status'), - (r'^shortcuts/render/current_app/$', 'render_view_with_current_app'), - (r'^shortcuts/render/current_app_conflict/$', 'render_view_with_current_app_conflict'), -) - -# simple generic views. -urlpatterns += patterns('django.views.generic.simple', - (r'^simple/redirect_to/$', 'redirect_to', dict(url='/views/simple/target/')), - (r'^simple/redirect_to_temp/$', 'redirect_to', dict(url='/views/simple/target/', permanent=False)), - (r'^simple/redirect_to_none/$', 'redirect_to', dict(url=None)), - (r'^simple/redirect_to_arg/(?P\d+)/$', 'redirect_to', dict(url='/views/simple/target_arg/%(id)s/')), - (r'^simple/redirect_to_query/$', 'redirect_to', dict(url='/views/simple/target/', query_string=True)), ) diff --git a/tests/regressiontests/views/views.py b/tests/regressiontests/views/views.py index 7226530d57..11d289f2bb 100644 --- a/tests/regressiontests/views/views.py +++ b/tests/regressiontests/views/views.py @@ -32,7 +32,7 @@ def custom_create(request): from django.views.generic.create_update import create_object return create_object(request, - post_save_redirect='/views/create_update/view/article/%(slug)s/', + post_save_redirect='/create_update/view/article/%(slug)s/', form_class=SlugChangingArticleForm) def raises(request):