From 690b8610919f901250a84c9a5eeefcf376ce2470 Mon Sep 17 00:00:00 2001 From: Prafful Sharma <115104695+DraKen0009@users.noreply.github.com> Date: Tue, 23 Apr 2024 00:23:37 +0530 Subject: [PATCH] Fix ward filters and add tests for places APIs (#2029) * tests for places api * minor update * updated tests * updated ward list endpoint * updated local_body list endpoint * updated district list endpoint * minor updates in state tests * fixed bug for filtering wards usign state and state_name * updated district tests * fixing lint issue * Update care/utils/tests/test_utils.py --------- Co-authored-by: Aakash Singh Co-authored-by: Vignesh Hari --- care/facility/tests/test_places_api.py | 194 +++++++++++++++++++++++++ care/users/api/viewsets/lsg.py | 4 +- care/utils/tests/test_utils.py | 25 ++-- 3 files changed, 212 insertions(+), 11 deletions(-) create mode 100644 care/facility/tests/test_places_api.py diff --git a/care/facility/tests/test_places_api.py b/care/facility/tests/test_places_api.py new file mode 100644 index 0000000000..b05c717243 --- /dev/null +++ b/care/facility/tests/test_places_api.py @@ -0,0 +1,194 @@ +from rest_framework import status +from rest_framework.test import APITestCase + +from care.users.models import District, LocalBody, State, Ward +from care.utils.tests.test_utils import TestUtils + + +class DistrictViewSetTestCase(TestUtils, APITestCase): + @classmethod + def setUpTestData(cls) -> None: + cls.state = cls.create_state() + cls.district = cls.create_district(cls.state) + cls.local_body = cls.create_local_body(cls.district) + cls.super_user = cls.create_super_user("su", cls.district) + cls.facility = cls.create_facility(cls.super_user, cls.district, cls.local_body) + cls.user = cls.create_user("staff", cls.district, home_facility=cls.facility) + cls.ward = cls.create_ward(cls.local_body) + + def test_list_district(self): + state2 = self.create_state(name="TEST_STATE_2") + self.create_district(state2, name="TEST_DISTRICT_2") + + response = self.client.get("/api/v1/district/") + self.assertEqual(response.status_code, status.HTTP_200_OK) + + response = self.client.get("/api/v1/district/?district_name=TEST_DISTRICT_2") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "TEST_DISTRICT_2") + + response = self.client.get(f"/api/v1/district/?state={state2.id}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "TEST_DISTRICT_2") + + response = self.client.get(f"/api/v1/district/?state_name={self.state.name}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.district.name) + + def test_retrieve_district(self): + response = self.client.get(f"/api/v1/district/{self.district.id}/") + district_obj = District.objects.get(pk=self.district.id) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data.get("id"), district_obj.id) + self.assertEqual(response.data.get("name"), district_obj.name) + + def test_list_district_all_local_body(self): + response = self.client.get( + f"/api/v1/district/{self.district.id}/get_all_local_body/" + ) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data[0]["name"], self.local_body.name) + self.assertEqual(response.data[0]["wards"][0]["name"], self.ward.name) + + def test_list_district_local_body(self): + response = self.client.get( + f"/api/v1/district/{self.district.id}/local_bodies/", + ) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data[0]["name"], self.local_body.name) + + +class LocalBodyViewSetTestCase(TestUtils, APITestCase): + @classmethod + def setUpTestData(cls) -> None: + cls.state = cls.create_state() + cls.district = cls.create_district(cls.state) + cls.local_body = cls.create_local_body(cls.district) + cls.super_user = cls.create_super_user("su", cls.district) + cls.facility = cls.create_facility(cls.super_user, cls.district, cls.local_body) + cls.user = cls.create_user("staff", cls.district, home_facility=cls.facility) + + def test_list_local_body(self): + state2 = self.create_state(name="TEST_STATE_2") + district2 = self.create_district(state2) + self.create_local_body(district2, name="LOCAL_BODY_2") + + response = self.client.get("/api/v1/local_body/") + self.assertEqual(response.status_code, status.HTTP_200_OK) + + response = self.client.get( + f"/api/v1/local_body/?local_body_name={self.local_body.name}" + ) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.local_body.name) + + response = self.client.get(f"/api/v1/local_body/?state={state2.id}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "LOCAL_BODY_2") + + response = self.client.get(f"/api/v1/local_body/?state_name={self.state.name}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.local_body.name) + + response = self.client.get(f"/api/v1/local_body/?district={self.district.id}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.local_body.name) + + response = self.client.get(f"/api/v1/local_body/?district2={district2.name}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "LOCAL_BODY_2") + + def test_retrieve_local_body(self): + response = self.client.get(f"/api/v1/local_body/{self.local_body.id}/") + local_body_obj = LocalBody.objects.get(pk=self.local_body.id) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data.get("id"), local_body_obj.id) + self.assertEqual(response.data.get("name"), local_body_obj.name) + + +class StateViewSetTestCase(TestUtils, APITestCase): + @classmethod + def setUpTestData(cls) -> None: + cls.state = cls.create_state() + cls.district = cls.create_district(cls.state) + cls.local_body = cls.create_local_body(cls.district) + cls.super_user = cls.create_super_user("su", cls.district) + cls.facility = cls.create_facility(cls.super_user, cls.district, cls.local_body) + cls.user = cls.create_user("staff", cls.district, home_facility=cls.facility) + + def test_list_state(self): + response = self.client.get("/api/v1/state/") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["count"], len(State.objects.all())) + + def test_retrieve_state(self): + response = self.client.get(f"/api/v1/state/{self.state.id}/") + state_obj = State.objects.get(pk=self.state.id) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data.get("id"), state_obj.id) + self.assertEqual(response.data.get("name"), state_obj.name) + + def test_list_state_districts(self): + response = self.client.get(f"/api/v1/state/{self.state.id}/districts/") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data[0]["name"], self.district.name) + + +class WardViewSetTestCase(TestUtils, APITestCase): + @classmethod + def setUpTestData(cls) -> None: + cls.state = cls.create_state() + cls.district = cls.create_district(cls.state) + cls.local_body = cls.create_local_body(cls.district) + cls.super_user = cls.create_super_user("su", cls.district) + cls.facility = cls.create_facility(cls.super_user, cls.district, cls.local_body) + cls.user = cls.create_user("staff", cls.district, home_facility=cls.facility) + cls.ward = cls.create_ward(cls.local_body) + + def test_list_ward(self): + state2 = self.create_state(name="TEST_STATE_2") + district2 = self.create_district(state2) + local_body2 = self.create_local_body(district2) + self.create_ward(local_body2, name="WARD2") + + # Endpoints to filter with state id and state name are throwing error + + response = self.client.get("/api/v1/ward/") + self.assertEqual(response.status_code, status.HTTP_200_OK) + + response = self.client.get("/api/v1/ward/?ward_name=WARD2") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "WARD2") + + response = self.client.get(f"/api/v1/ward/?district={district2.id}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "WARD2") + + response = self.client.get(f"/api/v1/ward/?district_name={self.district.name}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.ward.name) + + response = self.client.get(f"/api/v1/ward/?local_body={self.local_body.id}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.ward.name) + self.assertEqual(response.data["results"][0]["local_body"], self.local_body.id) + + response = self.client.get(f"/api/v1/ward/?local_body_name={local_body2.name}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "WARD2") + + response = self.client.get(f"/api/v1/ward/?state_name={state2.name}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], "WARD2") + + response = self.client.get(f"/api/v1/ward/?state={self.state.id}") + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data["results"][0]["name"], self.ward.name) + + def test_retrieve_ward(self): + response = self.client.get(f"/api/v1/ward/{self.ward.id}/") + ward_obj = Ward.objects.get(pk=self.ward.id) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data.get("id"), ward_obj.id) + self.assertEqual(response.data.get("name"), ward_obj.name) diff --git a/care/users/api/viewsets/lsg.py b/care/users/api/viewsets/lsg.py index 2b45ccbb35..a899b387cf 100644 --- a/care/users/api/viewsets/lsg.py +++ b/care/users/api/viewsets/lsg.py @@ -127,9 +127,9 @@ class LocalBodyViewSet( class WardFilterSet(filters.FilterSet): - state = filters.NumberFilter(field_name="district__state_id") + state = filters.NumberFilter(field_name="local_body__district__state_id") state_name = filters.CharFilter( - field_name="district__state__name", lookup_expr="icontains" + field_name="local_body__district__state__name", lookup_expr="icontains" ) district = filters.NumberFilter(field_name="local_body__district_id") district_name = filters.CharFilter( diff --git a/care/utils/tests/test_utils.py b/care/utils/tests/test_utils.py index 2b8471338b..acb286f043 100644 --- a/care/utils/tests/test_utils.py +++ b/care/utils/tests/test_utils.py @@ -96,12 +96,16 @@ def get_base_url(self) -> str: raise NotImplementedError() @classmethod - def create_state(cls) -> State: - return State.objects.create(name=f"State{now().timestamp()}") + def create_state(cls, **kwargs) -> State: + data = {"name": f"State{now().timestamp()}"} + data.update(kwargs) + return State.objects.create(**data) @classmethod - def create_district(cls, state: State) -> District: - return District.objects.create(state=state, name=f"District{now().timestamp()}") + def create_district(cls, state: State, **kwargs) -> District: + data = {"state": state, "name": f"District{now().timestamp()}"} + data.update(**kwargs) + return District.objects.create(**data) @classmethod def create_local_body(cls, district: District, **kwargs) -> LocalBody: @@ -175,11 +179,14 @@ def create_user( return user @classmethod - def create_ward(cls, local_body) -> Ward: - ward = Ward.objects.create( - name=f"Ward{now().timestamp()}", local_body=local_body, number=1 - ) - return ward + def create_ward(cls, local_body, **kwargs) -> Ward: + data = { + "name": f"Ward{now().timestamp()}", + "local_body": local_body, + "number": 1, + } + data.update(kwargs) + return Ward.objects.create(**data) @classmethod def create_super_user(cls, *args, **kwargs) -> User: