From df60db0e7872796b4a48e62e9733f85c8ddf8306 Mon Sep 17 00:00:00 2001 From: Ben Davis Date: Sat, 3 May 2014 12:02:07 -0500 Subject: [PATCH] Fixed #22570 -- Made Form.__getitem__ KeyError more descriptive. --- django/forms/forms.py | 3 ++- tests/forms_tests/tests/test_forms.py | 6 +++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/django/forms/forms.py b/django/forms/forms.py index af7318255f..917987c0be 100644 --- a/django/forms/forms.py +++ b/django/forms/forms.py @@ -142,7 +142,8 @@ class BaseForm(object): try: field = self.fields[name] except KeyError: - raise KeyError('Key %r not found in Form' % name) + raise KeyError( + "Key %r not found in '%s'" % (name, self.__class__.__name__)) return BoundField(self, field, name) @property diff --git a/tests/forms_tests/tests/test_forms.py b/tests/forms_tests/tests/test_forms.py index 051968d14f..b8c5f28d2f 100644 --- a/tests/forms_tests/tests/test_forms.py +++ b/tests/forms_tests/tests/test_forms.py @@ -58,11 +58,11 @@ class FormsTestCase(TestCase): self.assertHTMLEqual(str(p['first_name']), '') self.assertHTMLEqual(str(p['last_name']), '') self.assertHTMLEqual(str(p['birthday']), '') - try: + + nonexistenterror = "Key u?'nonexistentfield' not found in 'Person'" + with self.assertRaisesRegexp(KeyError, nonexistenterror): p['nonexistentfield'] self.fail('Attempts to access non-existent fields should fail.') - except KeyError: - pass form_output = []