Kaydet (Commit) 80e68ee2 authored tarafından Anssi Kääriäinen's avatar Anssi Kääriäinen

Added tests for already fixed #20101

The ticket dealt with a case where one query had .exclude() that
produced a subquery, the other query had a join to the same model that
was subqueried in the first query. This was already fixed in master, so
only test added.
üst a9ee0e29
...@@ -2808,3 +2808,19 @@ class RelabelCloneTest(TestCase): ...@@ -2808,3 +2808,19 @@ class RelabelCloneTest(TestCase):
# not change results for the parents query. # not change results for the parents query.
self.assertEqual(list(children), [my2]) self.assertEqual(list(children), [my2])
self.assertEqual(list(parents), [my1]) self.assertEqual(list(parents), [my1])
class Ticket20101Tests(TestCase):
def test_ticket_20101(self):
"""
Tests QuerySet ORed combining in exclude subquery case.
"""
t = Tag.objects.create(name='foo')
a1 = Annotation.objects.create(tag=t, name='a1')
a2 = Annotation.objects.create(tag=t, name='a2')
a3 = Annotation.objects.create(tag=t, name='a3')
n = Note.objects.create(note='foo', misc='bar')
qs1 = Note.objects.exclude(annotation__in=[a1, a2])
qs2 = Note.objects.filter(annotation__in=[a3])
self.assertTrue(n in qs1)
self.assertFalse(n in qs2)
self.assertTrue(n in (qs1 | qs2))
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment