Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

updated populate fixing-investigation command #2500

Open
wants to merge 25 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
54be430
updated populate fixing-investigation command
DraKen0009 Sep 26, 2024
5156565
removed comments
DraKen0009 Sep 26, 2024
53d5692
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Sep 26, 2024
5a20988
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 7, 2024
d6c4d85
added error handling for uncleaned data
DraKen0009 Oct 7, 2024
31cb31e
added error handling for uncleaned data
DraKen0009 Oct 7, 2024
abf76fd
updated investigation json
DraKen0009 Oct 8, 2024
af764d2
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 15, 2024
1c27434
fixed indentation
DraKen0009 Oct 15, 2024
f2461d8
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 18, 2024
1e9b1ec
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 22, 2024
7aa339f
improved exception handling
DraKen0009 Oct 23, 2024
77581f7
improved exception handling
DraKen0009 Oct 23, 2024
a9b70f5
added test cases
DraKen0009 Oct 23, 2024
e18d896
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 23, 2024
02de4de
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 26, 2024
5dff175
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Oct 30, 2024
43bfc8a
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Nov 3, 2024
1b75a13
Merge branch 'refs/heads/master' into fixing-investigation-loading
DraKen0009 Nov 4, 2024
b0bd9a7
Merge remote-tracking branch 'origin/fixing-investigation-loading' in…
DraKen0009 Nov 4, 2024
48128aa
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Nov 7, 2024
3dba2b5
fixed the typo
DraKen0009 Nov 7, 2024
3de9f41
Merge remote-tracking branch 'origin/fixing-investigation-loading' in…
DraKen0009 Nov 7, 2024
20b6461
implemented rabbit changes and reformatted the code
DraKen0009 Nov 7, 2024
3aa0853
Merge branch 'develop' into fixing-investigation-loading
DraKen0009 Nov 23, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
48 changes: 48 additions & 0 deletions care/facility/tests/test_management_commands.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
import json
from pathlib import Path

from django.core.management import call_command
from django.test import TestCase

from care.facility.models import PatientInvestigation, PatientInvestigationGroup


class LoadInvestigationsCommandTest(TestCase):
@classmethod
def setUpTestData(cls):
call_command("populate_investigations", verbosity=0)

with Path("data/investigations.json").open() as investigations_data:
cls.investigations = json.load(investigations_data)

with Path("data/investigation_groups.json").open() as investigation_groups_data:
cls.investigation_groups = json.load(investigation_groups_data)

sainak marked this conversation as resolved.
Show resolved Hide resolved
def test_number_of_entries(self):
self.assertEqual(len(self.investigations), PatientInvestigation.objects.count())
self.assertEqual(
len(self.investigation_groups), PatientInvestigationGroup.objects.count()
)

def test_relation_between_investigations_and_groups(self):
# taking first and last 5 data to test it out
test_investigation_data = self.investigations[:5] + self.investigations[-5:]

# creating a dictionary to avoid looping of group data for each check
group_dict = {
int(group["id"]): group["name"] for group in self.investigation_groups
}

for investigation_data in test_investigation_data:
investigation = PatientInvestigation.objects.get(
name=investigation_data["name"]
)

group_values = list(investigation.groups.values_list("name", flat=True))

expected_groups = [
group_dict[category_id]
for category_id in investigation_data["category_id"]
]

self.assertCountEqual(group_values, expected_groups)
97 changes: 53 additions & 44 deletions care/users/management/commands/populate_investigations.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,74 +9,70 @@
PatientInvestigationGroup,
)

with Path("data/investigations.json").open() as investigations_data:
investigations = json.load(investigations_data)

with Path("data/investigation_groups.json").open() as investigation_groups_data:
investigation_groups = json.load(investigation_groups_data)


class Command(BaseCommand):
"""
Populates Investigation seed data
"""

help = "Seed Data for Investigations"

def handle(self, *args, **kwargs):
investigation_group_dict = {}
with Path("data/investigations.json").open() as investigations_data:
investigations = json.load(investigations_data)

investigation_groups_to_create = [
PatientInvestigationGroup(name=group.get("name"))
for group in investigation_groups
if group.get("id") not in investigation_group_dict
]
created_groups = PatientInvestigationGroup.objects.bulk_create(
investigation_groups_to_create
)
investigation_group_dict.update({group.id: group for group in created_groups})
with Path("data/investigation_groups.json").open() as investigation_groups_data:
investigation_groups = json.load(investigation_groups_data)

existing_objs = PatientInvestigation.objects.filter(
name__in=[investigation["name"] for investigation in investigations]
)
investigation_group_dict = {}

for investigation_group in investigation_groups:
current_obj = PatientInvestigationGroup.objects.filter(
name=investigation_group["name"]
).first()
if not current_obj:
current_obj = PatientInvestigationGroup(
name=investigation_group["name"]
)
current_obj.save()
investigation_group_dict[str(investigation_group["id"])] = current_obj
sainak marked this conversation as resolved.
Show resolved Hide resolved

bulk_create_data = []
bulk_update_data = []
investigations_to_update_groups = []

for investigation in investigations:
data = {
"name": investigation["name"],
"unit": investigation.get("unit", ""),
"ideal_value": investigation.get("ideal_value", ""),
"min_value": (
None
if investigation.get("min_value") is None
else float(investigation.get("min_value"))
),
"max_value": (
None
if investigation.get("max_value") is None
else float(investigation.get("max_value"))
),
"investigation_type": investigation["type"],
"min_value": None,
"max_value": None,
"investigation_type": investigation.get("type", None),
"choices": investigation.get("choices", ""),
}

existing_obj = existing_objs.filter(name=data["name"]).first()
try:
data["min_value"] = float(investigation["min"])
except (ValueError, TypeError, KeyError):
data["min_value"] = None
try:
data["max_value"] = float(investigation["max"])
except (ValueError, TypeError, KeyError):
data["max_value"] = None

existing_obj = PatientInvestigation.objects.filter(
name=data["name"]
).first()
if existing_obj:
for field, value in data.items():
setattr(existing_obj, field, value)
bulk_update_data.append(existing_obj)
investigations_to_update_groups.append(
(existing_obj, investigation["category_id"])
)
else:
new_obj = PatientInvestigation(**data)
bulk_create_data.append(new_obj)

group_ids = investigation.get("category_ids", [])
groups_to_add = [
investigation_group_dict[category_id] for category_id in group_ids
]
if existing_obj:
existing_obj.groups.set(groups_to_add)
else:
data["groups"] = groups_to_add
investigations_to_update_groups.append(
sainak marked this conversation as resolved.
Show resolved Hide resolved
(new_obj, investigation["category_id"])
)

with transaction.atomic():
if bulk_create_data:
Expand All @@ -94,3 +90,16 @@ def handle(self, *args, **kwargs):
"choices",
],
)

for investigation_obj, category_ids in investigations_to_update_groups:
groups_to_add = [
investigation_group_dict.get(str(category_id))
for category_id in category_ids
]
investigation_obj.save()
investigation_obj.groups.set(groups_to_add)
sainak marked this conversation as resolved.
Show resolved Hide resolved

if kwargs.get("verbosity", 1) > 0:
self.stdout.write(
self.style.SUCCESS("Successfully populated investigation data")
)
52 changes: 52 additions & 0 deletions data/investigation_groups.json
Original file line number Diff line number Diff line change
Expand Up @@ -26,5 +26,57 @@
{
"id": "7",
"name": "Kidney Function test"
},
{
"id": "8",
"name": "Elecyrolytes"
},
sainak marked this conversation as resolved.
Show resolved Hide resolved
{
"id": "9",
"name": "Lipid Profile"
},
{
"id": "10",
"name": "ABG"
},
{
"id": "11",
"name": "Cardiac Enzyme"
},
{
"id": "12",
"name": "RFT"
},
sainak marked this conversation as resolved.
Show resolved Hide resolved
{
"id": "13",
"name": "Blood Glucose Level"
},
{
"id": "14",
"name": "Immunoglobulins"
},
{
"id": "15",
"name": "Other Body Fluids"
},
{
"id": "16",
"name": "Cerebro Spinal Fluid analysis"
},
sainak marked this conversation as resolved.
Show resolved Hide resolved
{
"id": "17",
"name": "Gastric Analysis"
},
{
"id": "18",
"name": "Semen analysis"
},
{
"id": "19",
"name": "Stool Examination"
},
{
"id": "20",
"name": "Thyroid Function Test"
}
]
Loading
Loading