diff options
| author | Bendeguz Csirmaz <csirmazbendeguz@gmail.com> | 2024-04-07 10:32:16 +0800 |
|---|---|---|
| committer | Sarah Boyce <42296566+sarahboyce@users.noreply.github.com> | 2024-11-29 11:23:04 +0100 |
| commit | 978aae4334fa71ba78a3e94408f0f3aebde8d07c (patch) | |
| tree | dd1cc322769441a3dd28b952ce52e07c3f72f90a /tests/composite_pk/test_create.py | |
| parent | 86661f2449fb0903f72b3522c68e146934013377 (diff) | |
Fixed #373 -- Added CompositePrimaryKey.
Thanks Lily Foote and Simon Charette for reviews and mentoring
this Google Summer of Code 2024 project.
Co-authored-by: Simon Charette <charette.s@gmail.com>
Co-authored-by: Lily Foote <code@lilyf.org>
Diffstat (limited to 'tests/composite_pk/test_create.py')
| -rw-r--r-- | tests/composite_pk/test_create.py | 138 |
1 files changed, 138 insertions, 0 deletions
diff --git a/tests/composite_pk/test_create.py b/tests/composite_pk/test_create.py new file mode 100644 index 0000000000..7c9925b946 --- /dev/null +++ b/tests/composite_pk/test_create.py @@ -0,0 +1,138 @@ +from django.test import TestCase + +from .models import Tenant, User + + +class CompositePKCreateTests(TestCase): + maxDiff = None + + @classmethod + def setUpTestData(cls): + cls.tenant = Tenant.objects.create() + cls.user = User.objects.create( + tenant=cls.tenant, + id=1, + email="user0001@example.com", + ) + + def test_create_user(self): + test_cases = ( + {"tenant": self.tenant, "id": 2412, "email": "user2412@example.com"}, + {"tenant_id": self.tenant.id, "id": 5316, "email": "user5316@example.com"}, + {"pk": (self.tenant.id, 7424), "email": "user7424@example.com"}, + ) + + for fields in test_cases: + with self.subTest(fields=fields): + count = User.objects.count() + user = User(**fields) + obj = User.objects.create(**fields) + self.assertEqual(obj.tenant_id, self.tenant.id) + self.assertEqual(obj.id, user.id) + self.assertEqual(obj.pk, (self.tenant.id, user.id)) + self.assertEqual(obj.email, user.email) + self.assertEqual(count + 1, User.objects.count()) + + def test_save_user(self): + test_cases = ( + {"tenant": self.tenant, "id": 9241, "email": "user9241@example.com"}, + {"tenant_id": self.tenant.id, "id": 5132, "email": "user5132@example.com"}, + {"pk": (self.tenant.id, 3014), "email": "user3014@example.com"}, + ) + + for fields in test_cases: + with self.subTest(fields=fields): + count = User.objects.count() + user = User(**fields) + self.assertIsNotNone(user.id) + self.assertIsNotNone(user.email) + user.save() + self.assertEqual(user.tenant_id, self.tenant.id) + self.assertEqual(user.tenant, self.tenant) + self.assertIsNotNone(user.id) + self.assertEqual(user.pk, (self.tenant.id, user.id)) + self.assertEqual(user.email, fields["email"]) + self.assertEqual(user.email, f"user{user.id}@example.com") + self.assertEqual(count + 1, User.objects.count()) + + def test_bulk_create_users(self): + objs = [ + User(tenant=self.tenant, id=8291, email="user8291@example.com"), + User(tenant_id=self.tenant.id, id=4021, email="user4021@example.com"), + User(pk=(self.tenant.id, 8214), email="user8214@example.com"), + ] + + obj_1, obj_2, obj_3 = User.objects.bulk_create(objs) + + self.assertEqual(obj_1.tenant_id, self.tenant.id) + self.assertEqual(obj_1.id, 8291) + self.assertEqual(obj_1.pk, (obj_1.tenant_id, obj_1.id)) + self.assertEqual(obj_1.email, "user8291@example.com") + self.assertEqual(obj_2.tenant_id, self.tenant.id) + self.assertEqual(obj_2.id, 4021) + self.assertEqual(obj_2.pk, (obj_2.tenant_id, obj_2.id)) + self.assertEqual(obj_2.email, "user4021@example.com") + self.assertEqual(obj_3.tenant_id, self.tenant.id) + self.assertEqual(obj_3.id, 8214) + self.assertEqual(obj_3.pk, (obj_3.tenant_id, obj_3.id)) + self.assertEqual(obj_3.email, "user8214@example.com") + + def test_get_or_create_user(self): + test_cases = ( + { + "pk": (self.tenant.id, 8314), + "defaults": {"email": "user8314@example.com"}, + }, + { + "tenant": self.tenant, + "id": 3142, + "defaults": {"email": "user3142@example.com"}, + }, + { + "tenant_id": self.tenant.id, + "id": 4218, + "defaults": {"email": "user4218@example.com"}, + }, + ) + + for fields in test_cases: + with self.subTest(fields=fields): + count = User.objects.count() + user, created = User.objects.get_or_create(**fields) + self.assertIs(created, True) + self.assertIsNotNone(user.id) + self.assertEqual(user.pk, (self.tenant.id, user.id)) + self.assertEqual(user.tenant_id, self.tenant.id) + self.assertEqual(user.email, fields["defaults"]["email"]) + self.assertEqual(user.email, f"user{user.id}@example.com") + self.assertEqual(count + 1, User.objects.count()) + + def test_update_or_create_user(self): + test_cases = ( + { + "pk": (self.tenant.id, 2931), + "defaults": {"email": "user2931@example.com"}, + }, + { + "tenant": self.tenant, + "id": 6428, + "defaults": {"email": "user6428@example.com"}, + }, + { + "tenant_id": self.tenant.id, + "id": 5278, + "defaults": {"email": "user5278@example.com"}, + }, + ) + + for fields in test_cases: + with self.subTest(fields=fields): + count = User.objects.count() + user, created = User.objects.update_or_create(**fields) + self.assertIs(created, True) + self.assertIsNotNone(user.id) + self.assertEqual(user.pk, (self.tenant.id, user.id)) + self.assertEqual(user.tenant_id, self.tenant.id) + self.assertEqual(user.email, fields["defaults"]["email"]) + self.assertEqual(user.email, f"user{user.id}@example.com") + self.assertEqual(count + 1, User.objects.count()) |
