mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #27266 -- Allowed using assertFormError()/assertFormsetError() in admin forms and formsets.
Thanks Diego Andrés Sanabria Martín for the report and review.
This commit is contained in:
		| @@ -56,6 +56,14 @@ class AdminForm(object): | |||||||
|                 **options |                 **options | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def errors(self): | ||||||
|  |         return self.form.errors | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def non_field_errors(self): | ||||||
|  |         return self.form.non_field_errors | ||||||
|  |  | ||||||
|     @property |     @property | ||||||
|     def media(self): |     def media(self): | ||||||
|         media = self.form.media |         media = self.form.media | ||||||
| @@ -303,6 +311,14 @@ class InlineAdminFormSet(object): | |||||||
|             } |             } | ||||||
|         }) |         }) | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def forms(self): | ||||||
|  |         return self.formset.forms | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def non_form_errors(self): | ||||||
|  |         return self.formset.non_form_errors | ||||||
|  |  | ||||||
|     @property |     @property | ||||||
|     def media(self): |     def media(self): | ||||||
|         media = self.opts.media + self.formset.media |         media = self.opts.media + self.formset.media | ||||||
|   | |||||||
| @@ -1474,8 +1474,7 @@ class AdminViewPermissionsTest(TestCase): | |||||||
|         self.assertEqual(response.status_code, 302) |         self.assertEqual(response.status_code, 302) | ||||||
|         login = self.client.post(login_url, self.no_username_login) |         login = self.client.post(login_url, self.no_username_login) | ||||||
|         self.assertEqual(login.status_code, 200) |         self.assertEqual(login.status_code, 200) | ||||||
|         form = login.context[0].get('form') |         self.assertFormError(login, 'form', 'username', ['This field is required.']) | ||||||
|         self.assertEqual(form.errors['username'][0], 'This field is required.') |  | ||||||
|  |  | ||||||
|     def test_login_redirect_for_direct_get(self): |     def test_login_redirect_for_direct_get(self): | ||||||
|         """ |         """ | ||||||
| @@ -4935,9 +4934,8 @@ class UserAdminTest(TestCase): | |||||||
|             'password2': 'mismatch', |             'password2': 'mismatch', | ||||||
|         }) |         }) | ||||||
|         self.assertEqual(response.status_code, 200) |         self.assertEqual(response.status_code, 200) | ||||||
|         adminform = response.context['adminform'] |         self.assertFormError(response, 'adminform', 'password', []) | ||||||
|         self.assertNotIn('password', adminform.form.errors) |         self.assertFormError(response, 'adminform', 'password2', ["The two password fields didn't match."]) | ||||||
|         self.assertEqual(adminform.form.errors['password2'], ["The two password fields didn't match."]) |  | ||||||
|  |  | ||||||
|     def test_user_fk_add_popup(self): |     def test_user_fk_add_popup(self): | ||||||
|         """User addition through a FK popup should return the appropriate JavaScript response.""" |         """User addition through a FK popup should return the appropriate JavaScript response.""" | ||||||
| @@ -5922,7 +5920,9 @@ class AdminViewOnSiteTests(TestCase): | |||||||
|         """ |         """ | ||||||
|         Issue #20522 |         Issue #20522 | ||||||
|         Verifying that if the parent form fails validation, the inlines also |         Verifying that if the parent form fails validation, the inlines also | ||||||
|         run validation even if validation is contingent on parent form data |         run validation even if validation is contingent on parent form data. | ||||||
|  |         Also, assertFormError() and assertFormsetError() is usable for admin | ||||||
|  |         forms and formsets. | ||||||
|         """ |         """ | ||||||
|         # The form validation should fail because 'some_required_info' is |         # The form validation should fail because 'some_required_info' is | ||||||
|         # not included on the parent form, and the family_name of the parent |         # not included on the parent form, and the family_name of the parent | ||||||
| @@ -5936,15 +5936,17 @@ class AdminViewOnSiteTests(TestCase): | |||||||
|                      "dependentchild_set-0-family_name": "Test2"} |                      "dependentchild_set-0-family_name": "Test2"} | ||||||
|         response = self.client.post(reverse('admin:admin_views_parentwithdependentchildren_add'), |         response = self.client.post(reverse('admin:admin_views_parentwithdependentchildren_add'), | ||||||
|                                     post_data) |                                     post_data) | ||||||
|  |         self.assertFormError(response, 'adminform', 'some_required_info', ['This field is required.']) | ||||||
|         # just verifying the parent form failed validation, as expected -- |         msg = "The form 'adminform' in context 0 does not contain the non-field error 'Error'" | ||||||
|         # this isn't the regression test |         with self.assertRaisesMessage(AssertionError, msg): | ||||||
|         self.assertIn('some_required_info', response.context['adminform'].form.errors) |             self.assertFormError(response, 'adminform', None, ['Error']) | ||||||
|  |         self.assertFormsetError( | ||||||
|         # actual regression test |             response, 'inline_admin_formset', 0, None, | ||||||
|         for error_set in response.context['inline_admin_formset'].formset.errors: |             ['Children must share a family name with their parents in this contrived test case'] | ||||||
|             self.assertEqual(['Children must share a family name with their parents in this contrived test case'], |         ) | ||||||
|                              error_set.get('__all__')) |         msg = "The formset 'inline_admin_formset' in context 4 does not contain any non-form errors." | ||||||
|  |         with self.assertRaisesMessage(AssertionError, msg): | ||||||
|  |             self.assertFormsetError(response, 'inline_admin_formset', None, None, ['Error']) | ||||||
|  |  | ||||||
|     def test_change_view_form_and_formsets_run_validation(self): |     def test_change_view_form_and_formsets_run_validation(self): | ||||||
|         """ |         """ | ||||||
| @@ -5967,15 +5969,11 @@ class AdminViewOnSiteTests(TestCase): | |||||||
|         response = self.client.post( |         response = self.client.post( | ||||||
|             reverse('admin:admin_views_parentwithdependentchildren_change', args=(pwdc.id,)), post_data |             reverse('admin:admin_views_parentwithdependentchildren_change', args=(pwdc.id,)), post_data | ||||||
|         ) |         ) | ||||||
|  |         self.assertFormError(response, 'adminform', 'some_required_info', ['This field is required.']) | ||||||
|         # just verifying the parent form failed validation, as expected -- |         self.assertFormsetError( | ||||||
|         # this isn't the regression test |             response, 'inline_admin_formset', 0, None, | ||||||
|         self.assertIn('some_required_info', response.context['adminform'].form.errors) |             ['Children must share a family name with their parents in this contrived test case'] | ||||||
|  |         ) | ||||||
|         # actual regression test |  | ||||||
|         for error_set in response.context['inline_admin_formset'].formset.errors: |  | ||||||
|             self.assertEqual(['Children must share a family name with their parents in this contrived test case'], |  | ||||||
|                              error_set.get('__all__')) |  | ||||||
|  |  | ||||||
|     def test_check(self): |     def test_check(self): | ||||||
|         "Ensure that the view_on_site value is either a boolean or a callable" |         "Ensure that the view_on_site value is either a boolean or a callable" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user