diff --git a/django/forms/forms.py b/django/forms/forms.py index 549a3adf6f..614f990395 100644 --- a/django/forms/forms.py +++ b/django/forms/forms.py @@ -316,7 +316,7 @@ class BaseForm(RenderableFormMixin): """ Clean all of self.data and populate self._errors and self.cleaned_data. """ - self._errors = ErrorDict() + self._errors = ErrorDict(renderer=self.renderer) if not self.is_bound: # Stop further processing. return self.cleaned_data = {} diff --git a/tests/forms_tests/tests/test_forms.py b/tests/forms_tests/tests/test_forms.py index cd909628cb..d88ac33f24 100644 --- a/tests/forms_tests/tests/test_forms.py +++ b/tests/forms_tests/tests/test_forms.py @@ -5313,6 +5313,22 @@ class OverrideTests(SimpleTestCase): "required>
", ) + def test_custom_renderer_error_dict(self): + class CustomRenderer(DjangoTemplates): + def render(self, template_name, context, request=None): + if template_name == "django/forms/errors/dict/default.html": + return "So many errors!" + return super().render(template_name, context, request) + + form = Form({}, renderer=CustomRenderer()) + form.full_clean() + form.add_error(None, "Test error") + + self.assertHTMLEqual( + form.errors.render(), + "So many errors!", + ) + def test_cyclic_context_boundfield_render(self): class FirstNameForm(Form): first_name = CharField()