mirror of https://github.com/django/django.git
Deprecated django.views.defaults.shortcut.
This commit is contained in:
parent
2f121dfe63
commit
3f2befc931
|
@ -1,5 +1,10 @@
|
|||
import warnings
|
||||
|
||||
from django.conf.urls import patterns
|
||||
|
||||
warnings.warn("django.conf.urls.shortcut will be removed in Django 1.8.",
|
||||
PendingDeprecationWarning)
|
||||
|
||||
urlpatterns = patterns('django.views',
|
||||
(r'^(?P<content_type_id>\d+)/(?P<object_id>.*)/$', 'defaults.shortcut'),
|
||||
)
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import warnings
|
||||
|
||||
from django import http
|
||||
from django.template import (Context, RequestContext,
|
||||
loader, Template, TemplateDoesNotExist)
|
||||
|
@ -63,12 +65,9 @@ def permission_denied(request, template_name='403.html'):
|
|||
|
||||
|
||||
def shortcut(request, content_type_id, object_id):
|
||||
# TODO: Remove this in Django 2.0.
|
||||
# This is a legacy view that depends on the contenttypes framework.
|
||||
# The core logic was moved to django.contrib.contenttypes.views after
|
||||
# Django 1.0, but this remains here for backwards compatibility.
|
||||
# Note that the import is *within* this function, rather than being at
|
||||
# module level, because we don't want to assume people have contenttypes
|
||||
# installed.
|
||||
warnings.warn(
|
||||
"django.views.defaults.shortcut will be removed in Django 1.8. "
|
||||
"Import it from django.contrib.contenttypes.views instead.",
|
||||
PendingDeprecationWarning, stacklevel=2)
|
||||
from django.contrib.contenttypes.views import shortcut as real_shortcut
|
||||
return real_shortcut(request, content_type_id, object_id)
|
||||
|
|
|
@ -362,6 +362,9 @@ these changes.
|
|||
* Remove the backward compatible shims introduced to rename the attributes
|
||||
``ChangeList.root_query_set`` and ``ChangeList.query_set``.
|
||||
|
||||
* ``django.conf.urls.shortcut`` and ``django.views.defaults.shortcut`` will be
|
||||
removed.
|
||||
|
||||
* The following private APIs will be removed:
|
||||
|
||||
- ``django.db.close_connection()``
|
||||
|
|
|
@ -352,3 +352,20 @@ private API, it will go through a regular deprecation path.
|
|||
|
||||
Methods that return a ``QuerySet`` such as ``Manager.get_query_set`` or
|
||||
``ModelAdmin.queryset`` have been renamed to ``get_queryset``.
|
||||
|
||||
``shortcut`` view and URLconf
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
The ``shortcut`` view was moved from ``django.views.defaults`` to
|
||||
``django.contrib.contentypes.views`` shortly after the 1.0 release, but the
|
||||
old location was never deprecated. This oversight was corrected in Django 1.6
|
||||
and you should now use the new location.
|
||||
|
||||
The URLconf ``django.conf.urls.shortcut`` was also deprecated. If you're
|
||||
including it in an URLconf, simply replace::
|
||||
|
||||
(r'^prefix/', include('django.conf.urls.shortcut')),
|
||||
|
||||
with::
|
||||
|
||||
(r'^prefix/(?P<content_type_id>\d+)/(?P<object_id>.*)/$', 'django.contrib.contentypes.views'),
|
||||
|
|
|
@ -330,7 +330,6 @@ itself. It includes a number of other URLconfs::
|
|||
(r'^comments/', include('django.contrib.comments.urls')),
|
||||
(r'^community/', include('django_website.aggregator.urls')),
|
||||
(r'^contact/', include('django_website.contact.urls')),
|
||||
(r'^r/', include('django.conf.urls.shortcut')),
|
||||
# ... snip ...
|
||||
)
|
||||
|
||||
|
|
|
@ -0,0 +1,47 @@
|
|||
[
|
||||
{
|
||||
"pk": 1,
|
||||
"model": "contenttypes_tests.author",
|
||||
"fields": {
|
||||
"name": "Boris"
|
||||
}
|
||||
},
|
||||
{
|
||||
"pk": 1,
|
||||
"model": "contenttypes_tests.article",
|
||||
"fields": {
|
||||
"author": 1,
|
||||
"title": "Old Article",
|
||||
"slug": "old_article",
|
||||
"date_created": "2001-01-01 21:22:23"
|
||||
}
|
||||
},
|
||||
{
|
||||
"pk": 2,
|
||||
"model": "contenttypes_tests.article",
|
||||
"fields": {
|
||||
"author": 1,
|
||||
"title": "Current Article",
|
||||
"slug": "current_article",
|
||||
"date_created": "2007-09-17 21:22:23"
|
||||
}
|
||||
},
|
||||
{
|
||||
"pk": 3,
|
||||
"model": "contenttypes_tests.article",
|
||||
"fields": {
|
||||
"author": 1,
|
||||
"title": "Future Article",
|
||||
"slug": "future_article",
|
||||
"date_created": "3000-01-01 21:22:23"
|
||||
}
|
||||
},
|
||||
{
|
||||
"pk": 1,
|
||||
"model": "sites.site",
|
||||
"fields": {
|
||||
"domain": "testserver",
|
||||
"name": "testserver"
|
||||
}
|
||||
}
|
||||
]
|
|
@ -0,0 +1,24 @@
|
|||
from __future__ import absolute_import, unicode_literals
|
||||
|
||||
from django.db import models
|
||||
from django.utils.encoding import python_2_unicode_compatible
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Author(models.Model):
|
||||
name = models.CharField(max_length=100)
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
def get_absolute_url(self):
|
||||
return '/views/authors/%s/' % self.id
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Article(models.Model):
|
||||
title = models.CharField(max_length=100)
|
||||
slug = models.SlugField()
|
||||
author = models.ForeignKey(Author)
|
||||
date_created = models.DateTimeField()
|
||||
|
||||
def __str__(self):
|
||||
return self.title
|
|
@ -0,0 +1,47 @@
|
|||
from __future__ import absolute_import, unicode_literals
|
||||
|
||||
from django.contrib.contenttypes.models import ContentType
|
||||
from django.test import TestCase
|
||||
|
||||
from .models import Author, Article
|
||||
|
||||
class ContentTypesViewsTests(TestCase):
|
||||
fixtures = ['testdata.json']
|
||||
urls = 'contenttypes_tests.urls'
|
||||
|
||||
def test_shortcut_with_absolute_url(self):
|
||||
"Can view a shortcut for an Author object that has a get_absolute_url method"
|
||||
for obj in Author.objects.all():
|
||||
short_url = '/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Author).id, obj.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertRedirects(response, 'http://testserver%s' % obj.get_absolute_url(),
|
||||
status_code=302, target_status_code=404)
|
||||
|
||||
def test_shortcut_no_absolute_url(self):
|
||||
"Shortcuts for an object that has no get_absolute_url method raises 404"
|
||||
for obj in Article.objects.all():
|
||||
short_url = '/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Article).id, obj.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_wrong_type_pk(self):
|
||||
short_url = '/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Author).id, 'nobody/expects')
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_shortcut_bad_pk(self):
|
||||
short_url = '/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Author).id, '42424242')
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_nonint_content_type(self):
|
||||
an_author = Author.objects.all()[0]
|
||||
short_url = '/shortcut/%s/%s/' % ('spam', an_author.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_bad_content_type(self):
|
||||
an_author = Author.objects.all()[0]
|
||||
short_url = '/shortcut/%s/%s/' % (42424242, an_author.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
|
@ -0,0 +1,7 @@
|
|||
from __future__ import absolute_import, unicode_literals
|
||||
|
||||
from django.conf.urls import patterns
|
||||
|
||||
urlpatterns = patterns('',
|
||||
(r'^shortcut/(\d+)/(.*)/$', 'django.contrib.contenttypes.views.shortcut'),
|
||||
)
|
|
@ -13,43 +13,6 @@ class DefaultsTests(TestCase):
|
|||
non_existing_urls = ['/views/non_existing_url/', # this is in urls.py
|
||||
'/views/other_non_existing_url/'] # this NOT in urls.py
|
||||
|
||||
def test_shortcut_with_absolute_url(self):
|
||||
"Can view a shortcut for an Author object that has a get_absolute_url method"
|
||||
for obj in Author.objects.all():
|
||||
short_url = '/views/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Author).id, obj.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertRedirects(response, 'http://testserver%s' % obj.get_absolute_url(),
|
||||
status_code=302, target_status_code=404)
|
||||
|
||||
def test_shortcut_no_absolute_url(self):
|
||||
"Shortcuts for an object that has no get_absolute_url method raises 404"
|
||||
for obj in Article.objects.all():
|
||||
short_url = '/views/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Article).id, obj.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_wrong_type_pk(self):
|
||||
short_url = '/views/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Author).id, 'nobody/expects')
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_shortcut_bad_pk(self):
|
||||
short_url = '/views/shortcut/%s/%s/' % (ContentType.objects.get_for_model(Author).id, '42424242')
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_nonint_content_type(self):
|
||||
an_author = Author.objects.all()[0]
|
||||
short_url = '/views/shortcut/%s/%s/' % ('spam', an_author.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_bad_content_type(self):
|
||||
an_author = Author.objects.all()[0]
|
||||
short_url = '/views/shortcut/%s/%s/' % (42424242, an_author.pk)
|
||||
response = self.client.get(short_url)
|
||||
self.assertEqual(response.status_code, 404)
|
||||
|
||||
def test_page_not_found(self):
|
||||
"A 404 status is returned by the page_not_found view"
|
||||
for url in self.non_existing_urls:
|
||||
|
|
|
@ -42,7 +42,6 @@ urlpatterns = patterns('',
|
|||
(r'^$', views.index_page),
|
||||
|
||||
# Default views
|
||||
(r'^shortcut/(\d+)/(.*)/$', 'django.views.defaults.shortcut'),
|
||||
(r'^non_existing_url/', 'django.views.defaults.page_not_found'),
|
||||
(r'^server_error/', 'django.views.defaults.server_error'),
|
||||
|
||||
|
|
Loading…
Reference in New Issue