Fix unnecessary switch. Refactor tests.
This commit is contained in:
parent
9e6700d9a9
commit
fce80bb9b1
|
@ -15,8 +15,12 @@ import org.hl7.fhir.exceptions.FHIRException;
|
||||||
import org.hl7.fhir.r4.model.Extension;
|
import org.hl7.fhir.r4.model.Extension;
|
||||||
import org.hl7.fhir.r4.model.Immunization;
|
import org.hl7.fhir.r4.model.Immunization;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public class Immunization30_40 {
|
public class Immunization30_40 {
|
||||||
|
|
||||||
|
public static final String NOT_GIVEN_EXTENSION_URL = "http://hl7.org/fhir/3.0/StructureDefinition/extension-Immunization.notGiven";
|
||||||
|
|
||||||
public static org.hl7.fhir.r4.model.Immunization convertImmunization(org.hl7.fhir.dstu3.model.Immunization src) throws FHIRException {
|
public static org.hl7.fhir.r4.model.Immunization convertImmunization(org.hl7.fhir.dstu3.model.Immunization src) throws FHIRException {
|
||||||
if (src == null)
|
if (src == null)
|
||||||
return null;
|
return null;
|
||||||
|
@ -68,7 +72,7 @@ public class Immunization30_40 {
|
||||||
|
|
||||||
public static org.hl7.fhir.r4.model.Extension getExtensionForNotGiven(boolean notGiven) {
|
public static org.hl7.fhir.r4.model.Extension getExtensionForNotGiven(boolean notGiven) {
|
||||||
org.hl7.fhir.r4.model.Extension extension = new org.hl7.fhir.r4.model.Extension();
|
org.hl7.fhir.r4.model.Extension extension = new org.hl7.fhir.r4.model.Extension();
|
||||||
extension.setUrl("http://hl7.org/fhir/3.0/StructureDefinition/extension-Immunization.notGiven");
|
extension.setUrl(NOT_GIVEN_EXTENSION_URL);
|
||||||
extension.setValue(new org.hl7.fhir.r4.model.BooleanType(notGiven));
|
extension.setValue(new org.hl7.fhir.r4.model.BooleanType(notGiven));
|
||||||
return extension;
|
return extension;
|
||||||
}
|
}
|
||||||
|
@ -82,10 +86,13 @@ public class Immunization30_40 {
|
||||||
tgt.addIdentifier(Identifier30_40.convertIdentifier(t));
|
tgt.addIdentifier(Identifier30_40.convertIdentifier(t));
|
||||||
if (src.hasStatus()) {
|
if (src.hasStatus()) {
|
||||||
tgt.setStatusElement(convertImmunizationStatus(src.getStatusElement()));
|
tgt.setStatusElement(convertImmunizationStatus(src.getStatusElement()));
|
||||||
switch (src.getStatusElement().getValue()) {
|
if (src.getStatusElement().getValue() == Immunization.ImmunizationStatus.NOTDONE)
|
||||||
case NOTDONE: tgt.setNotGivenElement(new BooleanType(true));
|
tgt.setNotGivenElement(new BooleanType(true));
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
if (src.hasExtension(NOT_GIVEN_EXTENSION_URL)) {
|
||||||
|
Extension notGivenExtension = src.getExtensionByUrl(NOT_GIVEN_EXTENSION_URL);
|
||||||
|
if (notGivenExtension.hasValue() && notGivenExtension.getValueAsPrimitive() instanceof org.hl7.fhir.r4.model.BooleanType)
|
||||||
|
tgt.setNotGivenElement(new org.hl7.fhir.dstu3.model.BooleanType());
|
||||||
}
|
}
|
||||||
if (src.hasVaccineCode())
|
if (src.hasVaccineCode())
|
||||||
tgt.setVaccineCode(CodeableConcept30_40.convertCodeableConcept(src.getVaccineCode()));
|
tgt.setVaccineCode(CodeableConcept30_40.convertCodeableConcept(src.getVaccineCode()));
|
||||||
|
@ -154,8 +161,6 @@ public class Immunization30_40 {
|
||||||
ConversionContext30_40.INSTANCE.getVersionConvertor_30_40().copyElement(src, tgt);
|
ConversionContext30_40.INSTANCE.getVersionConvertor_30_40().copyElement(src, tgt);
|
||||||
switch (src.getValue()) {
|
switch (src.getValue()) {
|
||||||
case COMPLETED:
|
case COMPLETED:
|
||||||
tgt.setValue(org.hl7.fhir.dstu3.model.Immunization.ImmunizationStatus.COMPLETED);
|
|
||||||
break;
|
|
||||||
case NOTDONE:
|
case NOTDONE:
|
||||||
tgt.setValue(org.hl7.fhir.dstu3.model.Immunization.ImmunizationStatus.COMPLETED);
|
tgt.setValue(org.hl7.fhir.dstu3.model.Immunization.ImmunizationStatus.COMPLETED);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -2,45 +2,67 @@ package org.hl7.fhir.convertors.conv30_40;
|
||||||
|
|
||||||
import org.hl7.fhir.convertors.advisors.impl.BaseAdvisor_30_40;
|
import org.hl7.fhir.convertors.advisors.impl.BaseAdvisor_30_40;
|
||||||
import org.hl7.fhir.convertors.factory.VersionConvertorFactory_30_40;
|
import org.hl7.fhir.convertors.factory.VersionConvertorFactory_30_40;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Assertions;
|
import org.junit.jupiter.api.Assertions;
|
||||||
import org.junit.jupiter.api.DisplayName;
|
import org.junit.jupiter.api.DisplayName;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
|
import org.junit.jupiter.params.provider.Arguments;
|
||||||
|
import org.junit.jupiter.params.provider.MethodSource;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
public class Immunization30_40Test {
|
public class Immunization30_40Test {
|
||||||
|
|
||||||
@Test
|
private org.hl7.fhir.r4.formats.JsonParser r4_parser = new org.hl7.fhir.r4.formats.JsonParser();
|
||||||
@DisplayName("Test r4 -> dstu3 immunization conversion.")
|
private org.hl7.fhir.dstu3.formats.JsonParser dstu3_parser = new org.hl7.fhir.dstu3.formats.JsonParser();
|
||||||
public void test1() throws IOException {
|
|
||||||
InputStream r4_input = this.getClass().getResourceAsStream("/immunization_40.json");
|
|
||||||
InputStream dstu3_expected_output = this.getClass().getResourceAsStream("/immunization_30.json");
|
|
||||||
|
|
||||||
org.hl7.fhir.r4.model.Immunization r4_actual = (org.hl7.fhir.r4.model.Immunization) new org.hl7.fhir.r4.formats.JsonParser().parse(r4_input);
|
public static Stream<Arguments> getR4toDSTU3Arguments() {
|
||||||
|
return Stream.of(
|
||||||
|
Arguments.of("test1", "/immunization_40-not-done.json", "/immunization_30_completed_notGiven.json")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
@ParameterizedTest(name = "Test r4 -> dstu3 immunization conversions {0}")
|
||||||
|
@MethodSource("getR4toDSTU3Arguments")
|
||||||
|
public void test1(String testName, String r4_input_resource, String dstu3_expected_output_resource) throws IOException {
|
||||||
|
InputStream r4_input = this.getClass().getResourceAsStream(r4_input_resource);
|
||||||
|
InputStream dstu3_expected_output = this.getClass().getResourceAsStream(dstu3_expected_output_resource);
|
||||||
|
|
||||||
|
org.hl7.fhir.r4.model.Immunization r4_actual = (org.hl7.fhir.r4.model.Immunization) r4_parser.parse(r4_input);
|
||||||
org.hl7.fhir.dstu3.model.Resource dstu3_conv = VersionConvertorFactory_30_40.convertResource(r4_actual, new BaseAdvisor_30_40(false));
|
org.hl7.fhir.dstu3.model.Resource dstu3_conv = VersionConvertorFactory_30_40.convertResource(r4_actual, new BaseAdvisor_30_40(false));
|
||||||
|
|
||||||
org.hl7.fhir.dstu3.formats.JsonParser dstu3_parser = new org.hl7.fhir.dstu3.formats.JsonParser();
|
|
||||||
org.hl7.fhir.dstu3.model.Resource dstu3_expected = dstu3_parser.parse(dstu3_expected_output);
|
org.hl7.fhir.dstu3.model.Resource dstu3_expected = dstu3_parser.parse(dstu3_expected_output);
|
||||||
|
|
||||||
Assertions.assertTrue(dstu3_expected.equalsDeep(dstu3_conv),
|
Assertions.assertTrue(dstu3_expected.equalsDeep(dstu3_conv),
|
||||||
"Failed comparing\n" + dstu3_parser.composeString(dstu3_expected) + "\nand\n" + dstu3_parser.composeString(dstu3_conv));
|
"Failed comparing\n" + dstu3_parser.composeString(dstu3_expected) + "\nand\n" + dstu3_parser.composeString(dstu3_conv));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
public static Stream<Arguments> getDSTU3toR4Arguments() {
|
||||||
@DisplayName("Test dstu3 -> r4 immunization conversion.")
|
return Stream.of(
|
||||||
public void test2() throws IOException {
|
Arguments.of("test1", "/immunization_30_completed_notGiven.json", "/immunization_40-not-done-notGiven.json")
|
||||||
InputStream dstu3_input = this.getClass().getResourceAsStream("/immunization_30.json");
|
);
|
||||||
InputStream r4_expected_output = this.getClass().getResourceAsStream("/immunization_40-converted.json");
|
}
|
||||||
|
|
||||||
org.hl7.fhir.dstu3.model.Immunization dstu3_actual = (org.hl7.fhir.dstu3.model.Immunization) new org.hl7.fhir.dstu3.formats.JsonParser().parse(dstu3_input);
|
@ParameterizedTest(name = "Test dstu3 -> r4 immunization conversions {0}")
|
||||||
|
@MethodSource("getDSTU3toR4Arguments")
|
||||||
|
public void test2(String testName, String dstu3_input_resource, String r4_expected_output_resource) throws IOException {
|
||||||
|
InputStream dstu3_input = this.getClass().getResourceAsStream(dstu3_input_resource);
|
||||||
|
|
||||||
|
org.hl7.fhir.dstu3.model.Immunization dstu3_actual = (org.hl7.fhir.dstu3.model.Immunization) dstu3_parser.parse(dstu3_input);
|
||||||
org.hl7.fhir.r4.model.Resource r4_conv = VersionConvertorFactory_30_40.convertResource(dstu3_actual, new BaseAdvisor_30_40(false));
|
org.hl7.fhir.r4.model.Resource r4_conv = VersionConvertorFactory_30_40.convertResource(dstu3_actual, new BaseAdvisor_30_40(false));
|
||||||
|
|
||||||
org.hl7.fhir.r4.formats.JsonParser r4_parser = new org.hl7.fhir.r4.formats.JsonParser();
|
InputStream r4_expected_output = this.getClass().getResourceAsStream(r4_expected_output_resource);
|
||||||
org.hl7.fhir.r4.model.Resource r4_expected = r4_parser.parse(r4_expected_output);
|
org.hl7.fhir.r4.model.Resource r4_expected = r4_parser.parse(r4_expected_output);
|
||||||
|
|
||||||
Assertions.assertTrue(r4_expected.equalsDeep(r4_conv),
|
Assertions.assertTrue(r4_expected.equalsDeep(r4_conv),
|
||||||
"Failed comparing\n" + r4_parser.composeString(r4_expected) + "\nand\n" + r4_parser.composeString(r4_conv));
|
"Failed comparing\n" + r4_parser.composeString(r4_expected) + "\nand\n" + r4_parser.composeString(r4_conv));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("")
|
||||||
|
public void test3() throws IOException {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
{
|
||||||
|
"resourceType": "Immunization",
|
||||||
|
"id": "notGiven",
|
||||||
|
"text": {
|
||||||
|
"status": "generated",
|
||||||
|
"div": "<div xmlns=\"http://www.w3.org/1999/xhtml\">dummyDiv</div>"
|
||||||
|
},
|
||||||
|
"extension":[
|
||||||
|
{
|
||||||
|
"url":"http://hl7.org/fhir/3.0/StructureDefinition/extension-Immunization.notGiven",
|
||||||
|
"valueBoolean":true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"status": "completed",
|
||||||
|
"vaccineCode": {
|
||||||
|
"coding": [
|
||||||
|
{
|
||||||
|
"system": "http://hl7.org/fhir/sid/cvx",
|
||||||
|
"code": "01",
|
||||||
|
"display": "DTP"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"patient": {
|
||||||
|
"reference": "Patient/example"
|
||||||
|
},
|
||||||
|
"occurrenceDateTime": "2013-01-10",
|
||||||
|
"primarySource": true
|
||||||
|
}
|
Loading…
Reference in New Issue