mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #28577 -- Added checks for ArrayField and JSONField to prevent mutable defaults.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							5ceaf14686
						
					
				
				
					commit
					f6e1789654
				
			| @@ -2,13 +2,14 @@ import datetime | ||||
| import uuid | ||||
| from decimal import Decimal | ||||
|  | ||||
| from django.core import exceptions, serializers | ||||
| from django.core import checks, exceptions, serializers | ||||
| from django.core.serializers.json import DjangoJSONEncoder | ||||
| from django.forms import CharField, Form, widgets | ||||
| from django.test.utils import isolate_apps | ||||
| from django.utils.html import escape | ||||
|  | ||||
| from . import PostgreSQLTestCase | ||||
| from .models import JSONModel | ||||
| from .models import JSONModel, PostgreSQLModel | ||||
|  | ||||
| try: | ||||
|     from django.contrib.postgres import forms | ||||
| @@ -259,6 +260,42 @@ class TestQuerying(PostgreSQLTestCase): | ||||
|         self.assertTrue(JSONModel.objects.filter(field__foo__iregex=r'^bAr$').exists()) | ||||
|  | ||||
|  | ||||
| @isolate_apps('postgres_tests') | ||||
| class TestChecks(PostgreSQLTestCase): | ||||
|  | ||||
|     def test_invalid_default(self): | ||||
|         class MyModel(PostgreSQLModel): | ||||
|             field = JSONField(default={}) | ||||
|  | ||||
|         model = MyModel() | ||||
|         self.assertEqual(model.check(), [ | ||||
|             checks.Warning( | ||||
|                 msg=( | ||||
|                     "JSONField default should be a callable instead of an " | ||||
|                     "instance so that it's not shared between all field " | ||||
|                     "instances." | ||||
|                 ), | ||||
|                 hint='Use a callable instead, e.g., use `dict` instead of `{}`.', | ||||
|                 obj=MyModel._meta.get_field('field'), | ||||
|                 id='postgres.E003', | ||||
|             ) | ||||
|         ]) | ||||
|  | ||||
|     def test_valid_default(self): | ||||
|         class MyModel(PostgreSQLModel): | ||||
|             field = JSONField(default=dict) | ||||
|  | ||||
|         model = MyModel() | ||||
|         self.assertEqual(model.check(), []) | ||||
|  | ||||
|     def test_valid_default_none(self): | ||||
|         class MyModel(PostgreSQLModel): | ||||
|             field = JSONField(default=None) | ||||
|  | ||||
|         model = MyModel() | ||||
|         self.assertEqual(model.check(), []) | ||||
|  | ||||
|  | ||||
| class TestSerialization(PostgreSQLTestCase): | ||||
|     test_data = ( | ||||
|         '[{"fields": {"field": {"a": "b", "c": null}, "field_custom": null}, ' | ||||
|   | ||||
		Reference in New Issue
	
	Block a user