From 3ee4c6a27ad520d4ecc3cded260d47cbccafb144 Mon Sep 17 00:00:00 2001 From: Andrew Miller Date: Sun, 15 Dec 2024 21:04:29 +0000 Subject: [PATCH] Refs #26007 -- Improved the ImproperlyConfigured error message for SingleObjectTemplateResponseMixin.get_template_names(). --- django/views/generic/detail.py | 6 +++++- tests/generic_views/test_base.py | 5 +++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/django/views/generic/detail.py b/django/views/generic/detail.py index 05ced1f25dbd..70e427c59b29 100644 --- a/django/views/generic/detail.py +++ b/django/views/generic/detail.py @@ -171,7 +171,11 @@ def get_template_names(self): # If we still haven't managed to find any template names, we should # re-raise the ImproperlyConfigured to alert the user. if not names: - raise + raise ImproperlyConfigured( + "SingleObjectTemplateResponseMixin requires a definition " + "of 'template_name', 'template_name_field', or 'model'; " + "or an implementation of 'get_template_names()'." + ) return names diff --git a/tests/generic_views/test_base.py b/tests/generic_views/test_base.py index add485245a87..5f3941196b26 100644 --- a/tests/generic_views/test_base.py +++ b/tests/generic_views/test_base.py @@ -607,8 +607,9 @@ def test_template_mixin_without_template(self): """ view = views.TemplateResponseWithoutTemplate() msg = ( - "TemplateResponseMixin requires either a definition of " - "'template_name' or an implementation of 'get_template_names()'" + "SingleObjectTemplateResponseMixin requires a definition " + "of 'template_name', 'template_name_field', or 'model'; " + "or an implementation of 'get_template_names()'." ) with self.assertRaisesMessage(ImproperlyConfigured, msg): view.get_template_names()