diff options
| author | Malcolm Tredinnick <malcolm.tredinnick@gmail.com> | 2008-09-01 02:43:55 +0000 |
|---|---|---|
| committer | Malcolm Tredinnick <malcolm.tredinnick@gmail.com> | 2008-09-01 02:43:55 +0000 |
| commit | 2d7feda05c45f38a04a6ee7ec93842cfea7aff43 (patch) | |
| tree | 0f8453107957428e471ee34c6e4fd8f4ee4fe5b3 /tests/regressiontests/null_fk_ordering/models.py | |
| parent | 4480645ac3b4d3b72ee2880c774f849965d555d4 (diff) | |
Fixed #7512 -- Fixed an oversight when I first fixed ordering on nullable
foreign keys (r7761). Thanks to George Vilches for the test case here.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@8783 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'tests/regressiontests/null_fk_ordering/models.py')
| -rw-r--r-- | tests/regressiontests/null_fk_ordering/models.py | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/tests/regressiontests/null_fk_ordering/models.py b/tests/regressiontests/null_fk_ordering/models.py new file mode 100644 index 0000000000..8c79e81f17 --- /dev/null +++ b/tests/regressiontests/null_fk_ordering/models.py @@ -0,0 +1,95 @@ +""" +Regression tests for proper working of ForeignKey(null=True). Tests these bugs: + + * #7512: including a nullable foreign key reference in Meta ordering has un +xpected results + +""" + +from django.db import models + +# The first two models represent a very simple null FK ordering case. +class Author(models.Model): + name = models.CharField(max_length=150) + +class Article(models.Model): + title = models.CharField(max_length=150) + author = models.ForeignKey(Author, null=True) + + def __unicode__(self): + return u'Article titled: %s' % (self.title, ) + + class Meta: + ordering = ['author__name', ] + + +# These following 4 models represent a far more complex ordering case. +class SystemInfo(models.Model): + system_name = models.CharField(max_length=32) + +class Forum(models.Model): + system_info = models.ForeignKey(SystemInfo) + forum_name = models.CharField(max_length=32) + +class Post(models.Model): + forum = models.ForeignKey(Forum, null=True) + title = models.CharField(max_length=32) + + def __unicode__(self): + return self.title + +class Comment(models.Model): + post = models.ForeignKey(Post, null=True) + comment_text = models.CharField(max_length=250) + + class Meta: + ordering = ['post__forum__system_info__system_name', 'comment_text'] + + def __unicode__(self): + return self.comment_text + +class Comment(models.Model): + post = models.ForeignKey(Post, null=True) + comment_text = models.CharField(max_length=250) + + class Meta: + ordering = ['post__forum__system_info__system_name', 'comment_text'] + + def __unicode__(self): + return self.comment_text + +__test__ = {'API_TESTS': """ +# 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') +>>> article_1 = Article.objects.create(title='No author on this article') +>>> article_2 = Article.objects.create(author=author_1, title='This article written by Tom Jones') +>>> article_3 = Article.objects.create(author=author_2, title='This article written by Bob Smith') + +# 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. +>>> len(list(Article.objects.all())) == 3 +True + +>>> 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') +>>> c1 = Comment.objects.create(post=p, comment_text='My first comment') +>>> c2 = Comment.objects.create(comment_text='My second comment') +>>> 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') +>>> c3 = Comment.objects.create(comment_text='Another first comment') +>>> c4 = Comment.objects.create(post=p2, comment_text='Another second comment') + +# We have to test this carefully. Some databases sort NULL values before +# everything else, some sort them afterwards. So we extract the ordered list +# and check the length. Before the fix, this list was too short (some values +# were omitted). +>>> len(list(Comment.objects.all())) == 4 +True + +""" +} |
