|
@@ -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):
|