mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #28658 -- Added DISTINCT handling to the Aggregate class.
This commit is contained in:
committed by
Tim Graham
parent
222caab68a
commit
bc05547cd8
@@ -1481,18 +1481,22 @@ class ReprTests(SimpleTestCase):
|
||||
|
||||
def test_aggregates(self):
|
||||
self.assertEqual(repr(Avg('a')), "Avg(F(a))")
|
||||
self.assertEqual(repr(Count('a')), "Count(F(a), distinct=False)")
|
||||
self.assertEqual(repr(Count('*')), "Count('*', distinct=False)")
|
||||
self.assertEqual(repr(Count('a')), "Count(F(a))")
|
||||
self.assertEqual(repr(Count('*')), "Count('*')")
|
||||
self.assertEqual(repr(Max('a')), "Max(F(a))")
|
||||
self.assertEqual(repr(Min('a')), "Min(F(a))")
|
||||
self.assertEqual(repr(StdDev('a')), "StdDev(F(a), sample=False)")
|
||||
self.assertEqual(repr(Sum('a')), "Sum(F(a))")
|
||||
self.assertEqual(repr(Variance('a', sample=True)), "Variance(F(a), sample=True)")
|
||||
|
||||
def test_distinct_aggregates(self):
|
||||
self.assertEqual(repr(Count('a', distinct=True)), "Count(F(a), distinct=True)")
|
||||
self.assertEqual(repr(Count('*', distinct=True)), "Count('*', distinct=True)")
|
||||
|
||||
def test_filtered_aggregates(self):
|
||||
filter = Q(a=1)
|
||||
self.assertEqual(repr(Avg('a', filter=filter)), "Avg(F(a), filter=(AND: ('a', 1)))")
|
||||
self.assertEqual(repr(Count('a', filter=filter)), "Count(F(a), distinct=False, filter=(AND: ('a', 1)))")
|
||||
self.assertEqual(repr(Count('a', filter=filter)), "Count(F(a), filter=(AND: ('a', 1)))")
|
||||
self.assertEqual(repr(Max('a', filter=filter)), "Max(F(a), filter=(AND: ('a', 1)))")
|
||||
self.assertEqual(repr(Min('a', filter=filter)), "Min(F(a), filter=(AND: ('a', 1)))")
|
||||
self.assertEqual(repr(StdDev('a', filter=filter)), "StdDev(F(a), filter=(AND: ('a', 1)), sample=False)")
|
||||
@@ -1501,6 +1505,9 @@ class ReprTests(SimpleTestCase):
|
||||
repr(Variance('a', sample=True, filter=filter)),
|
||||
"Variance(F(a), filter=(AND: ('a', 1)), sample=True)"
|
||||
)
|
||||
self.assertEqual(
|
||||
repr(Count('a', filter=filter, distinct=True)), "Count(F(a), distinct=True, filter=(AND: ('a', 1)))"
|
||||
)
|
||||
|
||||
|
||||
class CombinableTests(SimpleTestCase):
|
||||
|
||||
Reference in New Issue
Block a user