Author: russellm
Date: 2009-04-16 09:26:08 -0500 (Thu, 16 Apr 2009)
New Revision: 10575
Modified:
django/trunk/django/forms/models.py
django/trunk/tests/regressiontests/forms/models.py
Log:
Fixed #10363 -- Modified ModelForm handling to ensure that excluded fields
can't be saved onto the model. Thanks to jgoldberg for the report, an Alex
Gaynor for the fix.
Modified: django/trunk/django/forms/models.py
===================================================================
--- django/trunk/django/forms/models.py 2009-04-16 14:25:18 UTC (rev 10574)
+++ django/trunk/django/forms/models.py 2009-04-16 14:26:08 UTC (rev 10575)
@@ -334,7 +334,8 @@
fail_message = 'created'
else:
fail_message = 'changed'
- return save_instance(self, self.instance, self._meta.fields,
fail_message, commit)
+ return save_instance(self, self.instance, self._meta.fields,
+ fail_message, commit, exclude=self._meta.exclude)
save.alters_data = True
Modified: django/trunk/tests/regressiontests/forms/models.py
===================================================================
--- django/trunk/tests/regressiontests/forms/models.py 2009-04-16 14:25:18 UTC
(rev 10574)
+++ django/trunk/tests/regressiontests/forms/models.py 2009-04-16 14:26:08 UTC
(rev 10575)
@@ -42,7 +42,7 @@
{'file1': <SimpleUploadedFile: 我隻氣墊船裝滿晒鱔.txt (text/plain)>}
>>> m = FileModel.objects.create(file=f.cleaned_data['file1'])
-# It's enough that m gets created without error. Preservation of the exotic
name is checked
+# It's enough that m gets created without error. Preservation of the exotic
name is checked
# in a file_uploads test; it's hard to do that correctly with doctest's
unicode issues. So
# we create and then immediately delete m so as to not leave the exotically
named file around
# for shutil.rmtree (on Windows) to have trouble with later.
@@ -85,5 +85,24 @@
datetime.date(1969, 4, 4)
>>> instance_form.initial['value']
12
+
+>>> from django.forms import CharField
+>>> class ExcludingForm(ModelForm):
+... name = CharField(max_length=256)
+... class Meta:
+... model = Defaults
+... exclude = ['name']
+>>> f = ExcludingForm({'name': u'Hello', 'value': 99, 'def_date':
datetime.date(1999, 3, 2)})
+>>> f.is_valid()
+True
+>>> f.cleaned_data['name']
+u'Hello'
+>>> obj = f.save()
+>>> obj.name
+u'class default value'
+>>> obj.value
+99
+>>> obj.def_date
+datetime.date(1999, 3, 2)
>>> shutil.rmtree(temp_storage_location)
"""}
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups
"Django updates" group.
To post to this group, send email to [email protected]
To unsubscribe from this group, send email to
[email protected]
For more options, visit this group at
http://groups.google.com/group/django-updates?hl=en
-~----------~----~----~----~------~----~------~--~---