From 14c3cc9e58d403e38ff657a4d9737a6893d5289b Mon Sep 17 00:00:00 2001 From: Agustin Arce Date: Mon, 14 Oct 2024 11:47:54 -0300 Subject: [PATCH 1/3] refactor: add __eq__ on Table --- piccolo/table.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/piccolo/table.py b/piccolo/table.py index bae9b8a4..22e742a3 100644 --- a/piccolo/table.py +++ b/piccolo/table.py @@ -851,6 +851,13 @@ def __repr__(self) -> str: ) return f"<{self.__class__.__name__}: {pk}>" + def __eq__(self, other: Table): + return ( + isinstance(other, self.__class__) + and self.__class__._meta.primary_key + == other.__class__._meta.primary_key + ) + ########################################################################### # Classmethods From b847b3772bce0c43fdcac5f3ce43f3febb67c756 Mon Sep 17 00:00:00 2001 From: Agustin Arce Date: Wed, 16 Oct 2024 21:47:14 -0300 Subject: [PATCH 2/3] feat: add __eq__ on Table --- piccolo/table.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/piccolo/table.py b/piccolo/table.py index 22e742a3..6c86ef77 100644 --- a/piccolo/table.py +++ b/piccolo/table.py @@ -851,12 +851,10 @@ def __repr__(self) -> str: ) return f"<{self.__class__.__name__}: {pk}>" - def __eq__(self, other: Table): - return ( - isinstance(other, self.__class__) - and self.__class__._meta.primary_key - == other.__class__._meta.primary_key - ) + def __eq__(self, other) -> bool: + return isinstance(other, self.__class__) and getattr( + self, self._meta.primary_key._meta.name, None + ) == getattr(other, other._meta.primary_key._meta.name, None) ########################################################################### # Classmethods From ecf8683008220ae2414754aa83e71065cc3ac199 Mon Sep 17 00:00:00 2001 From: Agustin Arce Date: Wed, 16 Oct 2024 21:51:45 -0300 Subject: [PATCH 3/3] testing (Table): test equality --- .../table/instance/test_instance_equality.py | 31 +++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 tests/table/instance/test_instance_equality.py diff --git a/tests/table/instance/test_instance_equality.py b/tests/table/instance/test_instance_equality.py new file mode 100644 index 00000000..b9533453 --- /dev/null +++ b/tests/table/instance/test_instance_equality.py @@ -0,0 +1,31 @@ +from piccolo.testing.test_case import AsyncTableTest +from tests.example_apps.music.tables import Band, Manager + + +class TestInstanceEquality(AsyncTableTest): + tables = [Manager, Band] + + async def asyncSetUp(self): + await super().asyncSetUp() + + self.manager = Manager(name="Guido") + await self.manager.save() + + self.band = Band( + name="Pythonistas", manager=self.manager.id, popularity=100 + ) + await self.band.save() + + async def test_instance_equality(self) -> None: + """ + Make sure for instance equailty. + """ + band_pk = await self.band.objects().first() + band = await self.band.objects(Band.manager).get( + (Band._meta.primary_key == band_pk.id) + ) + manager_pk = await self.manager.objects().first() + manager = await self.manager.objects().get( + Manager._meta.primary_key == manager_pk.id + ) + self.assertTrue(band.manager == manager)