2012-04-29 15:37:23 +02:00
|
|
|
import datetime
|
2017-01-19 12:16:04 -05:00
|
|
|
from unittest import mock
|
2016-10-07 21:06:49 -04:00
|
|
|
|
|
|
|
import pytz
|
2013-07-01 14:22:27 +02:00
|
|
|
|
2019-09-06 07:59:06 +02:00
|
|
|
from django.test import SimpleTestCase, override_settings
|
2015-01-28 07:35:27 -05:00
|
|
|
from django.utils import timezone
|
|
|
|
|
2016-10-07 21:06:49 -04:00
|
|
|
CET = pytz.timezone("Europe/Paris")
|
2013-09-08 02:04:31 -05:00
|
|
|
EAT = timezone.get_fixed_timezone(180) # Africa/Nairobi
|
|
|
|
ICT = timezone.get_fixed_timezone(420) # Asia/Bangkok
|
2013-01-31 16:00:39 +01:00
|
|
|
|
2016-08-09 18:14:15 -04:00
|
|
|
|
|
|
|
class TimezoneTests(SimpleTestCase):
|
2011-11-18 13:01:06 +00:00
|
|
|
|
2012-04-29 15:37:23 +02:00
|
|
|
def test_now(self):
|
|
|
|
with override_settings(USE_TZ=True):
|
|
|
|
self.assertTrue(timezone.is_aware(timezone.now()))
|
|
|
|
with override_settings(USE_TZ=False):
|
|
|
|
self.assertTrue(timezone.is_naive(timezone.now()))
|
|
|
|
|
2016-08-31 17:19:33 -07:00
|
|
|
def test_localdate(self):
|
|
|
|
naive = datetime.datetime(2015, 1, 1, 0, 0, 1)
|
2016-11-05 12:33:22 +01:00
|
|
|
with self.assertRaisesMessage(ValueError, 'localtime() cannot be applied to a naive datetime'):
|
|
|
|
timezone.localdate(naive)
|
|
|
|
with self.assertRaisesMessage(ValueError, 'localtime() cannot be applied to a naive datetime'):
|
|
|
|
timezone.localdate(naive, timezone=EAT)
|
2016-08-31 17:19:33 -07:00
|
|
|
|
|
|
|
aware = datetime.datetime(2015, 1, 1, 0, 0, 1, tzinfo=ICT)
|
|
|
|
self.assertEqual(timezone.localdate(aware, timezone=EAT), datetime.date(2014, 12, 31))
|
|
|
|
with timezone.override(EAT):
|
|
|
|
self.assertEqual(timezone.localdate(aware), datetime.date(2014, 12, 31))
|
|
|
|
|
|
|
|
with mock.patch('django.utils.timezone.now', return_value=aware):
|
|
|
|
self.assertEqual(timezone.localdate(timezone=EAT), datetime.date(2014, 12, 31))
|
|
|
|
with timezone.override(EAT):
|
|
|
|
self.assertEqual(timezone.localdate(), datetime.date(2014, 12, 31))
|
|
|
|
|
2013-01-31 16:00:39 +01:00
|
|
|
def test_override(self):
|
|
|
|
default = timezone.get_default_timezone()
|
|
|
|
try:
|
|
|
|
timezone.activate(ICT)
|
|
|
|
|
|
|
|
with timezone.override(EAT):
|
|
|
|
self.assertIs(EAT, timezone.get_current_timezone())
|
|
|
|
self.assertIs(ICT, timezone.get_current_timezone())
|
|
|
|
|
|
|
|
with timezone.override(None):
|
|
|
|
self.assertIs(default, timezone.get_current_timezone())
|
|
|
|
self.assertIs(ICT, timezone.get_current_timezone())
|
|
|
|
|
|
|
|
timezone.deactivate()
|
|
|
|
|
|
|
|
with timezone.override(EAT):
|
|
|
|
self.assertIs(EAT, timezone.get_current_timezone())
|
|
|
|
self.assertIs(default, timezone.get_current_timezone())
|
|
|
|
|
|
|
|
with timezone.override(None):
|
|
|
|
self.assertIs(default, timezone.get_current_timezone())
|
|
|
|
self.assertIs(default, timezone.get_current_timezone())
|
|
|
|
finally:
|
|
|
|
timezone.deactivate()
|
|
|
|
|
2014-08-30 20:06:38 +02:00
|
|
|
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()
|
|
|
|
|
2016-11-01 14:01:40 -04:00
|
|
|
def test_override_string_tz(self):
|
|
|
|
with timezone.override('Asia/Bangkok'):
|
|
|
|
self.assertEqual(timezone.get_current_timezone_name(), 'Asia/Bangkok')
|
|
|
|
|
|
|
|
def test_override_fixed_offset(self):
|
2018-07-10 01:33:36 +05:00
|
|
|
with timezone.override(datetime.timezone(datetime.timedelta(), 'tzname')):
|
2016-11-01 14:01:40 -04:00
|
|
|
self.assertEqual(timezone.get_current_timezone_name(), 'tzname')
|
|
|
|
|
|
|
|
def test_activate_invalid_timezone(self):
|
|
|
|
with self.assertRaisesMessage(ValueError, 'Invalid timezone: None'):
|
|
|
|
timezone.activate(None)
|
|
|
|
|
2014-05-16 22:52:10 +02:00
|
|
|
def test_is_aware(self):
|
|
|
|
self.assertTrue(timezone.is_aware(datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=EAT)))
|
|
|
|
self.assertFalse(timezone.is_aware(datetime.datetime(2011, 9, 1, 13, 20, 30)))
|
|
|
|
|
|
|
|
def test_is_naive(self):
|
|
|
|
self.assertFalse(timezone.is_naive(datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=EAT)))
|
|
|
|
self.assertTrue(timezone.is_naive(datetime.datetime(2011, 9, 1, 13, 20, 30)))
|
|
|
|
|
|
|
|
def test_make_aware(self):
|
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_aware(datetime.datetime(2011, 9, 1, 13, 20, 30), EAT),
|
|
|
|
datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=EAT))
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
timezone.make_aware(datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=EAT), EAT)
|
|
|
|
|
|
|
|
def test_make_naive(self):
|
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_naive(datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=EAT), EAT),
|
|
|
|
datetime.datetime(2011, 9, 1, 13, 20, 30))
|
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_naive(datetime.datetime(2011, 9, 1, 17, 20, 30, tzinfo=ICT), EAT),
|
|
|
|
datetime.datetime(2011, 9, 1, 13, 20, 30))
|
2016-08-09 18:14:15 -04:00
|
|
|
|
2016-11-05 12:33:22 +01:00
|
|
|
with self.assertRaisesMessage(ValueError, 'make_naive() cannot be applied to a naive datetime'):
|
|
|
|
timezone.make_naive(datetime.datetime(2011, 9, 1, 13, 20, 30), EAT)
|
2014-05-16 23:12:59 +02:00
|
|
|
|
2016-11-01 14:01:40 -04:00
|
|
|
def test_make_naive_no_tz(self):
|
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_naive(datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=EAT)),
|
|
|
|
datetime.datetime(2011, 9, 1, 5, 20, 30)
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_make_aware_no_tz(self):
|
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_aware(datetime.datetime(2011, 9, 1, 13, 20, 30)),
|
|
|
|
datetime.datetime(2011, 9, 1, 13, 20, 30, tzinfo=timezone.get_fixed_timezone(-300))
|
|
|
|
)
|
|
|
|
|
2014-05-17 09:54:34 -07:00
|
|
|
def test_make_aware2(self):
|
2014-05-16 23:12:59 +02:00
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_aware(datetime.datetime(2011, 9, 1, 12, 20, 30), CET),
|
|
|
|
CET.localize(datetime.datetime(2011, 9, 1, 12, 20, 30)))
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
timezone.make_aware(CET.localize(datetime.datetime(2011, 9, 1, 12, 20, 30)), CET)
|
|
|
|
|
|
|
|
def test_make_aware_pytz(self):
|
|
|
|
self.assertEqual(
|
|
|
|
timezone.make_naive(CET.localize(datetime.datetime(2011, 9, 1, 12, 20, 30)), CET),
|
|
|
|
datetime.datetime(2011, 9, 1, 12, 20, 30))
|
|
|
|
self.assertEqual(
|
2015-09-11 19:33:12 -04:00
|
|
|
timezone.make_naive(
|
|
|
|
pytz.timezone("Asia/Bangkok").localize(datetime.datetime(2011, 9, 1, 17, 20, 30)), CET
|
|
|
|
),
|
2014-05-16 23:12:59 +02:00
|
|
|
datetime.datetime(2011, 9, 1, 12, 20, 30))
|
2016-11-05 12:33:22 +01:00
|
|
|
with self.assertRaisesMessage(ValueError, 'make_naive() cannot be applied to a naive datetime'):
|
|
|
|
timezone.make_naive(datetime.datetime(2011, 9, 1, 12, 20, 30), CET)
|
2015-03-31 16:58:37 +11:00
|
|
|
|
|
|
|
def test_make_aware_pytz_ambiguous(self):
|
|
|
|
# 2:30 happens twice, once before DST ends and once after
|
|
|
|
ambiguous = datetime.datetime(2015, 10, 25, 2, 30)
|
|
|
|
|
|
|
|
with self.assertRaises(pytz.AmbiguousTimeError):
|
|
|
|
timezone.make_aware(ambiguous, timezone=CET)
|
|
|
|
|
|
|
|
std = timezone.make_aware(ambiguous, timezone=CET, is_dst=False)
|
|
|
|
dst = timezone.make_aware(ambiguous, timezone=CET, is_dst=True)
|
|
|
|
self.assertEqual(std - dst, datetime.timedelta(hours=1))
|
|
|
|
self.assertEqual(std.tzinfo.utcoffset(std), datetime.timedelta(hours=1))
|
|
|
|
self.assertEqual(dst.tzinfo.utcoffset(dst), datetime.timedelta(hours=2))
|
|
|
|
|
|
|
|
def test_make_aware_pytz_non_existent(self):
|
|
|
|
# 2:30 never happened due to DST
|
|
|
|
non_existent = datetime.datetime(2015, 3, 29, 2, 30)
|
|
|
|
|
|
|
|
with self.assertRaises(pytz.NonExistentTimeError):
|
|
|
|
timezone.make_aware(non_existent, timezone=CET)
|
|
|
|
|
|
|
|
std = timezone.make_aware(non_existent, timezone=CET, is_dst=False)
|
|
|
|
dst = timezone.make_aware(non_existent, timezone=CET, is_dst=True)
|
|
|
|
self.assertEqual(std - dst, datetime.timedelta(hours=1))
|
|
|
|
self.assertEqual(std.tzinfo.utcoffset(std), datetime.timedelta(hours=1))
|
|
|
|
self.assertEqual(dst.tzinfo.utcoffset(dst), datetime.timedelta(hours=2))
|
2016-11-01 14:01:40 -04:00
|
|
|
|
|
|
|
def test_get_default_timezone(self):
|
|
|
|
self.assertEqual(timezone.get_default_timezone_name(), 'America/Chicago')
|
|
|
|
|
2018-06-28 09:30:10 -04:00
|
|
|
def test_get_default_timezone_utc(self):
|
|
|
|
with override_settings(USE_TZ=True, TIME_ZONE='UTC'):
|
|
|
|
self.assertIs(timezone.get_default_timezone(), timezone.utc)
|
|
|
|
|
2016-11-01 14:01:40 -04:00
|
|
|
def test_fixedoffset_timedelta(self):
|
|
|
|
delta = datetime.timedelta(hours=1)
|
2018-07-10 01:33:36 +05:00
|
|
|
self.assertEqual(timezone.get_fixed_timezone(delta).utcoffset(None), delta)
|
2016-11-01 14:01:40 -04:00
|
|
|
|
2017-10-24 12:42:44 -07:00
|
|
|
def test_fixedoffset_negative_timedelta(self):
|
|
|
|
delta = datetime.timedelta(hours=-2)
|
2018-07-10 01:33:36 +05:00
|
|
|
self.assertEqual(timezone.get_fixed_timezone(delta).utcoffset(None), delta)
|