mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Refs #26602 -- Added tests for aggregating over a RawSQL() annotation.
Fixed in 3f32154f40.
Thanks Manav Agarwal for initial test.
			
			
This commit is contained in:
		| @@ -670,6 +670,18 @@ class BasicExpressionsTests(TestCase): | |||||||
|         # contain nested aggregates. |         # contain nested aggregates. | ||||||
|         self.assertNotIn('GROUP BY', sql) |         self.assertNotIn('GROUP BY', sql) | ||||||
|  |  | ||||||
|  |     @skipUnlessDBFeature('supports_over_clause') | ||||||
|  |     def test_aggregate_rawsql_annotation(self): | ||||||
|  |         with self.assertNumQueries(1) as ctx: | ||||||
|  |             aggregate = Company.objects.annotate( | ||||||
|  |                 salary=RawSQL('SUM(num_chairs) OVER (ORDER BY num_employees)', []), | ||||||
|  |             ).aggregate( | ||||||
|  |                 count=Count('pk'), | ||||||
|  |             ) | ||||||
|  |             self.assertEqual(aggregate, {'count': 3}) | ||||||
|  |         sql = ctx.captured_queries[0]['sql'] | ||||||
|  |         self.assertNotIn('GROUP BY', sql) | ||||||
|  |  | ||||||
|     def test_explicit_output_field(self): |     def test_explicit_output_field(self): | ||||||
|         class FuncA(Func): |         class FuncA(Func): | ||||||
|             output_field = CharField() |             output_field = CharField() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user