mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #28277 -- Added validation of QuerySet.annotate() and aggregate() args.
Thanks Tim Graham and Nick Pope for reviews.
This commit is contained in:
@@ -1186,3 +1186,12 @@ class AggregateTestCase(TestCase):
|
||||
).filter(rating_or_num_awards__gt=F('num_awards')).order_by('num_awards')
|
||||
self.assertQuerysetEqual(
|
||||
qs2, [1, 3], lambda v: v.num_awards)
|
||||
|
||||
def test_arguments_must_be_expressions(self):
|
||||
msg = 'QuerySet.aggregate() received non-expression(s): %s.'
|
||||
with self.assertRaisesMessage(TypeError, msg % FloatField()):
|
||||
Book.objects.aggregate(FloatField())
|
||||
with self.assertRaisesMessage(TypeError, msg % True):
|
||||
Book.objects.aggregate(is_book=True)
|
||||
with self.assertRaisesMessage(TypeError, msg % ', '.join([str(FloatField()), 'True'])):
|
||||
Book.objects.aggregate(FloatField(), Avg('price'), is_book=True)
|
||||
|
||||
Reference in New Issue
Block a user