The current test process succeeds incorrectly because of an NPE if the differential ends up including elements that aren't in the snapshot. We need a messaging array defined so that raising the errors doesn't cause an NPE.

This commit is contained in:
Lloyd McKenzie 2019-05-19 16:23:31 -06:00
parent d998bfacec
commit 0e95aa3008
1 changed files with 3 additions and 1 deletions

View File

@ -301,6 +301,7 @@ public class SnapShotGenerationTests {
private final TestScriptTestComponent test;
private final String name;
private SnapShotGenerationTestsContext context;
private List<ValidationMessage> messages;
public SnapShotGenerationTests(String name, TestScriptTestComponent e, SnapShotGenerationTestsContext context) {
this.name = name;
@ -312,6 +313,7 @@ public class SnapShotGenerationTests {
@Test
public void test() throws FHIRException {
try {
messages = new ArrayList<ValidationMessage>();
for (Resource cr : context.tests.getContained()) {
if (cr instanceof StructureDefinition) {
StructureDefinition sd = (StructureDefinition) cr;
@ -344,7 +346,7 @@ public class SnapShotGenerationTests {
StructureDefinition source = (StructureDefinition) context.fetchFixture(op.getSourceId());
StructureDefinition base = getSD(source.getBaseDefinition());
StructureDefinition output = source.copy();
ProfileUtilities pu = new ProfileUtilities(TestingUtilities.context(), null, new TestPKP());
ProfileUtilities pu = new ProfileUtilities(TestingUtilities.context(), messages , new TestPKP());
pu.setIds(source, false);
if ("sort=true".equals(op.getParams())) {
List<String> errors = new ArrayList<String>();