mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #28188 -- Fixed crash when pickling model fields.
Regression in d2a26c1a90.
Thanks Adam Alton for the report and test, and Adam Johnson for
suggesting the fix.
			
			
This commit is contained in:
		| @@ -514,7 +514,11 @@ class Field(RegisterLookupMixin): | |||||||
|             # instance. The code below will create a new empty instance of |             # instance. The code below will create a new empty instance of | ||||||
|             # class self.__class__, then update its dict with self.__dict__ |             # class self.__class__, then update its dict with self.__dict__ | ||||||
|             # values - so, this is very close to normal pickle. |             # values - so, this is very close to normal pickle. | ||||||
|             return _empty, (self.__class__,), self.__dict__ |             state = self.__dict__.copy() | ||||||
|  |             # The _get_default cached_property can't be pickled due to lambda | ||||||
|  |             # usage. | ||||||
|  |             state.pop('_get_default', None) | ||||||
|  |             return _empty, (self.__class__,), state | ||||||
|         return _load_field, (self.model._meta.app_label, self.model._meta.object_name, |         return _load_field, (self.model._meta.app_label, self.model._meta.object_name, | ||||||
|                              self.name) |                              self.name) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -18,3 +18,5 @@ Bugfixes | |||||||
|  |  | ||||||
| * Fixed ``django.utils.http.is_safe_url()`` crash on invalid IPv6 URLs | * Fixed ``django.utils.http.is_safe_url()`` crash on invalid IPv6 URLs | ||||||
|   (:ticket:`28142`). |   (:ticket:`28142`). | ||||||
|  |  | ||||||
|  | * Fixed regression causing pickling of model fields to crash (:ticket:`28188`). | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
|  | import pickle | ||||||
|  |  | ||||||
| from django import forms | from django import forms | ||||||
| from django.db import models | from django.db import models | ||||||
| from django.test import SimpleTestCase, TestCase | from django.test import SimpleTestCase, TestCase | ||||||
| @@ -76,6 +78,13 @@ class BasicFieldTests(TestCase): | |||||||
|         self.assertIsNotNone(f1) |         self.assertIsNotNone(f1) | ||||||
|         self.assertNotIn(f2, (None, 1, '')) |         self.assertNotIn(f2, (None, 1, '')) | ||||||
|  |  | ||||||
|  |     def test_field_instance_is_picklable(self): | ||||||
|  |         """Field instances can be pickled.""" | ||||||
|  |         field = models.Field(max_length=100, default='a string') | ||||||
|  |         # Must be picklable with this cached property populated (#28188). | ||||||
|  |         field._get_default | ||||||
|  |         pickle.dumps(field) | ||||||
|  |  | ||||||
|  |  | ||||||
| class ChoicesTests(SimpleTestCase): | class ChoicesTests(SimpleTestCase): | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user