-
Notifications
You must be signed in to change notification settings - Fork 226
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
HTML-842: Add Appointments tag (#302)
- Loading branch information
1 parent
12d3f5a
commit aa38901
Showing
20 changed files
with
689 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
281 changes: 281 additions & 0 deletions
281
api-tests/src/test/java/org/openmrs/module/htmlformentry/AppointmentsTagTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,281 @@ | ||
package org.openmrs.module.htmlformentry; | ||
|
||
import java.util.Date; | ||
import java.util.Map; | ||
|
||
import org.junit.Assert; | ||
import org.junit.Before; | ||
import org.junit.Test; | ||
import org.openmrs.api.context.Context; | ||
import org.openmrs.module.appointments.model.Appointment; | ||
import org.openmrs.module.appointments.model.AppointmentStatus; | ||
import org.openmrs.module.appointments.service.AppointmentsService; | ||
import org.springframework.mock.web.MockHttpServletRequest; | ||
|
||
public class AppointmentsTagTest extends BaseHtmlFormEntryTest { | ||
|
||
@Before | ||
public void loadTestData() throws Exception { | ||
executeVersionedDataSet("org/openmrs/module/htmlformentry/data/RegressionTest-data-openmrs-2.3.xml"); | ||
executeVersionedDataSet("org/openmrs/module/htmlformentry/data/appointmentCheckInTest.xml"); | ||
} | ||
|
||
@Test | ||
public void testAppointmentCheckInTag_shouldDisplayCheckboxesForScheduledAppointmentsForPatient() throws Exception { | ||
new RegressionTestHelper() { | ||
|
||
@Override | ||
public String getFormName() { | ||
return "appointmentCheckInForm"; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabels() { | ||
return new String[] { "Date:", "Location:", "Provider:", "Appointments:" }; | ||
} | ||
|
||
@Override | ||
public void testBlankFormHtml(String html) { | ||
TestUtil.assertFuzzyContains("value=\"05f2ad92-1cc8-4cec-bf54-9cac0200746d\"/>", html); | ||
TestUtil.assertFuzzyContains("2024-08-16, 13:00:00 - of Cos, Hippocrates - Never Never Land", html); | ||
TestUtil.assertFuzzyContains("value=\"75504r42-3ca8-11e3-bf2b-0800271c1111\"/>", html); | ||
TestUtil.assertFuzzyContains("2024-08-15, 12:00:00 - of Cos, Hippocrates - Xanadu", html); | ||
} | ||
}.run(); | ||
} | ||
|
||
@Test | ||
public void testAppointmentCheckInTag_shouldCheckPatientInForSingleAppointment() throws Exception { | ||
final Date date = new Date(); | ||
new RegressionTestHelper() { | ||
|
||
@Override | ||
public String getFormName() { | ||
return "appointmentCheckInForm"; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabels() { | ||
return new String[] { "Date:", "Location:", "Provider:", "Appointments:" }; | ||
} | ||
|
||
@Override | ||
public void setupRequest(MockHttpServletRequest request, Map<String, String> widgets) { | ||
request.setParameter(widgets.get("Date:"), dateAsString(date)); | ||
request.setParameter(widgets.get("Location:"), "2"); | ||
request.setParameter(widgets.get("Provider:"), "502"); | ||
request.setParameter(widgets.get("Appointments:"), "05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
} | ||
|
||
@Override | ||
public void testResults(SubmissionResults results) { | ||
results.assertNoErrors(); | ||
results.assertEncounterCreated(); | ||
Appointment appointment1 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment1.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment1.getFulfillingEncounters().stream().findFirst().get()); | ||
|
||
// just confirm the other appointment has not been checked in or linked to the encounter | ||
Appointment appointment2 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("75504r42-3ca8-11e3-bf2b-0800271c1111"); | ||
Assert.assertEquals(AppointmentStatus.Scheduled, appointment2.getStatus()); | ||
Assert.assertEquals(0, appointment2.getFulfillingEncounters().size()); | ||
} | ||
}.run(); | ||
} | ||
|
||
@Test | ||
public void testAppointmentCheckInTag_shouldCheckPatientInForMultipleAppointments() throws Exception { | ||
final Date date = new Date(); | ||
new RegressionTestHelper() { | ||
|
||
@Override | ||
public String getFormName() { | ||
return "appointmentCheckInForm"; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabels() { | ||
return new String[] { "Date:", "Location:", "Provider:", "Appointments:" }; | ||
} | ||
|
||
@Override | ||
public void setupRequest(MockHttpServletRequest request, Map<String, String> widgets) { | ||
request.setParameter(widgets.get("Date:"), dateAsString(date)); | ||
request.setParameter(widgets.get("Location:"), "2"); | ||
request.setParameter(widgets.get("Provider:"), "502"); | ||
request.setParameter(widgets.get("Appointments:"), "05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
request.setParameter(widgets.get("Appointments:").replace("_1", "_2"), | ||
"75504r42-3ca8-11e3-bf2b-0800271c1111"); | ||
} | ||
|
||
@Override | ||
public void testResults(SubmissionResults results) { | ||
results.assertNoErrors(); | ||
results.assertEncounterCreated(); | ||
|
||
Appointment appointment1 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment1.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment1.getFulfillingEncounters().stream().findFirst().get()); | ||
|
||
Appointment appointment2 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("75504r42-3ca8-11e3-bf2b-0800271c1111"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment2.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment2.getFulfillingEncounters().stream().findFirst().get()); | ||
} | ||
}.run(); | ||
} | ||
|
||
@Test | ||
public void testAppointmentCheckInTag_editShouldDisassociateEncounterFromAppointmentAndAssociateNewEncounter() | ||
throws Exception { | ||
final Date date = new Date(); | ||
new RegressionTestHelper() { | ||
|
||
@Override | ||
public String getFormName() { | ||
return "appointmentCheckInForm"; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabels() { | ||
return new String[] { "Date:", "Location:", "Provider:", "Appointments:" }; | ||
} | ||
|
||
@Override | ||
public void setupRequest(MockHttpServletRequest request, Map<String, String> widgets) { | ||
request.setParameter(widgets.get("Date:"), dateAsString(date)); | ||
request.setParameter(widgets.get("Location:"), "2"); | ||
request.setParameter(widgets.get("Provider:"), "502"); | ||
request.setParameter(widgets.get("Appointments:"), "05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
} | ||
|
||
@Override | ||
public boolean doEditEncounter() { | ||
return true; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabelsForEdit() { | ||
return new String[] { "Appointments:" }; | ||
} | ||
|
||
public void setupEditRequest(MockHttpServletRequest request, Map<String, String> widgets) { | ||
request.setParameter(widgets.get("Appointments:"), ""); | ||
request.setParameter(widgets.get("Appointments:").replace("_1", "_2"), | ||
"75504r42-3ca8-11e3-bf2b-0800271c1111"); | ||
} | ||
|
||
@Override | ||
public void testResults(SubmissionResults results) { | ||
results.assertNoErrors(); | ||
results.assertEncounterCreated(); | ||
|
||
// sanity check | ||
Appointment appointment1 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment1.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment1.getFulfillingEncounters().stream().findFirst().get()); | ||
|
||
Appointment appointment2 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("75504r42-3ca8-11e3-bf2b-0800271c1111"); | ||
Assert.assertEquals(AppointmentStatus.Scheduled, appointment2.getStatus()); | ||
Assert.assertEquals(0, appointment2.getFulfillingEncounters().size()); | ||
} | ||
|
||
// confirm that the associated appointment is now checked by default | ||
@Override | ||
public void testEditFormHtml(String html) { | ||
TestUtil.assertFuzzyContains("value=\"05f2ad92-1cc8-4cec-bf54-9cac0200746d\" checked=\"true\"/>", html); | ||
} | ||
|
||
@Override | ||
public void testEditedResults(SubmissionResults results) { | ||
results.assertNoErrors(); | ||
results.assertEncounterCreated(); | ||
|
||
Appointment appointment1 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment1.getStatus()); // Note that we are NOT changing the status back to Scheduled | ||
Assert.assertEquals(0, appointment1.getFulfillingEncounters().size()); // but encounter should be removed | ||
|
||
Appointment appointment2 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("75504r42-3ca8-11e3-bf2b-0800271c1111"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment2.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment2.getFulfillingEncounters().stream().findFirst().get()); | ||
} | ||
}.run(); | ||
} | ||
|
||
@Test | ||
public void testAppointmentCheckInTag_editingFormWithoutChangingStatusShouldNotCauseError() throws Exception { | ||
final Date date = new Date(); | ||
new RegressionTestHelper() { | ||
|
||
@Override | ||
public String getFormName() { | ||
return "appointmentCheckInForm"; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabels() { | ||
return new String[] { "Date:", "Location:", "Provider:", "Appointments:" }; | ||
} | ||
|
||
@Override | ||
public void setupRequest(MockHttpServletRequest request, Map<String, String> widgets) { | ||
request.setParameter(widgets.get("Date:"), dateAsString(date)); | ||
request.setParameter(widgets.get("Location:"), "2"); | ||
request.setParameter(widgets.get("Provider:"), "502"); | ||
request.setParameter(widgets.get("Appointments:"), "05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
} | ||
|
||
@Override | ||
public boolean doEditEncounter() { | ||
return true; | ||
} | ||
|
||
@Override | ||
public String[] widgetLabelsForEdit() { | ||
return new String[] { "Appointments:" }; | ||
} | ||
|
||
public void setupEditRequest(MockHttpServletRequest request, Map<String, String> widgets) { | ||
// upon edit keep the same checked | ||
request.setParameter(widgets.get("Appointments:"), "05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
} | ||
|
||
@Override | ||
public void testResults(SubmissionResults results) { | ||
results.assertNoErrors(); | ||
results.assertEncounterCreated(); | ||
|
||
// sanity check | ||
Appointment appointment1 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment1.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment1.getFulfillingEncounters().stream().findFirst().get()); | ||
} | ||
|
||
@Override | ||
public void testEditedResults(SubmissionResults results) { | ||
results.assertNoErrors(); | ||
results.assertEncounterCreated(); | ||
|
||
Appointment appointment1 = Context.getService(AppointmentsService.class) | ||
.getAppointmentByUuid("05f2ad92-1cc8-4cec-bf54-9cac0200746d"); | ||
Assert.assertEquals(AppointmentStatus.CheckedIn, appointment1.getStatus()); | ||
Assert.assertEquals(results.getEncounterCreated(), | ||
appointment1.getFulfillingEncounters().stream().findFirst().get()); | ||
} | ||
}.run(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.