mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #21954: Raise nice error when serializing datetimes with timezones
This commit is contained in:
		| @@ -212,7 +212,12 @@ class MigrationWriter(object): | |||||||
|                 strings.append((k_string, v_string)) |                 strings.append((k_string, v_string)) | ||||||
|             return "{%s}" % (", ".join("%s: %s" % (k, v) for k, v in strings)), imports |             return "{%s}" % (", ".join("%s: %s" % (k, v) for k, v in strings)), imports | ||||||
|         # Datetimes |         # Datetimes | ||||||
|         elif isinstance(value, (datetime.datetime, datetime.date)): |         elif isinstance(value, datetime.datetime): | ||||||
|  |             if value.tzinfo is not None: | ||||||
|  |                 raise ValueError("Cannot serialize datetime values with timezones. Either use a callable value for default or remove the timezone.") | ||||||
|  |             return repr(value), set(["import datetime"]) | ||||||
|  |         # Dates | ||||||
|  |         elif isinstance(value, datetime.date): | ||||||
|             return repr(value), set(["import datetime"]) |             return repr(value), set(["import datetime"]) | ||||||
|         # Settings references |         # Settings references | ||||||
|         elif isinstance(value, SettingsReference): |         elif isinstance(value, SettingsReference): | ||||||
|   | |||||||
| @@ -13,6 +13,7 @@ from django.conf import settings | |||||||
| from django.utils import six | from django.utils import six | ||||||
| from django.utils.deconstruct import deconstructible | from django.utils.deconstruct import deconstructible | ||||||
| from django.utils.translation import ugettext_lazy as _ | from django.utils.translation import ugettext_lazy as _ | ||||||
|  | from django.utils.timezone import get_default_timezone | ||||||
|  |  | ||||||
|  |  | ||||||
| class WriterTests(TestCase): | class WriterTests(TestCase): | ||||||
| @@ -78,6 +79,8 @@ class WriterTests(TestCase): | |||||||
|         self.assertSerializedEqual(datetime.datetime.today) |         self.assertSerializedEqual(datetime.datetime.today) | ||||||
|         self.assertSerializedEqual(datetime.date.today()) |         self.assertSerializedEqual(datetime.date.today()) | ||||||
|         self.assertSerializedEqual(datetime.date.today) |         self.assertSerializedEqual(datetime.date.today) | ||||||
|  |         with self.assertRaises(ValueError): | ||||||
|  |             self.assertSerializedEqual(datetime.datetime(2012, 1, 1, 1, 1, tzinfo=get_default_timezone())) | ||||||
|         # Classes |         # Classes | ||||||
|         validator = RegexValidator(message="hello") |         validator = RegexValidator(message="hello") | ||||||
|         string, imports = MigrationWriter.serialize(validator) |         string, imports = MigrationWriter.serialize(validator) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user