2010-09-28 10:17:12 +02:00
|
|
|
from django.test import TestCase
|
|
|
|
|
2015-01-28 13:35:27 +01:00
|
|
|
from .models import Article, Author, Comment, Forum, Post, SystemInfo
|
2011-10-13 23:34:56 +02:00
|
|
|
|
2010-09-28 10:17:12 +02:00
|
|
|
|
|
|
|
class NullFkOrderingTests(TestCase):
|
|
|
|
def test_ordering_across_null_fk(self):
|
|
|
|
"""
|
|
|
|
Regression test for #7512
|
|
|
|
|
|
|
|
ordering across nullable Foreign Keys shouldn't exclude results
|
|
|
|
"""
|
|
|
|
author_1 = Author.objects.create(name="Tom Jones")
|
|
|
|
author_2 = Author.objects.create(name="Bob Smith")
|
2013-10-19 14:31:38 +02:00
|
|
|
Article.objects.create(title="No author on this article")
|
|
|
|
Article.objects.create(
|
|
|
|
author=author_1, title="This article written by Tom Jones"
|
|
|
|
)
|
|
|
|
Article.objects.create(
|
|
|
|
author=author_2, title="This article written by Bob Smith"
|
|
|
|
)
|
2010-09-28 10:17:12 +02:00
|
|
|
|
|
|
|
# We can't compare results directly (since different databases sort NULLs to
|
|
|
|
# different ends of the ordering), but we can check that all results are
|
|
|
|
# returned.
|
2014-10-28 11:02:56 +01:00
|
|
|
self.assertEqual(len(list(Article.objects.all())), 3)
|
2010-09-28 10:17:12 +02:00
|
|
|
|
|
|
|
s = SystemInfo.objects.create(system_name="System Info")
|
|
|
|
f = Forum.objects.create(system_info=s, forum_name="First forum")
|
|
|
|
p = Post.objects.create(forum=f, title="First Post")
|
2013-10-19 14:31:38 +02:00
|
|
|
Comment.objects.create(post=p, comment_text="My first comment")
|
|
|
|
Comment.objects.create(comment_text="My second comment")
|
2010-09-28 10:17:12 +02:00
|
|
|
s2 = SystemInfo.objects.create(system_name="More System Info")
|
|
|
|
f2 = Forum.objects.create(system_info=s2, forum_name="Second forum")
|
|
|
|
p2 = Post.objects.create(forum=f2, title="Second Post")
|
2013-10-19 14:31:38 +02:00
|
|
|
Comment.objects.create(comment_text="Another first comment")
|
|
|
|
Comment.objects.create(post=p2, comment_text="Another second comment")
|
2010-09-28 10:17:12 +02:00
|
|
|
|
|
|
|
# We have to test this carefully. Some databases sort NULL values before
|
2021-07-27 10:41:51 +02:00
|
|
|
# everything else, some sort them afterward. So we extract the ordered list
|
2010-09-28 10:17:12 +02:00
|
|
|
# and check the length. Before the fix, this list was too short (some values
|
|
|
|
# were omitted).
|
2014-10-28 11:02:56 +01:00
|
|
|
self.assertEqual(len(list(Comment.objects.all())), 4)
|