mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Deprecated legacy ways of calling cache_page
git-svn-id: http://code.djangoproject.com/svn/django/trunk@16338 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -39,8 +39,16 @@ def cache_page(*args, **kwargs): | |||||||
|     cache_alias = kwargs.pop('cache', None) |     cache_alias = kwargs.pop('cache', None) | ||||||
|     key_prefix = kwargs.pop('key_prefix', None) |     key_prefix = kwargs.pop('key_prefix', None) | ||||||
|     assert not kwargs, "The only keyword arguments are cache and key_prefix" |     assert not kwargs, "The only keyword arguments are cache and key_prefix" | ||||||
|  |     def warn(): | ||||||
|  |         import warnings | ||||||
|  |         warnings.warn('The cache_page decorator must be called like: ' | ||||||
|  |                       'cache_page(timeout, [cache=cache name], [key_prefix=key prefix]). ' | ||||||
|  |                       'All other ways are deprecated.', | ||||||
|  |                       PendingDeprecationWarning) | ||||||
|  |  | ||||||
|     if len(args) > 1: |     if len(args) > 1: | ||||||
|         assert len(args) == 2, "cache_page accepts at most 2 arguments" |         assert len(args) == 2, "cache_page accepts at most 2 arguments" | ||||||
|  |         warn() | ||||||
|         if callable(args[0]): |         if callable(args[0]): | ||||||
|             return decorator_from_middleware_with_args(CacheMiddleware)(cache_timeout=args[1], cache_alias=cache_alias, key_prefix=key_prefix)(args[0]) |             return decorator_from_middleware_with_args(CacheMiddleware)(cache_timeout=args[1], cache_alias=cache_alias, key_prefix=key_prefix)(args[0]) | ||||||
|         elif callable(args[1]): |         elif callable(args[1]): | ||||||
| @@ -49,10 +57,13 @@ def cache_page(*args, **kwargs): | |||||||
|             assert False, "cache_page must be passed a view function if called with two arguments" |             assert False, "cache_page must be passed a view function if called with two arguments" | ||||||
|     elif len(args) == 1: |     elif len(args) == 1: | ||||||
|         if callable(args[0]): |         if callable(args[0]): | ||||||
|  |             warn() | ||||||
|             return decorator_from_middleware_with_args(CacheMiddleware)(cache_alias=cache_alias, key_prefix=key_prefix)(args[0]) |             return decorator_from_middleware_with_args(CacheMiddleware)(cache_alias=cache_alias, key_prefix=key_prefix)(args[0]) | ||||||
|         else: |         else: | ||||||
|  |             # The One True Way | ||||||
|             return decorator_from_middleware_with_args(CacheMiddleware)(cache_timeout=args[0], cache_alias=cache_alias, key_prefix=key_prefix) |             return decorator_from_middleware_with_args(CacheMiddleware)(cache_timeout=args[0], cache_alias=cache_alias, key_prefix=key_prefix) | ||||||
|     else: |     else: | ||||||
|  |         warn() | ||||||
|         return decorator_from_middleware_with_args(CacheMiddleware)(cache_alias=cache_alias, key_prefix=key_prefix) |         return decorator_from_middleware_with_args(CacheMiddleware)(cache_alias=cache_alias, key_prefix=key_prefix) | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -207,6 +207,9 @@ their deprecation, as per the :ref:`Django deprecation policy | |||||||
|           refactored to use class based views with pluggable backends in 1.4. |           refactored to use class based views with pluggable backends in 1.4. | ||||||
|           The previous implementation will be deprecated. |           The previous implementation will be deprecated. | ||||||
|  |  | ||||||
|  |         * Legacy ways of calling | ||||||
|  |           :func:`~django.views.decorators.cache.cache_page` will be removed. | ||||||
|  |  | ||||||
|     * 2.0 |     * 2.0 | ||||||
|         * ``django.views.defaults.shortcut()``. This function has been moved |         * ``django.views.defaults.shortcut()``. This function has been moved | ||||||
|           to ``django.contrib.contenttypes.views.shortcut()`` as part of the |           to ``django.contrib.contenttypes.views.shortcut()`` as part of the | ||||||
|   | |||||||
| @@ -8,10 +8,14 @@ up-to-date information for those who are following trunk. | |||||||
|  |  | ||||||
| Django 1.4 includes various `new features`_ and some minor `backwards | Django 1.4 includes various `new features`_ and some minor `backwards | ||||||
| incompatible changes`_. There are also some features that have been dropped, | incompatible changes`_. There are also some features that have been dropped, | ||||||
| which are detailed in :doc:`our deprecation plan </internals/deprecation>`. | which are detailed in :doc:`our deprecation plan </internals/deprecation>`, and | ||||||
|  | we've `begun the deprecation process for some features`_. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| .. _new features: `What's new in Django 1.4`_ | .. _new features: `What's new in Django 1.4`_ | ||||||
| .. _backwards incompatible changes: backwards-incompatible-changes-1.4_ | .. _backwards incompatible changes: backwards-incompatible-changes-1.4_ | ||||||
|  | .. _begun the deprecation process for some features: deprecated-features-1.4_ | ||||||
|  |  | ||||||
| What's new in Django 1.4 | What's new in Django 1.4 | ||||||
| ======================== | ======================== | ||||||
| @@ -284,3 +288,15 @@ If you using PUT or DELETE methods in AJAX applications, please see the | |||||||
| This was an alias to ``django.template.loader`` since 2005, it has been removed | This was an alias to ``django.template.loader`` since 2005, it has been removed | ||||||
| without emitting a warning due to the length of the deprecation. If your code | without emitting a warning due to the length of the deprecation. If your code | ||||||
| still referenced this please use ``django.template.loader`` instead. | still referenced this please use ``django.template.loader`` instead. | ||||||
|  |  | ||||||
|  | .. _deprecated-features-1.4: | ||||||
|  |  | ||||||
|  | Features deprecated in 1.4 | ||||||
|  | ========================== | ||||||
|  |  | ||||||
|  | Old styles of calling ``cache_page`` decorator | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | Some legacy ways of calling :func:`~django.views.decorators.cache.cache_page` | ||||||
|  | have been deprecated, please see the docs for the correct way to use this | ||||||
|  | decorator. | ||||||
|   | |||||||
| @@ -494,7 +494,7 @@ __ `Controlling cache: Using other headers`_ | |||||||
| The per-view cache | The per-view cache | ||||||
| ================== | ================== | ||||||
|  |  | ||||||
| .. function ``django.views.decorators.cache.cache_page`` | .. function:: django.views.decorators.cache.cache_page | ||||||
|  |  | ||||||
| A more granular way to use the caching framework is by caching the output of | A more granular way to use the caching framework is by caching the output of | ||||||
| individual views. ``django.views.decorators.cache`` defines a ``cache_page`` | individual views. ``django.views.decorators.cache`` defines a ``cache_page`` | ||||||
| @@ -571,7 +571,7 @@ Here's the same thing, with ``my_view`` wrapped in ``cache_page``:: | |||||||
|     from django.views.decorators.cache import cache_page |     from django.views.decorators.cache import cache_page | ||||||
|  |  | ||||||
|     urlpatterns = ('', |     urlpatterns = ('', | ||||||
|         (r'^foo/(\d{1,2})/$', cache_page(my_view, 60 * 15)), |         (r'^foo/(\d{1,2})/$', cache_page(60 * 15)(my_view)), | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
| If you take this approach, don't forget to import ``cache_page`` within your | If you take this approach, don't forget to import ``cache_page`` within your | ||||||
|   | |||||||
| @@ -1,8 +1,10 @@ | |||||||
| from functools import wraps | from functools import wraps | ||||||
|  | import warnings | ||||||
|  |  | ||||||
| from django.contrib.auth.decorators import login_required, permission_required, user_passes_test | from django.contrib.auth.decorators import login_required, permission_required, user_passes_test | ||||||
| from django.contrib.admin.views.decorators import staff_member_required | from django.contrib.admin.views.decorators import staff_member_required | ||||||
| from django.http import HttpResponse, HttpRequest, HttpResponseNotAllowed | from django.http import HttpResponse, HttpRequest, HttpResponseNotAllowed | ||||||
|  | from django.test.utils import get_warnings_state, restore_warnings_state | ||||||
| from django.utils.decorators import method_decorator | from django.utils.decorators import method_decorator | ||||||
| from django.utils.functional import allow_lazy, lazy, memoize | from django.utils.functional import allow_lazy, lazy, memoize | ||||||
| from django.utils.unittest import TestCase | from django.utils.unittest import TestCase | ||||||
| @@ -65,6 +67,14 @@ fully_decorated = full_decorator(fully_decorated) | |||||||
|  |  | ||||||
| class DecoratorsTest(TestCase): | class DecoratorsTest(TestCase): | ||||||
|  |  | ||||||
|  |     def setUp(self): | ||||||
|  |         self.warning_state = get_warnings_state() | ||||||
|  |         warnings.filterwarnings('ignore', category=PendingDeprecationWarning, | ||||||
|  |                                 module='django.views.decorators.cache') | ||||||
|  |  | ||||||
|  |     def tearDown(self): | ||||||
|  |         restore_warnings_state(self.warning_state) | ||||||
|  |  | ||||||
|     def test_attributes(self): |     def test_attributes(self): | ||||||
|         """ |         """ | ||||||
|         Tests that django decorators set certain attributes of the wrapped |         Tests that django decorators set certain attributes of the wrapped | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user