From 04564eb74d2d92eaf88b22ab8cec7ef45978111e Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Thu, 28 Jan 2016 13:49:51 -0500 Subject: [PATCH] Fixed #26129 -- Made invalid forms display initial values of disabled fields. --- django/forms/fields.py | 2 ++ docs/releases/1.9.2.txt | 3 +++ tests/forms_tests/tests/test_forms.py | 8 ++++++++ 3 files changed, 13 insertions(+) diff --git a/django/forms/fields.py b/django/forms/fields.py index 2facb74b1de..3ad362b9b8e 100644 --- a/django/forms/fields.py +++ b/django/forms/fields.py @@ -167,6 +167,8 @@ class Field(object): For most fields, this will simply be data; FileFields need to handle it a bit differently. """ + if self.disabled: + return initial return data def widget_attrs(self, widget): diff --git a/docs/releases/1.9.2.txt b/docs/releases/1.9.2.txt index 6535fff0991..cfa04b703f5 100644 --- a/docs/releases/1.9.2.txt +++ b/docs/releases/1.9.2.txt @@ -91,3 +91,6 @@ Bugfixes * Fixed the ``contrib.gis`` map widgets when using ``USE_THOUSAND_SEPARATOR=True`` (:ticket:`20415`). + +* Made invalid forms display the initial of values of their disabled fields + (:ticket:`26129`). diff --git a/tests/forms_tests/tests/test_forms.py b/tests/forms_tests/tests/test_forms.py index 917b5c99d2d..00d20457868 100644 --- a/tests/forms_tests/tests/test_forms.py +++ b/tests/forms_tests/tests/test_forms.py @@ -718,6 +718,14 @@ class FormsTestCase(SimpleTestCase): {'birthday': datetime.date(1974, 8, 16), 'name': 'John Doe'} ) + # Initial data remains present on invalid forms. + data = {} + f1 = PersonForm(data, initial={'birthday': datetime.date(1974, 8, 16)}) + f2 = PersonFormFieldInitial(data) + for form in (f1, f2): + self.assertFalse(form.is_valid()) + self.assertEqual(form['birthday'].value(), datetime.date(1974, 8, 16)) + def test_hidden_data(self): class SongForm(Form): name = CharField()