[2.2.x] Refs #30325 -- Added tests for using count()/exists() with custom managers and reverse M2M relations.

Backport of 9ac8520fcd from master
This commit is contained in:
Tobias Kunze 2019-04-15 11:03:53 +02:00 committed by Mariusz Felisiak
parent e8de1cc94c
commit 5289d4faec
2 changed files with 13 additions and 0 deletions

View File

@ -27,6 +27,11 @@ class Tag(models.Model):
return self.name
class NoDeletedArticleManager(models.Manager):
def get_queryset(self):
return super().get_queryset().exclude(headline='deleted')
class Article(models.Model):
headline = models.CharField(max_length=100)
# Assign a string as name to make sure the intermediary model is
@ -34,6 +39,8 @@ class Article(models.Model):
publications = models.ManyToManyField(Publication, name='publications')
tags = models.ManyToManyField(Tag, related_name='tags')
objects = NoDeletedArticleManager()
class Meta:
ordering = ('headline',)

View File

@ -557,3 +557,9 @@ class ManyToManyTests(TestCase):
]
)
self.assertQuerysetEqual(b.publications.all(), ['<Publication: Science Weekly>'])
def test_custom_default_manager_exists_count(self):
a5 = Article.objects.create(headline='deleted')
a5.publications.add(self.p2)
self.assertEqual(self.p2.article_set.count(), self.p2.article_set.all().count())
self.assertEqual(self.p3.article_set.exists(), self.p3.article_set.all().exists())