diff options
author | Johan Schiff <johan@radkompaniet.se> | 2020-06-09 11:23:31 +0200 |
---|---|---|
committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2021-03-06 20:40:29 +0100 |
commit | d01709aae21de9cd2565b9c52f32732ea28a2d98 (patch) | |
tree | 83326f30469fb3dda431362dea3adfd6e058f85f /tests/queries/test_contains.py | |
parent | 286fb73b6962d197ed0cf041755fb724cfe08600 (diff) | |
download | django-d01709aae21de9cd2565b9c52f32732ea28a2d98.tar.gz |
Fixed #24141 -- Added QuerySet.contains().
Diffstat (limited to 'tests/queries/test_contains.py')
-rw-r--r-- | tests/queries/test_contains.py | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/tests/queries/test_contains.py b/tests/queries/test_contains.py new file mode 100644 index 0000000000..a58dbe180f --- /dev/null +++ b/tests/queries/test_contains.py @@ -0,0 +1,62 @@ +from django.test import TestCase + +from .models import DumbCategory, NamedCategory, ProxyCategory + + +class ContainsTests(TestCase): + @classmethod + def setUpTestData(cls): + cls.category = DumbCategory.objects.create() + cls.proxy_category = ProxyCategory.objects.create() + + def test_unsaved_obj(self): + msg = 'QuerySet.contains() cannot be used on unsaved objects.' + with self.assertRaisesMessage(ValueError, msg): + DumbCategory.objects.contains(DumbCategory()) + + def test_obj_type(self): + msg = "'obj' must be a model instance." + with self.assertRaisesMessage(TypeError, msg): + DumbCategory.objects.contains(object()) + + def test_values(self): + msg = 'Cannot call QuerySet.contains() after .values() or .values_list().' + with self.assertRaisesMessage(TypeError, msg): + DumbCategory.objects.values_list('pk').contains(self.category) + with self.assertRaisesMessage(TypeError, msg): + DumbCategory.objects.values('pk').contains(self.category) + + def test_basic(self): + with self.assertNumQueries(1): + self.assertIs(DumbCategory.objects.contains(self.category), True) + # QuerySet.contains() doesn't evaluate a queryset. + with self.assertNumQueries(1): + self.assertIs(DumbCategory.objects.contains(self.category), True) + + def test_evaluated_queryset(self): + qs = DumbCategory.objects.all() + proxy_qs = ProxyCategory.objects.all() + # Evaluate querysets. + list(qs) + list(proxy_qs) + with self.assertNumQueries(0): + self.assertIs(qs.contains(self.category), True) + self.assertIs(qs.contains(self.proxy_category), True) + self.assertIs(proxy_qs.contains(self.category), True) + self.assertIs(proxy_qs.contains(self.proxy_category), True) + + def test_proxy_model(self): + with self.assertNumQueries(1): + self.assertIs(DumbCategory.objects.contains(self.proxy_category), True) + with self.assertNumQueries(1): + self.assertIs(ProxyCategory.objects.contains(self.category), True) + + def test_wrong_model(self): + qs = DumbCategory.objects.all() + named_category = NamedCategory(name='category') + with self.assertNumQueries(0): + self.assertIs(qs.contains(named_category), False) + # Evaluate the queryset. + list(qs) + with self.assertNumQueries(0): + self.assertIs(qs.contains(named_category), False) |