mirror of
https://github.com/django/django.git
synced 2025-10-25 22:56:12 +00:00
Fixed #34437 -- Made values() resolving error mention selected annotations.
While the add_fields() call from set_values() does trigger validation it does so after annotations are masked resulting in them being excluded from the choices of valid options surfaced through a FieldError.
This commit is contained in:
@@ -2135,11 +2135,6 @@ class Query(BaseExpression):
|
||||
# For lookups spanning over relationships, show the error
|
||||
# from the model on which the lookup failed.
|
||||
raise
|
||||
elif name in self.annotations:
|
||||
raise FieldError(
|
||||
"Cannot select the '%s' alias. Use annotate() to promote "
|
||||
"it." % name
|
||||
)
|
||||
else:
|
||||
names = sorted(
|
||||
[
|
||||
@@ -2385,7 +2380,17 @@ class Query(BaseExpression):
|
||||
extra_names.append(f)
|
||||
elif f in self.annotation_select:
|
||||
annotation_names.append(f)
|
||||
elif f in self.annotations:
|
||||
raise FieldError(
|
||||
f"Cannot select the '{f}' alias. Use annotate() to "
|
||||
"promote it."
|
||||
)
|
||||
else:
|
||||
# Call `names_to_path` to ensure a FieldError including
|
||||
# annotations about to be masked as valid choices if
|
||||
# `f` is not resolvable.
|
||||
if self.annotation_select:
|
||||
self.names_to_path(f.split(LOOKUP_SEP), self.model._meta)
|
||||
field_names.append(f)
|
||||
self.set_extra_mask(extra_names)
|
||||
self.set_annotation_mask(annotation_names)
|
||||
|
||||
Reference in New Issue
Block a user