mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """
 | |
| Regression tests for proper working of ForeignKey(null=True). Tests these bugs:
 | |
| 
 | |
|     * #7512: including a nullable foreign key reference in Meta ordering has
 | |
| unexpected 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, models.SET_NULL, null=True)
 | |
| 
 | |
|     class Meta:
 | |
|         ordering = ['author__name']
 | |
| 
 | |
|     def __str__(self):
 | |
|         return 'Article titled: %s' % self.title
 | |
| 
 | |
| 
 | |
| # 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, models.CASCADE)
 | |
|     forum_name = models.CharField(max_length=32)
 | |
| 
 | |
| 
 | |
| class Post(models.Model):
 | |
|     forum = models.ForeignKey(Forum, models.SET_NULL, null=True)
 | |
|     title = models.CharField(max_length=32)
 | |
| 
 | |
|     def __str__(self):
 | |
|         return self.title
 | |
| 
 | |
| 
 | |
| class Comment(models.Model):
 | |
|     post = models.ForeignKey(Post, models.SET_NULL, null=True)
 | |
|     comment_text = models.CharField(max_length=250)
 | |
| 
 | |
|     class Meta:
 | |
|         ordering = ['post__forum__system_info__system_name', 'comment_text']
 | |
| 
 | |
|     def __str__(self):
 | |
|         return self.comment_text
 |