django-model-utils/tests/test_managers/test_join_manager.py

40 lines
1.3 KiB
Python
Raw Normal View History

from __future__ import annotations
from django.test import TestCase
2020-11-29 20:58:00 +00:00
from tests.models import BoxJoinModel, JoinItemForeignKey
class JoinManagerTest(TestCase):
2023-03-22 17:50:18 +00:00
def setUp(self) -> None:
for i in range(20):
BoxJoinModel.objects.create(name=f'name_{i}')
JoinItemForeignKey.objects.create(
weight=10, belonging=BoxJoinModel.objects.get(name='name_1')
)
JoinItemForeignKey.objects.create(weight=20)
2023-03-22 17:50:18 +00:00
def test_self_join(self) -> None:
a_slice = BoxJoinModel.objects.all()[0:10]
with self.assertNumQueries(1):
result = a_slice.join()
self.assertEqual(result.count(), 10)
2023-03-22 17:50:18 +00:00
def test_self_join_with_where_statement(self) -> None:
qs = BoxJoinModel.objects.filter(name='name_1')
result = qs.join()
self.assertEqual(result.count(), 1)
2023-03-22 17:50:18 +00:00
def test_join_with_other_qs(self) -> None:
item_qs = JoinItemForeignKey.objects.filter(weight=10)
boxes = BoxJoinModel.objects.all().join(qs=item_qs)
self.assertEqual(boxes.count(), 1)
self.assertEqual(boxes[0].name, 'name_1')
2023-03-22 17:50:18 +00:00
def test_reverse_join(self) -> None:
box_qs = BoxJoinModel.objects.filter(name='name_1')
items = JoinItemForeignKey.objects.all().join(box_qs)
self.assertEqual(items.count(), 1)
self.assertEqual(items[0].weight, 10)