Merge branch 'master' of github.com:jamesagnew/hapi-fhir
This commit is contained in:
commit
9dbeee3576
|
@ -0,0 +1,65 @@
|
|||
package ca.uhn.fhir.validation;
|
||||
|
||||
import ca.uhn.fhir.context.FhirContext;
|
||||
import ca.uhn.fhir.model.dstu2.resource.Appointment;
|
||||
import ca.uhn.fhir.model.dstu2.resource.Bundle;
|
||||
import ca.uhn.fhir.model.dstu2.resource.Patient;
|
||||
import ca.uhn.fhir.model.dstu2.valueset.AppointmentStatusEnum;
|
||||
import ca.uhn.fhir.model.dstu2.valueset.BundleTypeEnum;
|
||||
import ca.uhn.fhir.model.dstu2.valueset.ParticipantTypeEnum;
|
||||
import ca.uhn.fhir.model.dstu2.valueset.ParticipationStatusEnum;
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
|
||||
/**
|
||||
* @author Bill de Beaubien on 11/30/2015.
|
||||
*/
|
||||
public class BundleValidationTest {
|
||||
private static FhirContext ourCtx = FhirContext.forDstu2();
|
||||
|
||||
@Test
|
||||
public void testAppointmentIsInvalid() throws Exception {
|
||||
Appointment appointment = createAppointment();
|
||||
|
||||
FhirValidator validator = ourCtx.newValidator();
|
||||
validator.setValidateAgainstStandardSchema(true);
|
||||
validator.setValidateAgainstStandardSchematron(true);
|
||||
|
||||
ValidationResult result = validator.validateWithResult(appointment);
|
||||
assertFalse(result.isSuccessful());
|
||||
assertEquals(1, result.getMessages().size());
|
||||
for (SingleValidationMessage singleValidationMessage : result.getMessages()) {
|
||||
System.out.println(singleValidationMessage.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@Ignore
|
||||
@Test
|
||||
public void testBundleIsInvalid() throws Exception {
|
||||
Appointment appointment = createAppointment();
|
||||
Bundle bundle = new Bundle().setType(BundleTypeEnum.TRANSACTION);
|
||||
Bundle.Entry entry = new Bundle.Entry();
|
||||
entry.setResource(appointment).setFullUrl("urn:uuid:1");
|
||||
bundle.addEntry(entry);
|
||||
|
||||
FhirValidator validator = ourCtx.newValidator();
|
||||
validator.setValidateAgainstStandardSchema(true);
|
||||
validator.setValidateAgainstStandardSchematron(true);
|
||||
|
||||
ValidationResult result = validator.validateWithResult(bundle);
|
||||
assertFalse("Validation should have failed", result.isSuccessful());
|
||||
assertEquals(1, result.getMessages().size());
|
||||
for (SingleValidationMessage singleValidationMessage : result.getMessages()) {
|
||||
System.out.println(singleValidationMessage.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
private Appointment createAppointment() {
|
||||
Appointment.Participant participant = new Appointment.Participant().setStatus(ParticipationStatusEnum.ACCEPTED).setType(ParticipantTypeEnum.PART);
|
||||
return new Appointment().setStatus(AppointmentStatusEnum.BOOKED).addParticipant(participant);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue