mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Refs #26192 -- Added tests for ordering by constant value.
This commit is contained in:
		| @@ -1,7 +1,10 @@ | |||||||
| from datetime import datetime | from datetime import datetime | ||||||
| from operator import attrgetter | from operator import attrgetter | ||||||
|  |  | ||||||
| from django.db.models import Count, DateTimeField, F, Max, OuterRef, Subquery | from django.core.exceptions import FieldError | ||||||
|  | from django.db.models import ( | ||||||
|  |     CharField, Count, DateTimeField, F, Max, OuterRef, Subquery, Value, | ||||||
|  | ) | ||||||
| from django.db.models.functions import Upper | from django.db.models.functions import Upper | ||||||
| from django.test import TestCase | from django.test import TestCase | ||||||
| from django.utils.deprecation import RemovedInDjango31Warning | from django.utils.deprecation import RemovedInDjango31Warning | ||||||
| @@ -402,6 +405,18 @@ class OrderingTests(TestCase): | |||||||
|             attrgetter("headline") |             attrgetter("headline") | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     def test_order_by_annotated_constant_value(self): | ||||||
|  |         qs = Article.objects.annotate( | ||||||
|  |             constant=Value('1', output_field=CharField()), | ||||||
|  |         ).order_by('constant', '-headline') | ||||||
|  |         self.assertSequenceEqual(qs, [self.a4, self.a3, self.a2, self.a1]) | ||||||
|  |  | ||||||
|  |     def test_order_by_constant_value_without_output_field(self): | ||||||
|  |         msg = 'Cannot resolve expression type, unknown output_field' | ||||||
|  |         qs = Article.objects.annotate(constant=Value('1')).order_by('constant') | ||||||
|  |         with self.assertRaisesMessage(FieldError, msg): | ||||||
|  |             qs.first() | ||||||
|  |  | ||||||
|     def test_related_ordering_duplicate_table_reference(self): |     def test_related_ordering_duplicate_table_reference(self): | ||||||
|         """ |         """ | ||||||
|         An ordering referencing a model with an ordering referencing a model |         An ordering referencing a model with an ordering referencing a model | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user