Fixed #23388 -- Made django.utils.timezone.override usable as a decorator

This commit is contained in:
Thomas Chaumeny 2014-08-30 20:06:38 +02:00 committed by Aymeric Augustin
parent 8b6cb9d0dd
commit 032c091659
3 changed files with 36 additions and 1 deletions

View File

@ -16,6 +16,7 @@ except ImportError:
from django.conf import settings
from django.utils import six
from django.utils.decorators import ContextDecorator
__all__ = [
'utc', 'get_fixed_timezone',
@ -248,7 +249,7 @@ def deactivate():
del _active.value
class override(object):
class override(ContextDecorator):
"""
Temporarily set the time zone for the current thread.

View File

@ -901,6 +901,10 @@ appropriate entities.
``None``, the :ref:`current time zone <default-current-time-zone>` is unset
on entry with :func:`deactivate()` instead.
.. versionchanged:: 1.8
``override`` is now usable as a function decorator.
.. function:: localtime(value, timezone=None)
Converts an aware :class:`~datetime.datetime` to a different time zone,

View File

@ -71,6 +71,36 @@ class TimezoneTests(unittest.TestCase):
finally:
timezone.deactivate()
def test_override_decorator(self):
default = timezone.get_default_timezone()
@timezone.override(EAT)
def func_tz_eat():
self.assertIs(EAT, timezone.get_current_timezone())
@timezone.override(None)
def func_tz_none():
self.assertIs(default, timezone.get_current_timezone())
try:
timezone.activate(ICT)
func_tz_eat()
self.assertIs(ICT, timezone.get_current_timezone())
func_tz_none()
self.assertIs(ICT, timezone.get_current_timezone())
timezone.deactivate()
func_tz_eat()
self.assertIs(default, timezone.get_current_timezone())
func_tz_none()
self.assertIs(default, timezone.get_current_timezone())
finally:
timezone.deactivate()
def test_copy(self):
self.assertIsInstance(copy.copy(timezone.UTC()), timezone.UTC)
self.assertIsInstance(copy.copy(timezone.LocalTimezone()), timezone.LocalTimezone)