mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Refs #36152 -- Suppressed duplicate warning when using "%" in alias via values().
This commit is contained in:
		| @@ -35,6 +35,7 @@ from django.db.models.utils import ( | |||||||
|     resolve_callables, |     resolve_callables, | ||||||
| ) | ) | ||||||
| from django.utils import timezone | from django.utils import timezone | ||||||
|  | from django.utils.deprecation import RemovedInDjango70Warning | ||||||
| from django.utils.functional import cached_property | from django.utils.functional import cached_property | ||||||
|  |  | ||||||
| # The maximum number of results to fetch in a get() query. | # The maximum number of results to fetch in a get() query. | ||||||
| @@ -1394,7 +1395,12 @@ class QuerySet(AltersData): | |||||||
|     def _values(self, *fields, **expressions): |     def _values(self, *fields, **expressions): | ||||||
|         clone = self._chain() |         clone = self._chain() | ||||||
|         if expressions: |         if expressions: | ||||||
|             clone = clone.annotate(**expressions) |             # RemovedInDjango70Warning: When the deprecation ends, deindent as: | ||||||
|  |             # clone = clone.annotate(**expressions) | ||||||
|  |             with warnings.catch_warnings( | ||||||
|  |                 action="ignore", category=RemovedInDjango70Warning | ||||||
|  |             ): | ||||||
|  |                 clone = clone.annotate(**expressions) | ||||||
|         clone._fields = fields |         clone._fields = fields | ||||||
|         clone.query.set_values(fields) |         clone.query.set_values(fields) | ||||||
|         return clone |         return clone | ||||||
|   | |||||||
| @@ -1219,7 +1219,7 @@ class Query(BaseExpression): | |||||||
|             if "aggregate" in {frame.function for frame in inspect.stack()}: |             if "aggregate" in {frame.function for frame in inspect.stack()}: | ||||||
|                 stacklevel = 5 |                 stacklevel = 5 | ||||||
|             else: |             else: | ||||||
|                 # annotate() and alias(). |                 # annotate(), alias(), and values(). | ||||||
|                 stacklevel = 6 |                 stacklevel = 6 | ||||||
|             warnings.warn( |             warnings.warn( | ||||||
|                 "Using percent signs in a column alias is deprecated.", |                 "Using percent signs in a column alias is deprecated.", | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| from django.db.models import F, Sum | from django.db.models import F, Sum | ||||||
| from django.test import TestCase, skipUnlessDBFeature | from django.test import TestCase, skipUnlessDBFeature | ||||||
|  | from django.utils.deprecation import RemovedInDjango70Warning | ||||||
|  |  | ||||||
| from .models import Company, Employee, JSONFieldModel | from .models import Company, Employee, JSONFieldModel | ||||||
|  |  | ||||||
| @@ -34,6 +35,12 @@ class ValuesExpressionsTests(TestCase): | |||||||
|             [{"salary": 10}, {"salary": 20}, {"salary": 30}], |             [{"salary": 10}, {"salary": 20}, {"salary": 30}], | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     def test_values_expression_containing_percent_sign_deprecation_warns_once(self): | ||||||
|  |         msg = "Using percent signs in a column alias is deprecated." | ||||||
|  |         with self.assertWarnsMessage(RemovedInDjango70Warning, msg) as cm: | ||||||
|  |             Company.objects.values(**{"alias%": F("id")}) | ||||||
|  |         self.assertEqual(len(cm.warnings), 1) | ||||||
|  |  | ||||||
|     def test_values_expression_alias_sql_injection(self): |     def test_values_expression_alias_sql_injection(self): | ||||||
|         crafted_alias = """injected_name" from "expressions_company"; --""" |         crafted_alias = """injected_name" from "expressions_company"; --""" | ||||||
|         msg = ( |         msg = ( | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user