models.py 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. """
  2. Regression tests for proper working of ForeignKey(null=True). Tests these bugs:
  3. * #7512: including a nullable foreign key reference in Meta ordering has
  4. unexpected results
  5. """
  6. from django.db import models
  7. # The first two models represent a very simple null FK ordering case.
  8. class Author(models.Model):
  9. name = models.CharField(max_length=150)
  10. class Article(models.Model):
  11. title = models.CharField(max_length=150)
  12. author = models.ForeignKey(Author, models.SET_NULL, null=True)
  13. class Meta:
  14. ordering = ['author__name']
  15. def __str__(self):
  16. return 'Article titled: %s' % self.title
  17. # These following 4 models represent a far more complex ordering case.
  18. class SystemInfo(models.Model):
  19. system_name = models.CharField(max_length=32)
  20. class Forum(models.Model):
  21. system_info = models.ForeignKey(SystemInfo, models.CASCADE)
  22. forum_name = models.CharField(max_length=32)
  23. class Post(models.Model):
  24. forum = models.ForeignKey(Forum, models.SET_NULL, null=True)
  25. title = models.CharField(max_length=32)
  26. def __str__(self):
  27. return self.title
  28. class Comment(models.Model):
  29. post = models.ForeignKey(Post, models.SET_NULL, null=True)
  30. comment_text = models.CharField(max_length=250)
  31. class Meta:
  32. ordering = ['post__forum__system_info__system_name', 'comment_text']
  33. def __str__(self):
  34. return self.comment_text