Refs #31614 -- Added test for aliases ordering on combined querysets.
This commit is contained in:
parent
50f71ccb36
commit
51ad767d0b
|
@ -109,6 +109,15 @@ class QuerySetSetOperationTests(TestCase):
|
|||
qs2 = Number.objects.filter(num__gte=2, num__lte=3)
|
||||
self.assertNumbersEqual(qs1.union(qs2).order_by('-num'), [3, 2, 1, 0])
|
||||
|
||||
def test_ordering_by_alias(self):
|
||||
qs1 = Number.objects.filter(num__lte=1).values(alias=F('num'))
|
||||
qs2 = Number.objects.filter(num__gte=2, num__lte=3).values(alias=F('num'))
|
||||
self.assertQuerysetEqual(
|
||||
qs1.union(qs2).order_by('-alias'),
|
||||
[3, 2, 1, 0],
|
||||
operator.itemgetter('alias'),
|
||||
)
|
||||
|
||||
def test_ordering_by_f_expression(self):
|
||||
qs1 = Number.objects.filter(num__lte=1)
|
||||
qs2 = Number.objects.filter(num__gte=2, num__lte=3)
|
||||
|
@ -242,6 +251,8 @@ class QuerySetSetOperationTests(TestCase):
|
|||
# 'num' got realiased to num2
|
||||
with self.assertRaisesMessage(DatabaseError, msg):
|
||||
list(qs1.union(qs2).order_by('num'))
|
||||
with self.assertRaisesMessage(DatabaseError, msg):
|
||||
list(qs1.union(qs2).order_by(F('num')))
|
||||
# switched order, now 'exists' again:
|
||||
list(qs2.union(qs1).order_by('num'))
|
||||
|
||||
|
|
Loading…
Reference in New Issue