Updates to parser dont encode elements functionality

This commit is contained in:
James Agnew 2019-02-04 16:34:05 -05:00
parent e401ec86e4
commit edb79b8c6a
6 changed files with 120 additions and 20 deletions

View File

@ -30,6 +30,7 @@ import ca.uhn.fhir.util.UrlUtil;
import com.google.common.base.Charsets;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.Validate;
import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import org.hl7.fhir.instance.model.api.*;
@ -908,11 +909,11 @@ public abstract class BaseParser implements IParser {
} else {
if (myDontEncodeElements != null) {
String resourceName = myContext.getResourceDefinition(theResource).getName();
if (myDontEncodeElements.stream().anyMatch(t -> t.startsWithPath(resourceName + ".id"))) {
if (myDontEncodeElements.stream().anyMatch(t -> t.equalsPath(resourceName + ".id"))) {
retVal = false;
} else if (myDontEncodeElements.stream().anyMatch(t -> t.startsWithPath("*.id"))) {
} else if (myDontEncodeElements.stream().anyMatch(t -> t.equalsPath("*.id"))) {
retVal = false;
} else if (theEncodeContext.getResourcePath().size() == 1 && myDontEncodeElements.stream().anyMatch(t -> t.startsWithPath("id"))) {
} else if (theEncodeContext.getResourcePath().size() == 1 && myDontEncodeElements.stream().anyMatch(t -> t.equalsPath("id"))) {
retVal = false;
}
}
@ -924,12 +925,19 @@ public abstract class BaseParser implements IParser {
* Used for DSTU2 only
*/
protected boolean shouldEncodeResourceMeta(IResource theResource) {
return shouldEncodePath(theResource, "meta");
}
/**
* Used for DSTU2 only
*/
protected boolean shouldEncodePath(IResource theResource, String thePath) {
if (myDontEncodeElements != null) {
String resourceName = myContext.getResourceDefinition(theResource).getName();
if (myDontEncodeElements.stream().anyMatch(t -> t.startsWithPath(resourceName + ".meta"))) {
if (myDontEncodeElements.stream().anyMatch(t -> t.equalsPath(resourceName + "." + thePath))) {
return false;
} else if (myDontEncodeElements.stream().anyMatch(t -> t.equalsPath("*."+ thePath))) {
return false;
} else {
return myDontEncodeElements.stream().anyMatch(t -> t.startsWithPath("*.meta"));
}
}
return true;
@ -1207,8 +1215,9 @@ public abstract class BaseParser implements IParser {
return true;
}
public boolean startsWithPath(String thePath) {
return startsWith(new ElementsPath(thePath));
public boolean equalsPath(String thePath) {
ElementsPath parsedPath = new ElementsPath(thePath);
return getPath().equals(parsedPath.getPath());
}
}
@ -1289,6 +1298,24 @@ public abstract class BaseParser implements IParser {
return false;
}
@Override
public boolean equals(Object theO) {
if (this == theO) {
return true;
}
if (theO == null || getClass() != theO.getClass()) {
return false;
}
EncodeContextPathElement that = (EncodeContextPathElement) theO;
return new EqualsBuilder()
.append(myResource, that.myResource)
.append(myName, that.myName)
.isEquals();
}
@Override
public int hashCode() {
return new HashCodeBuilder(17, 37)

View File

@ -649,8 +649,13 @@ public class JsonParser extends BaseParser implements IJsonLikeParser {
if (super.shouldEncodeResourceMeta(resource) && (ElementUtil.isEmpty(versionIdPart, updated, securityLabels, tags, profiles) == false) || !extensionMetadataKeys.isEmpty()) {
beginObject(theEventWriter, "meta");
writeOptionalTagWithTextNode(theEventWriter, "versionId", versionIdPart);
writeOptionalTagWithTextNode(theEventWriter, "lastUpdated", updated);
if (shouldEncodePath(resource, "meta.versionId")) {
writeOptionalTagWithTextNode(theEventWriter, "versionId", versionIdPart);
}
if (shouldEncodePath(resource, "meta.lastUpdated")) {
writeOptionalTagWithTextNode(theEventWriter, "lastUpdated", updated);
}
if (profiles != null && profiles.isEmpty() == false) {
beginArray(theEventWriter, "profile");

View File

@ -526,9 +526,13 @@ public class XmlParser extends BaseParser /* implements IParser */ {
if (super.shouldEncodeResourceMeta(resource) && ElementUtil.isEmpty(versionIdPart, updated, securityLabels, tags, profiles) == false) {
theEventWriter.writeStartElement("meta");
writeOptionalTagWithValue(theEventWriter, "versionId", versionIdPart);
if (shouldEncodePath(resource, "meta.versionId")) {
writeOptionalTagWithValue(theEventWriter, "versionId", versionIdPart);
}
if (updated != null) {
writeOptionalTagWithValue(theEventWriter, "lastUpdated", updated.getValueAsString());
if (shouldEncodePath(resource, "meta.lastUpdated")) {
writeOptionalTagWithValue(theEventWriter, "lastUpdated", updated.getValueAsString());
}
}
for (IIdType profile : profiles) {

View File

@ -38,6 +38,7 @@ import static org.hamcrest.CoreMatchers.equalTo;
import static org.hamcrest.Matchers.contains;
import static org.hamcrest.Matchers.*;
import static org.hamcrest.core.IsInstanceOf.instanceOf;
import static org.hamcrest.core.IsNot.not;
import static org.junit.Assert.*;
import static org.mockito.Mockito.*;
@ -72,6 +73,29 @@ public class JsonParserDstu2Test {
}
@Test
public void testSetDontEncodeResourcesWithMetaSubPath() {
Patient p = new Patient();
ResourceMetadataKeyEnum.VERSION.put(p, "BBB");
p.setId("AAA");
p.getMeta().setVersionId("BBB");
p.getMeta().setLastUpdated(new InstantDt("2011-01-01T00:00:00.000Z").getValue());
p.getMeta().addTag().setSystem("SYS").setCode("CODE");
p.addName().addFamily("FAMILY");
IParser parser = ourCtx.newJsonParser();
parser.setDontEncodeElements(Sets.newHashSet("id", "*.meta.versionId", "*.meta.lastUpdated"));
String output = parser.encodeResourceToString(p);
assertThat(output, containsString("FAMILY"));
assertThat(output, containsString("SYS"));
assertThat(output, containsString("CODE"));
assertThat(output, not(containsString("AAA")));
assertThat(output, not(containsString("BBB")));
assertThat(output, not(containsString("2011")));
}
@Test
public void testBaseUrlFooResourceCorrectlySerializedInExtensionValueReference() {
String refVal = "http://my.org/FooBar";

View File

@ -1,6 +1,7 @@
package ca.uhn.fhir.parser;
import static org.hamcrest.Matchers.*;
import static org.hamcrest.core.IsNot.not;
import static org.junit.Assert.*;
import static org.mockito.Matchers.any;
import static org.mockito.Mockito.*;
@ -189,6 +190,29 @@ public class XmlParserDstu2Test {
parser.parseResource(ca.uhn.fhir.model.dstu2.resource.Bundle.class, string);
}
@Test
public void testSetDontEncodeResourcesWithMetaSubPath() {
Patient p = new Patient();
ResourceMetadataKeyEnum.VERSION.put(p, "BBB");
p.setId("AAA");
p.getMeta().setVersionId("BBB");
p.getMeta().setLastUpdated(new InstantDt("2011-01-01T00:00:00.000Z").getValue());
p.getMeta().addTag().setSystem("SYS").setCode("CODE");
p.addName().addFamily("FAMILY");
IParser parser = ourCtx.newXmlParser();
parser.setDontEncodeElements(Sets.newHashSet("id", "*.meta.versionId", "*.meta.lastUpdated"));
String output = parser.encodeResourceToString(p);
assertThat(output, containsString("FAMILY"));
assertThat(output, containsString("SYS"));
assertThat(output, containsString("CODE"));
assertThat(output, not(containsString("AAA")));
assertThat(output, not(containsString("BBB")));
assertThat(output, not(containsString("2011")));
}
@Test()
public void testContainedResourceWithNoIdLenient() throws IOException {
String string = IOUtils.toString(getClass().getResourceAsStream("/bundle_with_contained_with_no_id.xml"), StandardCharsets.UTF_8);

View File

@ -8,14 +8,7 @@ import ca.uhn.fhir.parser.IParser;
import com.google.common.collect.Sets;
import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils;
import org.hl7.fhir.r4.model.Bundle;
import org.hl7.fhir.r4.model.Extension;
import org.hl7.fhir.r4.model.Medication;
import org.hl7.fhir.r4.model.MedicationDispense;
import org.hl7.fhir.r4.model.MedicationRequest;
import org.hl7.fhir.r4.model.Patient;
import org.hl7.fhir.r4.model.Reference;
import org.hl7.fhir.r4.model.StringType;
import org.hl7.fhir.r4.model.*;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.ops4j.pax.exam.Configuration;
@ -32,6 +25,7 @@ import static org.hamcrest.core.IsNot.not;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertThat;
import static org.mockito.ArgumentMatchers.contains;
import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
import static org.ops4j.pax.exam.CoreOptions.options;
import static org.ops4j.pax.exam.CoreOptions.when;
@ -166,6 +160,28 @@ public class R4JsonParserTest {
assertThat(encoded, containsString(longString));
}
@Test
public void testSetDontEncodeResourcesWithMetaSubPath() {
Patient p = new Patient();
p.setId("AAA");
p.getMeta().setVersionId("BBB");
p.getMeta().setLastUpdatedElement(new InstantType("2011-01-01T00:00:00.000Z"));
p.getMeta().addTag().setSystem("SYS").setCode("CODE");
p.addName().setFamily("FAMILY");
IParser parser = ourCtx.newJsonParser();
parser.setDontEncodeElements(Sets.newHashSet("id", "*.meta.versionId", "*.meta.lastUpdated"));
String output = parser.encodeResourceToString(p);
assertThat(output, containsString("FAMILY"));
assertThat(output, containsString("SYS"));
assertThat(output, containsString("CODE"));
assertThat(output, not(containsString("AAA")));
assertThat(output, not(containsString("BBB")));
assertThat(output, not(containsString("2011")));
}
@Test
public void testParseAndEncodeExtensionWithValueWithExtension() {
String input = "{\n" +