AEGIS Touchstone Testing Implementation Guide

This is the Version 1.5.0 Release of the Touchstone Testing Implementation Guide, based on FHIR Version 4.0.1. See the Directory of published versions

Turtle Format: TestScript-patient-read-summary-rule-with-param-json

Raw ttl


@prefix fhir: <http://hl7.org/fhir/> .
@prefix owl: <http://www.w3.org/2002/07/owl#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .

# - resource -------------------------------------------------------------------

 a fhir:TestScript;
  fhir:nodeRole fhir:treeRoot;
  fhir:Resource.id [ fhir:value "patient-read-summary-rule-with-param-json"];
  fhir:Resource.meta [
     fhir:Meta.profile [
       fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript";
       fhir:index 0;
       fhir:link <http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript>     ]
  ];
  fhir:DomainResource.text [
     fhir:Narrative.status [ fhir:value "extensions" ];
     fhir:Narrative.div "<div xmlns=\"http://www.w3.org/1999/xhtml\"><p><b>Generated Narrative</b></p><div style=\"display: inline-block; background-color: #d9e0e7; padding: 6px; margin: 4px; border: 1px solid #8da1b4; border-radius: 5px; line-height: 60%\"><p style=\"margin-bottom: 0px\">Resource \"patient-read-summary-rule-with-param-json\" </p><p style=\"margin-bottom: 0px\">Profile: <a href=\"StructureDefinition-testscript.html\">AEGIS Touchstone Testing TestScript Profile</a></p></div><blockquote><p><b>AEGIS Touchstone Testing TestScript Rule Extension</b></p><p><b>value</b>: RuleContentTypeIfBody</p><p><b>value</b>: /FHIRCommon/_reference/rule/AssertHeaderIfBody.groovy</p></blockquote><p><b>url</b>: <code>http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-with-param-json</code></p><p><b>version</b>: 1.5.0</p><p><b>name</b>: PatientReadSummaryRuleWithParamJson</p><p><b>status</b>: active</p><p><b>date</b>: 2020-05-29</p><p><b>publisher</b>: AEGIS.net, Inc.</p><p><b>contact</b>: Touchstone Support: <a href=\"mailto:Touchstone_Support@aegis.net\">Touchstone_Support@aegis.net</a></p><p><b>description</b>: Demonstrate the use of the AEGIS Touchstone Testing IG rule extensions (no params) with a Patient read. The actual test is a read operation for a Patient in JSON format with the _summary=true parameter where the rule allows a single assert to test for the existence of the Content-Type header if a payload is returned.</p><p><b>jurisdiction</b>: US <span style=\"background: LightGoldenRodYellow; margin: 4px; border: 1px solid khaki\"> (unknown#US)</span></p><p><b>copyright</b>: (c) AEGIS.net, Inc. 2015+</p><p><b>profile</b>: <a href=\"http://hl7.org/fhir/StructureDefinition/Patient\">http://hl7.org/fhir/StructureDefinition/Patient</a> \"Patient\"</p><h3>Variables</h3><table class=\"grid\"><tr><td>-</td><td><b>Name</b></td><td><b>Hint</b></td></tr><tr><td>*</td><td>patientResourceId</td><td>Enter a known Patient resource id</td></tr></table><blockquote><p><b>test</b></p><p><b>name</b>: PatientReadSummaryRuleWithParam</p><p><b>description</b>: Read a known Patient in JSON format. The expected response code is 200 (OK). The expected response payload is the Patient resource with only the allowed summary elements in JSON format.</p><blockquote><p><b>action</b></p><h3>Operations</h3><table class=\"grid\"><tr><td>-</td><td><b>Type</b></td><td><b>Resource</b></td><td><b>Description</b></td><td><b>Accept</b></td><td><b>EncodeRequestUrl</b></td><td><b>Params</b></td></tr><tr><td>*</td><td>Read (Details: http://terminology.hl7.org/CodeSystem/testscript-operation-codes code read = 'Read', stated as 'null')</td><td>Patient</td><td>Read the created Patient. The destination server must support the _summary=true parameter.</td><td>json</td><td>false</td><td>/${patientResourceId}?_summary=true</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table class=\"grid\"><tr><td>-</td><td><b>Extension</b></td><td><b>Description</b></td><td><b>Direction</b></td><td><b>Response</b></td><td><b>WarningOnly</b></td></tr><tr><td>*</td><td></td><td>Confirm that the returned HTTP status is 200(OK).</td><td>response</td><td>okay</td><td>false</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table class=\"grid\"><tr><td>-</td><td><b>Extension</b></td><td><b>Description</b></td><td><b>Direction</b></td><td><b>WarningOnly</b></td></tr><tr><td>*</td><td>, </td><td>Complex rule assertion to evaluate if Content-Type header is present if a payload is returned.</td><td>response</td><td>false</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table class=\"grid\"><tr><td>-</td><td><b>Extension</b></td><td><b>Description</b></td><td><b>Direction</b></td><td><b>Resource</b></td><td><b>WarningOnly</b></td></tr><tr><td>*</td><td></td><td>Confirm that the returned resource type is Patient.</td><td>response</td><td>Patient</td><td>false</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table class=\"grid\"><tr><td>-</td><td><b>Description</b></td><td><b>Direction</b></td><td><b>ValidateProfileId</b></td><td><b>WarningOnly</b></td></tr><tr><td>*</td><td>Validate that the returned resource conforms to the base FHIR Patient profile.</td><td>response</td><td>patient-profile</td><td>false</td></tr></table></blockquote></blockquote></div>"
  ];
  fhir:DomainResource.extension [
     fhir:index 0;
     fhir:Element.extension [
       fhir:index 0;
       fhir:Extension.url [ fhir:value "ruleId" ];
       fhir:Extension.valueId [ fhir:value "RuleContentTypeIfBody" ]     ], [
       fhir:index 1;
       fhir:Extension.url [ fhir:value "path" ];
       fhir:Extension.valueString [ fhir:value "/FHIRCommon/_reference/rule/AssertHeaderIfBody.groovy" ]     ], [
       fhir:index 2;
       fhir:Element.extension [
         fhir:index 0;
         fhir:Extension.url [ fhir:value "name" ];
         fhir:Extension.valueString [ fhir:value "header" ]       ], [
         fhir:index 1;
         fhir:Extension.url [ fhir:value "value" ];
         fhir:Extension.valueString [ fhir:value "Content-Type" ]       ];
       fhir:Extension.url [ fhir:value "param" ]     ], [
       fhir:index 3;
       fhir:Element.extension [
         fhir:index 0;
         fhir:Extension.url [ fhir:value "name" ];
         fhir:Extension.valueString [ fhir:value "headerOperator" ]       ], [
         fhir:index 1;
         fhir:Extension.url [ fhir:value "value" ];
         fhir:Extension.valueString [ fhir:value "notEmpty" ]       ];
       fhir:Extension.url [ fhir:value "param" ]     ], [
       fhir:index 4;
       fhir:Element.extension [
         fhir:index 0;
         fhir:Extension.url [ fhir:value "name" ];
         fhir:Extension.valueString [ fhir:value "bodyOperator" ]       ], [
         fhir:index 1;
         fhir:Extension.url [ fhir:value "value" ];
         fhir:Extension.valueString [ fhir:value "notEmpty" ]       ];
       fhir:Extension.url [ fhir:value "param" ]     ];
     fhir:Extension.url [ fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-rule" ]
  ];
  fhir:TestScript.url [ fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-with-param-json"];
  fhir:TestScript.version [ fhir:value "1.5.0"];
  fhir:TestScript.name [ fhir:value "PatientReadSummaryRuleWithParamJson"];
  fhir:TestScript.status [ fhir:value "active"];
  fhir:TestScript.date [ fhir:value "2020-05-29"^^xsd:date];
  fhir:TestScript.publisher [ fhir:value "AEGIS.net, Inc."];
  fhir:TestScript.contact [
     fhir:index 0;
     fhir:ContactDetail.name [ fhir:value "Touchstone Support" ];
     fhir:ContactDetail.telecom [
       fhir:index 0;
       fhir:ContactPoint.system [ fhir:value "email" ];
       fhir:ContactPoint.value [ fhir:value "Touchstone_Support@aegis.net" ];
       fhir:ContactPoint.use [ fhir:value "work" ]     ]
  ];
  fhir:TestScript.description [ fhir:value "Demonstrate the use of the AEGIS Touchstone Testing IG rule extensions (no params) with a Patient read. The actual test is a read operation for a Patient in JSON format with the _summary=true parameter where the rule allows a single assert to test for the existence of the Content-Type header if a payload is returned."];
  fhir:TestScript.jurisdiction [
     fhir:index 0;
     fhir:CodeableConcept.coding [
       fhir:index 0;
       fhir:Coding.system [ fhir:value "urn:iso:std:iso:3166" ];
       fhir:Coding.code [ fhir:value "US" ]     ]
  ];
  fhir:TestScript.copyright [ fhir:value "(c) AEGIS.net, Inc. 2015+"];
  fhir:TestScript.profile [
     fhir:index 0;
     fhir:link <http://hl7.org/fhir/StructureDefinition/Patient>;
     fhir:Element.id [ fhir:value "patient-profile" ];
     fhir:Reference.reference [ fhir:value "http://hl7.org/fhir/StructureDefinition/Patient" ]
  ];
  fhir:TestScript.variable [
     fhir:index 0;
     fhir:TestScript.variable.name [ fhir:value "patientResourceId" ];
     fhir:TestScript.variable.hint [ fhir:value "Enter a known Patient resource id" ]
  ];
  fhir:TestScript.test [
     fhir:index 0;
     fhir:Element.id [ fhir:value "PatientReadSummaryRuleWithParam" ];
     fhir:TestScript.test.name [ fhir:value "PatientReadSummaryRuleWithParam" ];
     fhir:TestScript.test.description [ fhir:value "Read a known Patient in JSON format. The expected response code is 200 (OK). The expected response payload is the Patient resource with only the allowed summary elements in JSON format." ];
     fhir:TestScript.test.action [
       fhir:index 0;
       fhir:TestScript.test.action.operation [
         fhir:TestScript.setup.action.operation.type [
           fhir:Coding.system [ fhir:value "http://terminology.hl7.org/CodeSystem/testscript-operation-codes" ];
           fhir:Coding.code [ fhir:value "read" ]         ];
         fhir:TestScript.setup.action.operation.resource [ fhir:value "Patient" ];
         fhir:TestScript.setup.action.operation.description [ fhir:value "Read the created Patient. The destination server must support the _summary=true parameter." ];
         fhir:TestScript.setup.action.operation.accept [ fhir:value "json" ];
         fhir:TestScript.setup.action.operation.encodeRequestUrl [ fhir:value "false"^^xsd:boolean ];
         fhir:TestScript.setup.action.operation.params [ fhir:value "/${patientResourceId}?_summary=true" ]       ]     ], [
       fhir:index 1;
       fhir:TestScript.test.action.assert [
         fhir:Element.extension [
           fhir:index 0;
           fhir:Extension.url [ fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail" ];
           fhir:Extension.valueBoolean [ fhir:value "false"^^xsd:boolean ]         ];
         fhir:TestScript.setup.action.assert.description [ fhir:value "Confirm that the returned HTTP status is 200(OK)." ];
         fhir:TestScript.setup.action.assert.direction [ fhir:value "response" ];
         fhir:TestScript.setup.action.assert.response [ fhir:value "okay" ];
         fhir:TestScript.setup.action.assert.warningOnly [ fhir:value "false"^^xsd:boolean ]       ]     ], [
       fhir:index 2;
       fhir:TestScript.test.action.assert [
         fhir:Element.extension [
           fhir:index 0;
           fhir:Element.extension [
             fhir:index 0;
             fhir:Extension.url [ fhir:value "ruleId" ];
             fhir:Extension.valueId [ fhir:value "RuleContentTypeIfBody" ]           ], [
             fhir:index 1;
             fhir:Element.extension [
               fhir:index 0;
               fhir:Extension.url [ fhir:value "name" ];
               fhir:Extension.valueString [ fhir:value "headerOperator" ]             ], [
               fhir:index 1;
               fhir:Extension.url [ fhir:value "value" ];
               fhir:Extension.valueString [ fhir:value "notEmpty" ]             ];
             fhir:Extension.url [ fhir:value "param" ]           ];
           fhir:Extension.url [ fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-rule" ]         ], [
           fhir:index 1;
           fhir:Extension.url [ fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail" ];
           fhir:Extension.valueBoolean [ fhir:value "false"^^xsd:boolean ]         ];
         fhir:TestScript.setup.action.assert.description [ fhir:value "Complex rule assertion to evaluate if Content-Type header is present if a payload is returned." ];
         fhir:TestScript.setup.action.assert.direction [ fhir:value "response" ];
         fhir:TestScript.setup.action.assert.warningOnly [ fhir:value "false"^^xsd:boolean ]       ]     ], [
       fhir:index 3;
       fhir:TestScript.test.action.assert [
         fhir:Element.extension [
           fhir:index 0;
           fhir:Extension.url [ fhir:value "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail" ];
           fhir:Extension.valueBoolean [ fhir:value "true"^^xsd:boolean ]         ];
         fhir:TestScript.setup.action.assert.description [ fhir:value "Confirm that the returned resource type is Patient." ];
         fhir:TestScript.setup.action.assert.direction [ fhir:value "response" ];
         fhir:TestScript.setup.action.assert.resource [ fhir:value "Patient" ];
         fhir:TestScript.setup.action.assert.warningOnly [ fhir:value "false"^^xsd:boolean ]       ]     ], [
       fhir:index 4;
       fhir:TestScript.test.action.assert [
         fhir:TestScript.setup.action.assert.description [ fhir:value "Validate that the returned resource conforms to the base FHIR Patient profile." ];
         fhir:TestScript.setup.action.assert.direction [ fhir:value "response" ];
         fhir:TestScript.setup.action.assert.validateProfileId [ fhir:value "patient-profile" ];
         fhir:TestScript.setup.action.assert.warningOnly [ fhir:value "false"^^xsd:boolean ]       ]     ]
  ].

<http://hl7.org/fhir/StructureDefinition/Patient> a fhir:StructureDefinition.

# - ontology header ------------------------------------------------------------

 a owl:Ontology;
  owl:imports fhir:fhir.ttl.