#26007 closed Bug (fixed)
SingleObjectTemplateResponseMixin.get_template_names does not return names stack properly.
Reported by: | Chris Cogdon | Owned by: | Andy Miller |
---|---|---|---|
Component: | Generic views | Version: | 1.9 |
Severity: | Normal | Keywords: | |
Cc: | Triage Stage: | Ready for checkin | |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
The docstring for SingleObjectTemplateResponseMixin.get_template_names() implies that a particular list of names is being returned. However, if SingleObjectTemplateResponseMixin.get_template_names() (the super) returns anything, then only the template_name will be returned.
In addition, the name obtained by using self.template_name_field is inserted at 0, implying that there is something to insert it in front of, which is impossible given the current implementation, and conflicts with the documentation.
By inference, it appears that the intended implementation is that the following names are returned, in this order:
- a template derived from the template_name_field field of the object.
- a template derived from the super (the template_name) attribute of the view
- a template derived from the object's model name or self.model's name, with the template_name_suffix appended.
Change will need some refactoring of the method, change to the docstring, and the documentation. I'll provide a pull request.
Change History (17)
comment:1 by , 9 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
comment:2 by , 9 years ago
Has patch: | set |
---|---|
Triage Stage: | Unreviewed → Accepted |
comment:3 by , 9 years ago
Note: This patch introduces one potential backwards incompatibility:
In the current code, if both template_name and template_field_name is set, template_field_name is always ignored. With the patch, if template_field_name is declared AND there is a non-empty value in the referenced field, the template name from the field is used in preference to template_name.
I think the patch implements the intended behaviour (or why bother trying to insert(0, name)
, and compare the implementation in MultipleObjectTemplateResponseMixin.get_template_names
), and cases were someone has set both template_name and template_field_name is rare or non-existant, but given this possibility, we may want to defer the change to 1.10 with or without accelerated deprecation. Advise?
One possibility is we can detect when both template_name and template_field_name are defined and raise a deprecation warning, and then fix the stack in a later version. If that's preferable, I'll make the change, and would we want it deprecated for 1.10 or 1.11 ?
comment:4 by , 9 years ago
Patch needs improvement: | set |
---|
comment:5 by , 8 years ago
As noted on the PR, I don't see what implies that template_name_field
should be first? Even if the code implies some other behavior, it seems to me that the the documentation and docstring should take precedence.
comment:6 by , 2 weeks ago
Cc: | added |
---|
comment:7 by , 12 days ago
Owner: | changed from | to
---|
comment:8 by , 12 days ago
My personal feeling is the following on this is the following:
- The docstring could be clearer about what is returned and in what order depending on what is specified on the class
- Given how list returned from this function is used, then I believe a change could be made so that the code is purely additive to the list generated rather than reseting which is the current case if
template_name
is specified. This closer reflects the docstring intention. - Improve the error messages, specifically the re raising of the previous IncorrectlyConfigured is not correct since you can have other causes that aren't clear from the error provided.
Based on the comment from Tim that would suggest the docstring should remain despite the code implying otherwise in my reading of it.
I would suggest 3 smaller patches to deal with each of the points above which depends on there being a consensus that all 3 changes are good to do.
comment:9 by , 11 days ago
The expectation that when self.template_name
is set get_template_names()
returns [self.template_name]
is very established. TemplateResponseMixin, which defines this, is close to the shared behaviour of ≈all the GCBVs. Adjusting that for just for object detail views would be a strange inconsistency to add. Thus I think, the additional logic from SingleObjectTemplateResponseMixin should continue to only kick in after that, and then, yes, the docstring can be clarified to make that clearer.
Improving the error messages too sounds all for the good.
comment:10 by , 11 days ago
Thanks Carlton. I'll get working on 1/2 patches to cover the docstring and clearer error message.
comment:12 by , 9 days ago
Patch needs improvement: | set |
---|
comment:14 by , 6 days ago
So I completely misread Tim's comment on the PR, I have now closed the 2nd PR and pushed a second commit to the first PR. This is now ready for another review.
comment:15 by , 4 days ago
Triage Stage: | Accepted → Ready for checkin |
---|
Pull request: https://github.com/django/django/pull/5892
All tests pass. Documentation compiles.