mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +00:00 
			
		
		
		
	Fixed #35149 -- Fixed crashes of db_default with unresolvable output field.
Field.db_default accepts either literal Python values or compilables
(as_sql) and wrap the former ones in Value internally.
While 1e38f11 added support for automatic resolving of output fields for
types such as str, int, float, and other unambigous ones it's cannot do
so for all types such as dict or even contrib.postgres and contrib.gis
primitives.
When a literal, non-compilable, value is provided it likely make the
most sense to bind its output field to the field its attached to avoid
forcing the user to provide an explicit `Value(output_field)`.
Thanks David Sanders for the report.
			
			
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							fe1cb62f5c
						
					
				
				
					commit
					e67d7d70fa
				
			| @@ -7,6 +7,7 @@ from unittest import mock | ||||
|  | ||||
| from django.core.exceptions import FieldError | ||||
| from django.core.management.color import no_style | ||||
| from django.core.serializers.json import DjangoJSONEncoder | ||||
| from django.db import ( | ||||
|     DatabaseError, | ||||
|     DataError, | ||||
| @@ -2333,6 +2334,26 @@ class SchemaTests(TransactionTestCase): | ||||
|         with connection.schema_editor() as editor, self.assertNumQueries(0): | ||||
|             editor.alter_field(Author, Author._meta.get_field("name"), new_field) | ||||
|  | ||||
|     @isolate_apps("schema") | ||||
|     def test_db_default_output_field_resolving(self): | ||||
|         class Author(Model): | ||||
|             data = JSONField( | ||||
|                 encoder=DjangoJSONEncoder, | ||||
|                 db_default={ | ||||
|                     "epoch": datetime.datetime(1970, 1, 1, tzinfo=datetime.timezone.utc) | ||||
|                 }, | ||||
|             ) | ||||
|  | ||||
|             class Meta: | ||||
|                 app_label = "schema" | ||||
|  | ||||
|         with connection.schema_editor() as editor: | ||||
|             editor.create_model(Author) | ||||
|  | ||||
|         author = Author.objects.create() | ||||
|         author.refresh_from_db() | ||||
|         self.assertEqual(author.data, {"epoch": "1970-01-01T00:00:00Z"}) | ||||
|  | ||||
|     @skipUnlessDBFeature( | ||||
|         "supports_column_check_constraints", "can_introspect_check_constraints" | ||||
|     ) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user