Merge pull request #1851 from hapifhir/ValueSetInterversionFix

Value set interversion fix
This commit is contained in:
Grahame Grieve 2024-12-09 07:50:18 +04:00 committed by GitHub
commit 0d6f658a22
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 251 additions and 6 deletions

View File

@ -466,9 +466,9 @@ public class ValueSet40_50 {
for (org.hl7.fhir.r4.model.Extension t : src.getExtension()) { for (org.hl7.fhir.r4.model.Extension t : src.getExtension()) {
if ("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property".equals(t.getUrl())) { if ("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property".equals(t.getUrl())) {
ConceptPropertyComponent prop = tgt.addProperty(); ConceptPropertyComponent prop = tgt.addProperty();
ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().copyElement(t, prop, "code", "value"); ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().copyElement(t, prop, "code", "value[x]");
prop.setCode(t.getExtensionString("code")); prop.setCode(t.getExtensionString("code"));
prop.setValue(ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().convertType(t.getExtensionByUrl("value").getValue())); prop.setValue(ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().convertType(t.getExtensionByUrl("value[x]").getValue()));
} }
} }
@ -498,9 +498,9 @@ public class ValueSet40_50 {
tgt.addDesignation(convertConceptReferenceDesignationComponent(t)); tgt.addDesignation(convertConceptReferenceDesignationComponent(t));
for (org.hl7.fhir.r5.model.ValueSet.ConceptPropertyComponent t : src.getProperty()) { for (org.hl7.fhir.r5.model.ValueSet.ConceptPropertyComponent t : src.getProperty()) {
org.hl7.fhir.r4.model.Extension ext = tgt.addExtension().setUrl("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property"); org.hl7.fhir.r4.model.Extension ext = tgt.addExtension().setUrl("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property");
ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().copyElement(t, ext, "code", "value"); ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().copyElement(t, ext, "code", "value[x]");
ext.addExtension().setUrl("code").setValue(ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().convertType(t.getCodeElement())); ext.addExtension().setUrl("code").setValue(ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().convertType(t.getCodeElement()));
ext.addExtension().setUrl("value").setValue(ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().convertType(t.getValue())); ext.addExtension().setUrl("value[x]").setValue(ConversionContext40_50.INSTANCE.getVersionConvertor_40_50().convertType(t.getValue()));
} }
for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains()) for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains())
tgt.addContains(convertValueSetExpansionContainsComponent(t)); tgt.addContains(convertValueSetExpansionContainsComponent(t));

View File

@ -1,5 +1,6 @@
package org.hl7.fhir.convertors.conv43_50.resources43_50; package org.hl7.fhir.convertors.conv43_50.resources43_50;
import org.hl7.fhir.convertors.context.ConversionContext40_50;
import org.hl7.fhir.convertors.context.ConversionContext43_50; import org.hl7.fhir.convertors.context.ConversionContext43_50;
import org.hl7.fhir.convertors.conv43_50.datatypes43_50.general43_50.CodeableConcept43_50; import org.hl7.fhir.convertors.conv43_50.datatypes43_50.general43_50.CodeableConcept43_50;
import org.hl7.fhir.convertors.conv43_50.datatypes43_50.general43_50.Coding43_50; import org.hl7.fhir.convertors.conv43_50.datatypes43_50.general43_50.Coding43_50;
@ -16,6 +17,7 @@ import org.hl7.fhir.convertors.conv43_50.datatypes43_50.primitive43_50.MarkDown4
import org.hl7.fhir.convertors.conv43_50.datatypes43_50.primitive43_50.String43_50; import org.hl7.fhir.convertors.conv43_50.datatypes43_50.primitive43_50.String43_50;
import org.hl7.fhir.convertors.conv43_50.datatypes43_50.primitive43_50.Uri43_50; import org.hl7.fhir.convertors.conv43_50.datatypes43_50.primitive43_50.Uri43_50;
import org.hl7.fhir.exceptions.FHIRException; import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.r5.model.ValueSet;
/* /*
Copyright (c) 2011+, HL7, Inc. Copyright (c) 2011+, HL7, Inc.
@ -372,7 +374,7 @@ public class ValueSet43_50 {
if (src == null) if (src == null)
return null; return null;
org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionComponent tgt = new org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionComponent(); org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionComponent tgt = new org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionComponent();
ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().copyBackboneElement(src, tgt); ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().copyBackboneElement(src, tgt, "http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.property");
if (src.hasIdentifier()) if (src.hasIdentifier())
tgt.setIdentifierElement(Uri43_50.convertUri(src.getIdentifierElement())); tgt.setIdentifierElement(Uri43_50.convertUri(src.getIdentifierElement()));
if (src.hasTimestamp()) if (src.hasTimestamp())
@ -383,6 +385,11 @@ public class ValueSet43_50 {
tgt.setOffsetElement(Integer43_50.convertInteger(src.getOffsetElement())); tgt.setOffsetElement(Integer43_50.convertInteger(src.getOffsetElement()));
for (org.hl7.fhir.r4b.model.ValueSet.ValueSetExpansionParameterComponent t : src.getParameter()) for (org.hl7.fhir.r4b.model.ValueSet.ValueSetExpansionParameterComponent t : src.getParameter())
tgt.addParameter(convertValueSetExpansionParameterComponent(t)); tgt.addParameter(convertValueSetExpansionParameterComponent(t));
for (org.hl7.fhir.r4b.model.Extension t : src.getExtension()) {
if ("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.property".equals(t.getUrl())) {
tgt.addProperty().setCode(t.getExtensionString("code")).setUri(t.getExtensionString("uri"));
}
}
for (org.hl7.fhir.r4b.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains()) for (org.hl7.fhir.r4b.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains())
tgt.addContains(convertValueSetExpansionContainsComponent(t)); tgt.addContains(convertValueSetExpansionContainsComponent(t));
return tgt; return tgt;
@ -403,6 +410,11 @@ public class ValueSet43_50 {
tgt.setOffsetElement(Integer43_50.convertInteger(src.getOffsetElement())); tgt.setOffsetElement(Integer43_50.convertInteger(src.getOffsetElement()));
for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionParameterComponent t : src.getParameter()) for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionParameterComponent t : src.getParameter())
tgt.addParameter(convertValueSetExpansionParameterComponent(t)); tgt.addParameter(convertValueSetExpansionParameterComponent(t));
for (ValueSet.ValueSetExpansionPropertyComponent t : src.getProperty()) {
org.hl7.fhir.r4b.model.Extension ext = tgt.addExtension().setUrl("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.property");
ext.addExtension().setUrl("code").setValue(ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().convertType(t.getCodeElement()));
ext.addExtension().setUrl("uri").setValue(ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().convertType(t.getUriElement()));
}
for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains()) for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains())
tgt.addContains(convertValueSetExpansionContainsComponent(t)); tgt.addContains(convertValueSetExpansionContainsComponent(t));
return tgt; return tgt;
@ -451,6 +463,15 @@ public class ValueSet43_50 {
tgt.setDisplayElement(String43_50.convertString(src.getDisplayElement())); tgt.setDisplayElement(String43_50.convertString(src.getDisplayElement()));
for (org.hl7.fhir.r4b.model.ValueSet.ConceptReferenceDesignationComponent t : src.getDesignation()) for (org.hl7.fhir.r4b.model.ValueSet.ConceptReferenceDesignationComponent t : src.getDesignation())
tgt.addDesignation(convertConceptReferenceDesignationComponent(t)); tgt.addDesignation(convertConceptReferenceDesignationComponent(t));
for (org.hl7.fhir.r4b.model.Extension t : src.getExtension()) {
if ("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property".equals(t.getUrl())) {
ValueSet.ConceptPropertyComponent prop = tgt.addProperty();
ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().copyElement(t, prop, "code", "value[x]");
prop.setCode(t.getExtensionString("code"));
prop.setValue(ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().convertType(t.getExtensionByUrl("value[x]").getValue()));
}
}
for (org.hl7.fhir.r4b.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains()) for (org.hl7.fhir.r4b.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains())
tgt.addContains(convertValueSetExpansionContainsComponent(t)); tgt.addContains(convertValueSetExpansionContainsComponent(t));
return tgt; return tgt;
@ -475,6 +496,12 @@ public class ValueSet43_50 {
tgt.setDisplayElement(String43_50.convertString(src.getDisplayElement())); tgt.setDisplayElement(String43_50.convertString(src.getDisplayElement()));
for (org.hl7.fhir.r5.model.ValueSet.ConceptReferenceDesignationComponent t : src.getDesignation()) for (org.hl7.fhir.r5.model.ValueSet.ConceptReferenceDesignationComponent t : src.getDesignation())
tgt.addDesignation(convertConceptReferenceDesignationComponent(t)); tgt.addDesignation(convertConceptReferenceDesignationComponent(t));
for (org.hl7.fhir.r5.model.ValueSet.ConceptPropertyComponent t : src.getProperty()) {
org.hl7.fhir.r4b.model.Extension ext = tgt.addExtension().setUrl("http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property");
ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().copyElement(t, ext, "code", "value[x]");
ext.addExtension().setUrl("code").setValue(ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().convertType(t.getCodeElement()));
ext.addExtension().setUrl("value[x]").setValue(ConversionContext43_50.INSTANCE.getVersionConvertor_43_50().convertType(t.getValue()));
}
for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains()) for (org.hl7.fhir.r5.model.ValueSet.ValueSetExpansionContainsComponent t : src.getContains())
tgt.addContains(convertValueSetExpansionContainsComponent(t)); tgt.addContains(convertValueSetExpansionContainsComponent(t));
return tgt; return tgt;

View File

@ -13,7 +13,7 @@ public class TestScript40_50Test {
@Test @Test
@DisplayName("Test TestScript R4 <-> R5 with resoutce scope extension") @DisplayName("Test TestScript R4 <-> R5 with resource scope extension")
public void testValueExpressionConversion40_10() throws IOException { public void testValueExpressionConversion40_10() throws IOException {
InputStream r4_stream = this.getClass().getResourceAsStream("/test_script_r4.json"); InputStream r4_stream = this.getClass().getResourceAsStream("/test_script_r4.json");
org.hl7.fhir.r4.model.TestScript r4_input = (org.hl7.fhir.r4.model.TestScript) new org.hl7.fhir.r4.formats.JsonParser().parse(r4_stream); org.hl7.fhir.r4.model.TestScript r4_input = (org.hl7.fhir.r4.model.TestScript) new org.hl7.fhir.r4.formats.JsonParser().parse(r4_stream);

View File

@ -0,0 +1,47 @@
package org.hl7.fhir.convertors.conv40_50;
import org.hl7.fhir.convertors.factory.VersionConvertorFactory_40_50;
import org.hl7.fhir.r5.formats.IParser.OutputStyle;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import java.io.IOException;
import java.io.InputStream;
public class ValueSet40_50Test {
@Test
@DisplayName("Test ValueSet R4 <-> R5 with property extensions")
public void testValueExpressionConversion40_10() throws IOException {
InputStream r4_stream = this.getClass().getResourceAsStream("/value_set_r4.json");
org.hl7.fhir.r4.model.ValueSet r4_input = (org.hl7.fhir.r4.model.ValueSet) new org.hl7.fhir.r4.formats.JsonParser().parse(r4_stream);
InputStream r5_stream = this.getClass().getResourceAsStream("/value_set_r5.json");
org.hl7.fhir.r5.model.ValueSet r5_input = (org.hl7.fhir.r5.model.ValueSet) new org.hl7.fhir.r5.formats.JsonParser().parse(r5_stream);
org.hl7.fhir.r5.model.ValueSet r5_output = (org.hl7.fhir.r5.model.ValueSet) VersionConvertorFactory_40_50.convertResource(r4_input);
org.hl7.fhir.r4.model.ValueSet r4_output = (org.hl7.fhir.r4.model.ValueSet) VersionConvertorFactory_40_50.convertResource(r5_input);
org.hl7.fhir.r5.formats.JsonParser r5_parser = new org.hl7.fhir.r5.formats.JsonParser();
String r5_in = r5_parser.setOutputStyle(OutputStyle.PRETTY).composeString(r5_input);
String r5_out = r5_parser.composeString(r5_output);
boolean pass = r5_input.equalsDeep(r5_output);
if (!pass) {
System.out.println("R5. Expected out ->\n"+ r5_in + "\n\nActual out ->\n" + r5_out);
}
Assertions.assertTrue(pass);
org.hl7.fhir.r4.formats.JsonParser r4_parser = new org.hl7.fhir.r4.formats.JsonParser();
String r4_in = r4_parser.composeString(r4_input);
String r4_out = r4_parser.composeString(r4_output);
pass = r4_input.equalsDeep(r4_output);
if (!pass) {
System.out.println("R4. Expected out ->\n"+ r4_in + "\n\nActual out ->\n" + r4_out);
}
Assertions.assertTrue(pass);
}
}

View File

@ -0,0 +1,103 @@
{
"resourceType" : "ValueSet",
"id" : "VSPHQ9",
"url" : "http://example.org/ValueSet/VSPHQ9",
"name" : "VSPHQ9",
"status" : "active",
"immutable" : true,
"compose" : {
"include" : [{
"system" : "http://example.org/CodeSystem/CSPHQ9",
"concept" : [{
"code" : "Not-at-all",
"display" : "Not at all"
},
{
"code" : "Several-days",
"display" : "Several days"
},
{
"code" : "More than half the days",
"display" : "More than half the days"
},
{
"code" : "Nearly every day",
"display" : "Nearly every day"
}]
}]
},
"expansion" : {
"extension" : [{
"extension" : [{
"url" : "code",
"valueCode" : "itemWeight"
},
{
"url" : "uri",
"valueUri" : "http://hl7.org/fhir/concept-properties#itemWeight"
}],
"url" : "http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.property"
}],
"timestamp" : "2024-12-06T22:52:00-07:00",
"contains" : [{
"extension" : [{
"extension" : [{
"url" : "code",
"valueCode" : "itemWeight"
},
{
"url" : "value[x]",
"valueDecimal" : 0
}],
"url" : "http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property"
}],
"code" : "not-at-all",
"display" : "Not at all"
},
{
"extension" : [{
"extension" : [{
"url" : "code",
"valueCode" : "itemWeight"
},
{
"url" : "value[x]",
"valueDecimal" : 1
}],
"url" : "http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property"
}],
"code" : "Several-days",
"display" : "Several days"
},
{
"extension" : [{
"extension" : [{
"url" : "code",
"valueCode" : "itemWeight"
},
{
"url" : "value[x]",
"valueDecimal" : 2
}],
"url" : "http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property"
}],
"code" : "More than half the days",
"display" : "More than half the days"
},
{
"extension" : [{
"extension" : [{
"url" : "code",
"valueCode" : "itemWeight"
},
{
"url" : "value[x]",
"valueDecimal" : 4
}],
"url" : "http://hl7.org/fhir/5.0/StructureDefinition/extension-ValueSet.expansion.contains.property"
}],
"code" : "Nearly every day",
"display" : "Nearly every day"
}]
}
}

View File

@ -0,0 +1,68 @@
{
"resourceType" : "ValueSet",
"id" : "VSPHQ9",
"url" : "http://example.org/ValueSet/VSPHQ9",
"name" : "VSPHQ9",
"status" : "active",
"immutable" : true,
"compose" : {
"include" : [{
"system" : "http://example.org/CodeSystem/CSPHQ9",
"concept" : [{
"code" : "Not-at-all",
"display" : "Not at all"
},
{
"code" : "Several-days",
"display" : "Several days"
},
{
"code" : "More than half the days",
"display" : "More than half the days"
},
{
"code" : "Nearly every day",
"display" : "Nearly every day"
}]
}]
},
"expansion" : {
"timestamp" : "2024-12-06T22:52:00-07:00",
"property" : [{
"code" : "itemWeight",
"uri" : "http://hl7.org/fhir/concept-properties#itemWeight"
}],
"contains" : [{
"code" : "not-at-all",
"display" : "Not at all",
"property" : [{
"code" : "itemWeight",
"valueDecimal" : 0
}]
},
{
"code" : "Several-days",
"display" : "Several days",
"property" : [{
"code" : "itemWeight",
"valueDecimal" : 1
}]
},
{
"code" : "More than half the days",
"display" : "More than half the days",
"property" : [{
"code" : "itemWeight",
"valueDecimal" : 2
}]
},
{
"code" : "Nearly every day",
"display" : "Nearly every day",
"property" : [{
"code" : "itemWeight",
"valueDecimal" : 4
}]
}]
}
}