mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Fixed #24771 -- Simplified ModelForm._post_clean()
This code added in45e049937dis no longer necessary to pass the model_formsets_regress tests as of5e2c4a4bd1.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							4f8cbf08be
						
					
				
				
					commit
					681df1aeaf
				
			| @@ -411,10 +411,6 @@ class BaseModelForm(BaseForm): | ||||
|         opts = self._meta | ||||
|  | ||||
|         exclude = self._get_validation_exclusions() | ||||
|         # a subset of `exclude` which won't have the InlineForeignKeyField | ||||
|         # if we're adding a new object since that value doesn't exist | ||||
|         # until after the new instance is saved to the database. | ||||
|         construct_instance_exclude = list(exclude) | ||||
|  | ||||
|         # Foreign Keys being used to represent inline relationships | ||||
|         # are excluded from basic field value validation. This is for two | ||||
| @@ -425,12 +421,10 @@ class BaseModelForm(BaseForm): | ||||
|         # so this can't be part of _get_validation_exclusions(). | ||||
|         for name, field in self.fields.items(): | ||||
|             if isinstance(field, InlineForeignKeyField): | ||||
|                 if self.cleaned_data.get(name) is not None and self.cleaned_data[name]._state.adding: | ||||
|                     construct_instance_exclude.append(name) | ||||
|                 exclude.append(name) | ||||
|  | ||||
|         # Update the model instance with self.cleaned_data. | ||||
|         self.instance = construct_instance(self, self.instance, opts.fields, construct_instance_exclude) | ||||
|         self.instance = construct_instance(self, self.instance, opts.fields, exclude) | ||||
|  | ||||
|         try: | ||||
|             self.instance.full_clean(exclude=exclude, validate_unique=False) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user