mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #18766 -- Pointed to pytz when LocalTimezone fails.
Thanks void for the report.
This commit is contained in:
		| @@ -1,10 +1,12 @@ | ||||
| """Timezone helper functions. | ||||
| """ | ||||
| Timezone-related classes and functions. | ||||
|  | ||||
| This module uses pytz when it's available and fallbacks when it isn't. | ||||
| """ | ||||
|  | ||||
| from datetime import datetime, timedelta, tzinfo | ||||
| from threading import local | ||||
| import sys | ||||
| import time as _time | ||||
|  | ||||
| try: | ||||
| @@ -45,12 +47,14 @@ class UTC(tzinfo): | ||||
|     def dst(self, dt): | ||||
|         return ZERO | ||||
|  | ||||
| class LocalTimezone(tzinfo): | ||||
| class ReferenceLocalTimezone(tzinfo): | ||||
|     """ | ||||
|     Local time implementation taken from Python's docs. | ||||
|  | ||||
|     Used only when pytz isn't available, and most likely inaccurate. If you're | ||||
|     having trouble with this class, don't waste your time, just install pytz. | ||||
|  | ||||
|     Kept identical to the reference version. Subclasses contain improvements. | ||||
|     """ | ||||
|  | ||||
|     def __init__(self): | ||||
| @@ -91,6 +95,23 @@ class LocalTimezone(tzinfo): | ||||
|         tt = _time.localtime(stamp) | ||||
|         return tt.tm_isdst > 0 | ||||
|  | ||||
| class LocalTimezone(ReferenceLocalTimezone): | ||||
|     """ | ||||
|     Slightly improved local time implementation focusing on correctness. | ||||
|  | ||||
|     It still crashes on dates before 1970 or after 2038, but at least the | ||||
|     error message is helpful. | ||||
|     """ | ||||
|  | ||||
|     def _isdst(self, dt): | ||||
|         try: | ||||
|             return super(LocalTimezone, self)._isdst(dt) | ||||
|         except (OverflowError, ValueError) as exc: | ||||
|             exc_type = type(exc) | ||||
|             exc_value = exc_type( | ||||
|                     "Unsupported value: %r. You should install pytz." % dt) | ||||
|             exc_value.__cause__ = exc | ||||
|             six.reraise(exc_type, exc_value, sys.exc_info()[2]) | ||||
|  | ||||
| utc = pytz.utc if pytz else UTC() | ||||
| """UTC time zone as a tzinfo instance.""" | ||||
|   | ||||
| @@ -4,6 +4,7 @@ import pickle | ||||
| import unittest | ||||
|  | ||||
| from django.test.utils import override_settings | ||||
| from django.utils import six | ||||
| from django.utils import timezone | ||||
| from django.utils.tzinfo import FixedOffset | ||||
|  | ||||
| @@ -20,6 +21,12 @@ class TimezoneTests(unittest.TestCase): | ||||
|         local_now = timezone.localtime(now, local_tz) | ||||
|         self.assertEqual(local_now.tzinfo, local_tz) | ||||
|  | ||||
|     def test_localtime_out_of_range(self): | ||||
|         local_tz = timezone.LocalTimezone() | ||||
|         long_ago = datetime.datetime(1900, 1, 1, tzinfo=timezone.utc) | ||||
|         with six.assertRaisesRegex(self, OverflowError, "install pytz"): | ||||
|             timezone.localtime(long_ago, local_tz) | ||||
|  | ||||
|     def test_now(self): | ||||
|         with override_settings(USE_TZ=True): | ||||
|             self.assertTrue(timezone.is_aware(timezone.now())) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user