From c8638b70793ec4d78cb9692f535f1b4db63c348f Mon Sep 17 00:00:00 2001 From: Maria Lorena Rodriguez Viruel Date: Thu, 5 Dec 2024 10:16:16 -0300 Subject: [PATCH] fix(#123): improve cht hierarchy --- mediator/test/cht-resource-factories.ts | 20 +++++++------ mediator/test/workflows.spec.ts | 38 +++++++++++++++++-------- 2 files changed, 38 insertions(+), 20 deletions(-) diff --git a/mediator/test/cht-resource-factories.ts b/mediator/test/cht-resource-factories.ts index cd3830b1..53036b96 100644 --- a/mediator/test/cht-resource-factories.ts +++ b/mediator/test/cht-resource-factories.ts @@ -1,11 +1,11 @@ import { randomUUID } from 'crypto'; import { Factory } from 'rosie'; -const PlaceFactory = Factory.define('place') +export const PlaceFactory = Factory.define('place') .option('placeId', randomUUID()) .attr('name', 'CHP Branch One') .attr('type', 'district_hospital') - .attr('parent', ['placeId'], function (placeId) { + .attr('placeId', ['placeId'], function (placeId) { return placeId; }); @@ -14,19 +14,23 @@ const ContactFactory = Factory.define('contact') .attr('phone', '+2868917046'); export const UserFactory = Factory.define('user') - .option('placeId') + .option('parentPlace') .attr('password', 'Dakar1234') .attr('username', 'maria') .attr('type', 'chw') - .attr('place', ['placeId'], function (placeId) { - return PlaceFactory.build({}, { placeId }); + .attr('place', ['parentPlace'], function (parentPlace) { + return { + "name": "Mary's Area", + "type": "health_center", + "parent": parentPlace + }; }) .attr('contact', function () { return ContactFactory.build(); }); export const PatientFactory = Factory.define('patient') - .option('placeId') + .option('place') .attr('name', 'John Test') .attr('phone', '+2548277217095') .attr('date_of_birth', '1980-06-06') @@ -34,8 +38,8 @@ export const PatientFactory = Factory.define('patient') .attr('type', 'person') .attr('role', 'patient') .attr('contact_type', 'patient') - .attr('place', ['placeId'], function (placeId) { - return placeId; + .attr('place', ['place'], function (place) { + return place; }); const DocsFieldsFactory = Factory.define('fields') diff --git a/mediator/test/workflows.spec.ts b/mediator/test/workflows.spec.ts index e2b9ed78..f5dba817 100644 --- a/mediator/test/workflows.spec.ts +++ b/mediator/test/workflows.spec.ts @@ -1,7 +1,7 @@ import request from 'supertest'; import { OPENHIM, CHT, FHIR, OPENMRS } from '../config'; import { - UserFactory, PatientFactory, TaskReportFactory + UserFactory, PatientFactory, TaskReportFactory, PlaceFactory } from './cht-resource-factories'; import { EndpointFactory as EndpointFactoryBase, @@ -70,26 +70,28 @@ const createOpenMRSIdType = async (name: string) => { } }; -let placeId: string; +const parentPlace = PlaceFactory.build(); let chwUserName: string; let chwPassword: string; let contactId: string; let patientId: string; +let parentPlaceId: string; +let placeId: string; + const configureCHT = async () => { const createPlaceResponse = await request(CHT.url) .post('/api/v1/places') .auth(CHT.username, CHT.password) - .send({ 'name': 'CHP Branch Two', 'type': 'district_hospital' }); + .send(parentPlace); if (createPlaceResponse.status === 200 && createPlaceResponse.body.ok === true) { - placeId = createPlaceResponse.body.id; + parentPlaceId = createPlaceResponse.body.id; } else { throw new Error(`CHT place creation failed: Reason ${createPlaceResponse.status}`); } - const user = UserFactory.build({}, { placeId: placeId }); - + const user = UserFactory.build({}, { parentPlace: parentPlaceId }); chwUserName = user.username; chwPassword = user.password; @@ -102,6 +104,15 @@ const configureCHT = async () => { } else { throw new Error(`CHT user creation failed: Reason ${createUserResponse.status}`); } + + const retrieveChtHealthCenterResponse = await request(CHT.url) + .get('/api/v2/users/maria') + .auth(CHT.username, CHT.password); + if (retrieveChtHealthCenterResponse.status === 200) { + placeId = retrieveChtHealthCenterResponse.body.place[0]._id; + } else { + throw new Error(`CHT health center retrieval failed: Reason ${retrieveChtHealthCenterResponse.status}`); + } }; describe('Workflows', () => { @@ -122,12 +133,13 @@ describe('Workflows', () => { expect(checkMediatorResponse.status).toBe(200); expect(checkMediatorResponse.body.status).toBe('success'); - const patient = PatientFactory.build({name: 'OpenMRS Patient', phone: '+2548277217095'}, { placeId: placeId }); + const patient = PatientFactory.build({name: 'CHTOpenMRS Patient', phone: '+2548277217095'}, { place: placeId }); const createPatientResponse = await request(CHT.url) .post('/api/v1/people') .auth(chwUserName, chwPassword) .send(patient); + expect(createPatientResponse.status).toBe(200); expect(createPatientResponse.body.ok).toEqual(true); patientId = createPatientResponse.body.id; @@ -168,7 +180,7 @@ describe('Workflows', () => { ); const searchOpenMrsPatientResponse = await request(OPENMRS.url) - .get(`/Patient/?given=OpenMRS&family=Patient`) + .get(`/Patient/?given=CHTOpenMRS&family=Patient`) .auth(OPENMRS.username, OPENMRS.password); expect(searchOpenMrsPatientResponse.status).toBe(200); expect(searchOpenMrsPatientResponse.body.total).toBe(1); @@ -181,7 +193,7 @@ describe('Workflows', () => { .auth(FHIR.username, FHIR.password); expect(checkMediatorResponse.status).toBe(200); - const openMrsPatient = OpenMRSPatientFactory.build({}, {placeId}); + const openMrsPatient = OpenMRSPatientFactory.build({}, {placeId: parentPlace.placeId}); const createOpenMrsPatientResponse = await request(OPENMRS.url) .post('/Patient') @@ -201,7 +213,7 @@ describe('Workflows', () => { .send(); expect(triggerOpenMrsSyncPatientResponse.status).toBe(200); - await new Promise((r) => setTimeout(r, 10000)); + await new Promise((r) => setTimeout(r, 20000)); const retrieveFhirPatientIdResponse = await request(FHIR.url) .get('/fhir/Patient/?identifier=' + openMrsPatientId) @@ -217,6 +229,8 @@ describe('Workflows', () => { expect(retrieveChtPatientResponse.status).toBe(200); }); + }); + describe('Loss To Follow-Up (LTFU) workflow', () => { let encounterUrl: string; let endpointId: string; @@ -263,7 +277,7 @@ describe('Workflows', () => { expect(retrieveOrganizationResponse.status).toBe(200); expect(retrieveOrganizationResponse.body.total).toBe(1); - const patient = PatientFactory.build({}, { name: 'LTFU patient', placeId: placeId }); + const patient = PatientFactory.build({}, { name: 'LTFU patient', place: placeId }); const createPatientResponse = await request(CHT.url) .post('/api/v1/people') @@ -294,7 +308,7 @@ describe('Workflows', () => { expect(sendMediatorServiceRequestResponse.status).toBe(201); encounterUrl = sendMediatorServiceRequestResponse.body.criteria; - const taskReport = TaskReportFactory.build({}, { placeId, contactId, patientId }); + const taskReport = TaskReportFactory.build({}, { placeId: placeId, contactId, patientId }); const submitChtTaskResponse = await request(CHT.url) .post('/medic/_bulk_docs')