From 151bbd8dfb9283f03661a1da52e81762a24fff8f Mon Sep 17 00:00:00 2001 From: delcroip Date: Wed, 2 Oct 2024 16:12:46 +0200 Subject: [PATCH 1/5] support non calculation while still evaluating using uuid --- calculation/schema.py | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/calculation/schema.py b/calculation/schema.py index 11d1f78..d64f927 100644 --- a/calculation/schema.py +++ b/calculation/schema.py @@ -124,9 +124,12 @@ def resolve_calculation_rules(parent, info, **kwargs): list_cr = [] for cr in CALCULATION_RULES: calculation = f'{calculation}' - if (UUID(cr.uuid) == calculation and calcrule_type == cr.type) \ - or (UUID(cr.uuid) == calculation and calcrule_type is None) \ - or (calculation == 'None' and calcrule_type == cr.type): + if ( + (calculation and + UUID(cr.uuid) == UUID(calculation) and + (calcrule_type == cr.type or calcrule_type is None)) or + (calculation == 'None' and calcrule_type == cr.type) + ): list_cr = _append_to_calcrule_list(list_cr, cr) else: list_cr = [] From 27644a17902537fa0e2d567724bbaed725869e74 Mon Sep 17 00:00:00 2001 From: delcroip Date: Wed, 2 Oct 2024 16:14:26 +0200 Subject: [PATCH 2/5] improve readability --- calculation/schema.py | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/calculation/schema.py b/calculation/schema.py index d64f927..2c50ecc 100644 --- a/calculation/schema.py +++ b/calculation/schema.py @@ -125,10 +125,13 @@ def resolve_calculation_rules(parent, info, **kwargs): for cr in CALCULATION_RULES: calculation = f'{calculation}' if ( - (calculation and - UUID(cr.uuid) == UUID(calculation) and - (calcrule_type == cr.type or calcrule_type is None)) or - (calculation == 'None' and calcrule_type == cr.type) + ( + calculation and + UUID(cr.uuid) == UUID(calculation) and + (calcrule_type == cr.type or calcrule_type is None) + ) or ( + calculation == 'None' and calcrule_type == cr.type + ) ): list_cr = _append_to_calcrule_list(list_cr, cr) else: From 23d236292edd21e3c7a5bcd3a63a84ca0f6186aa Mon Sep 17 00:00:00 2001 From: delcroip Date: Thu, 3 Oct 2024 10:29:26 +0200 Subject: [PATCH 3/5] evaluate obj iso string --- calculation/schema.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/calculation/schema.py b/calculation/schema.py index 2c50ecc..aca5393 100644 --- a/calculation/schema.py +++ b/calculation/schema.py @@ -123,14 +123,13 @@ def resolve_calculation_rules(parent, info, **kwargs): if calculation or calcrule_type: list_cr = [] for cr in CALCULATION_RULES: - calculation = f'{calculation}' if ( ( calculation and - UUID(cr.uuid) == UUID(calculation) and + UUID(cr.uuid) == UUID(str(calculation)) and (calcrule_type == cr.type or calcrule_type is None) ) or ( - calculation == 'None' and calcrule_type == cr.type + not calculation and calcrule_type == cr.type ) ): list_cr = _append_to_calcrule_list(list_cr, cr) From 6cd608952f8c5cdb2bb2571a818bdd2658debf24 Mon Sep 17 00:00:00 2001 From: Patrick Delcroix Date: Thu, 3 Oct 2024 11:10:58 +0200 Subject: [PATCH 4/5] evaluate obj iso string (#64) --- calculation/schema.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/calculation/schema.py b/calculation/schema.py index 2c50ecc..aca5393 100644 --- a/calculation/schema.py +++ b/calculation/schema.py @@ -123,14 +123,13 @@ def resolve_calculation_rules(parent, info, **kwargs): if calculation or calcrule_type: list_cr = [] for cr in CALCULATION_RULES: - calculation = f'{calculation}' if ( ( calculation and - UUID(cr.uuid) == UUID(calculation) and + UUID(cr.uuid) == UUID(str(calculation)) and (calcrule_type == cr.type or calcrule_type is None) ) or ( - calculation == 'None' and calcrule_type == cr.type + not calculation and calcrule_type == cr.type ) ): list_cr = _append_to_calcrule_list(list_cr, cr) From 38462916995d31c6546bbeb75efb968358426243 Mon Sep 17 00:00:00 2001 From: delcroip Date: Thu, 3 Oct 2024 11:41:34 +0200 Subject: [PATCH 5/5] add tests --- calculation/tests/test_gql.py | 80 ++++++++++++++++++++++++++++++++--- 1 file changed, 75 insertions(+), 5 deletions(-) diff --git a/calculation/tests/test_gql.py b/calculation/tests/test_gql.py index 47e2117..adb367e 100644 --- a/calculation/tests/test_gql.py +++ b/calculation/tests/test_gql.py @@ -3,6 +3,7 @@ from dataclasses import dataclass from core.models import User, filter_validity +from core.models.openimis_graphql_test_case import openIMISGraphQLTestCase from core.test_helpers import create_test_interactive_user from django.conf import settings from graphene_django.utils.testing import GraphQLTestCase @@ -13,7 +14,7 @@ from insuree.test_helpers import create_test_insuree from policy.test_helpers import create_test_policy from contribution.models import Premium, PayTypeChoices - +from calculation.calculation_rule import ContributionValuationRule from location.test_helpers import create_test_location, create_test_health_facility, create_test_village from payer.models import Payer from product.models import Product @@ -28,7 +29,7 @@ class DummyContext: user: User -class CalcualtionGQLTestCase(GraphQLTestCase): +class CalcualtionGQLTestCase(openIMISGraphQLTestCase): GRAPHQL_URL = f'/{settings.SITE_ROOT()}graphql' # This is required by some version of graphene but is never used. It should be set to the schema but the import # is shown as an error in the IDE, so leaving it as True. @@ -65,7 +66,7 @@ def test_by_class_name(self): ) content = json.loads(response.content) - + self.assertTrue('data' in content and 'calculationRulesByClassName' in content['data']) # This validates the status code and if you get errors self.assertResponseNoErrors(response) @@ -86,12 +87,81 @@ def test_simple(self): ) content = json.loads(response.content) - + self.assertTrue('data' in content and 'calculationRules' in content['data']) # This validates the status code and if you get errors self.assertResponseNoErrors(response) # Add some more asserts if you like + def test_account_payable(self): + + response = self.query( + ''' + + query{ + calculationRules(calcruleType: "account_payable") + { + calculationRules{uuid, calculationClassName} + } + } + ''', + headers={"HTTP_AUTHORIZATION": f"Bearer {self.admin_token}"}, + ) + + content = json.loads(response.content) + self.assertTrue('data' in content and 'calculationRules' in content['data']) + + # This validates the status code and if you get errors + self.assertResponseNoErrors(response) + + # Add some more asserts if you like + + + def test_account_receivable(self): + + response = self.query( + ''' + + query{ + calculationRules(calcruleType: "account_receivable") + { + calculationRules{uuid, calculationClassName} + } + } + ''', + headers={"HTTP_AUTHORIZATION": f"Bearer {self.admin_token}"}, + ) + + content = json.loads(response.content) + self.assertTrue('data' in content and 'calculationRules' in content['data']) + # This validates the status code and if you get errors + self.assertResponseNoErrors(response) + + # Add some more asserts if you like + + def test_uuid(self): + + response = self.query( + f''' + + query{{ + calculationRules(calculation: "{ContributionValuationRule.uuid}") + {{ + calculationRules{{uuid, calculationClassName}} + }} + }} + ''', + headers={"HTTP_AUTHORIZATION": f"Bearer {self.admin_token}"}, + ) + + content = json.loads(response.content) + self.assertTrue('data' in content and 'calculationRules' in content['data']) + # This validates the status code and if you get errors + self.assertResponseNoErrors(response) + + # Add some more asserts if you like + + def test_params(self): response = self.query( @@ -107,7 +177,7 @@ def test_params(self): ) content = json.loads(response.content) - + self.assertTrue('data' in content and 'linkedClass' in content['data']) # This validates the status code and if you get errors self.assertResponseNoErrors(response)