AEGIS Touchstone Testing Implementation Guide

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

XML Format: TestScript-patient-read-notfound-ruleset-with-param-json

Raw xml



<TestScript xmlns="http://hl7.org/fhir">
  <id value="patient-read-notfound-ruleset-with-param-json"/>
  <meta>
    <profile
             value="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript"/>
  </meta>
  <text>
    <status value="extensions"/>
    <div xmlns="http://www.w3.org/1999/xhtml"><p><b>Generated Narrative</b></p><h3>Ids</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><h3>Meta</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><blockquote><p><b>AEGIS Touchstone Testing TestScript Ruleset Extension</b></p><h3>Urls</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><p><b>value</b>: RulesetPatientNotFound</p><h3>Urls</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><p><b>value</b>: ../_reference/ruleset/RuleSet-NotFound-Groovy.xml</p><h3>Urls</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><h3>Urls</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><h3>Urls</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><h3>Urls</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><p><b>url</b>: <a href="http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-notfound-ruleset-with-param-json">http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-notfound-ruleset-with-param-json</a></p><p><b>version</b>: 1.1.0</p><p><b>name</b>: PatientReadNotFoundRulesetWithParamJson</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 a ruleset with a Patient read. The actual test is a read operation for a Patient in JSON format where the patient is not found and a ruleset is used to conditionally check the system under test to either skip or apply checks for HTTP response headers the payload content.</p><p><b>jurisdiction</b>: <span title="Codes: {urn:iso:std:iso:3166 US}">United States of America</span></p><p><b>copyright</b>: (c) AEGIS.net, Inc. 2015+</p><p><b>profile</b>: <a href="http://hl7.org/fhir/StructureDefinition/Patient">Generated Summary: url: http://hl7.org/fhir/StructureDefinition/Patient; version: 4.0.1; name: Patient; ACTIVE; date: Oct 31, 2019 6:29:23 PM; publisher: Health Level Seven International (Patient Administration); http://hl7.org/fhir, http://www.hl7.org/Special/com...; description: Demographics and other administrative information about an individual or animal receiving care or other health-related services.; purpose: Tracking patient is the center of the healthcare process.; 4.0.1; RESOURCE; type: Patient; baseDefinition: http://hl7.org/fhir/StructureDefinition/DomainResource; SPECIALIZATION</a></p><h3>Variables</h3><table class="grid"><tr><td>-</td><td><b>Name</b></td><td><b>Description</b></td><td><b>Hint</b></td></tr><tr><td>*</td><td>NotFoundPatientResourceId</td><td>Enter a Patient resource id that does not exist on the destination system.</td><td>[Not Found Resource Id]</td></tr></table><blockquote><p><b>test</b></p><h3>Ids</h3><table class="grid"><tr><td>-</td></tr><tr><td>*</td></tr></table><p><b>name</b>: ReadNotFoundJSON</p><p><b>description</b>: Test the read operation for a known, not found (never existed) Patient resource instance. The expected HTTP response is 404 (Not Found) and optional content of an OperationOutcome resource 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><span title="{http://terminology.hl7.org/CodeSystem/testscript-operation-codes read}">Read</span></td><td>Patient</td><td>Patient read operation for a known, not found (never existed) resource instance.</td><td>json</td><td>true</td><td>/${NotFoundPatientResourceId}</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>ResponseCode</b></td><td><b>WarningOnly</b></td></tr><tr><td>*</td><td></td><td>Confirm that the returned HTTP status is 404(Not Found).</td><td>response</td><td>404</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 ruleset assertion to conditionally validate expected HTTP Headers and payload.</td><td>response</td><td>false</td></tr></table></blockquote></blockquote></div>
  </text>
  <extension
             url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-ruleset">
    <extension url="rulesetId">
      <valueId value="RulesetPatientNotFound"/>
    </extension>
    <extension url="path">
      <valueString value="../_reference/ruleset/RuleSet-NotFound-Groovy.xml"/>
    </extension>
    <extension url="rule">
      <extension url="ruleId">
        <valueId value="assertContentTypeIfBody"/>
      </extension>
    </extension>
    <extension url="rule">
      <extension url="ruleId">
        <valueId value="assertContentTypeMimeTypeIfBody"/>
      </extension>
    </extension>
    <extension url="rule">
      <extension url="ruleId">
        <valueId value="assertContentTypeCharsetIfBody"/>
      </extension>
    </extension>
    <extension url="rule">
      <extension url="ruleId">
        <valueId value="assertResourceIfBody"/>
      </extension>
      <extension url="param">
        <extension url="name">
          <valueString value="resourceOperator"/>
        </extension>
        <extension url="value">
          <valueString value="equals"/>
        </extension>
      </extension>
      <extension url="param">
        <extension url="name">
          <valueString value="bodyOperator"/>
        </extension>
        <extension url="value">
          <valueString value="notEmpty"/>
        </extension>
      </extension>
    </extension>
  </extension>
  <url
       value="http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-notfound-ruleset-with-param-json"/>
  <version value="1.1.0"/>
  <name value="PatientReadNotFoundRulesetWithParamJson"/>
  <status value="active"/>
  <date value="2020-05-29"/>
  <publisher value="AEGIS.net, Inc."/>
  <contact>
    <name value="Touchstone Support"/>
    <telecom>
      <system value="email"/>
      <value value="Touchstone_Support@aegis.net"/>
      <use value="work"/>
    </telecom>
  </contact>
  <description
               value="Demonstrate the use of a ruleset with a Patient read. The actual test is a read operation for a Patient in JSON format where the patient is not found and a ruleset is used to conditionally check the system under test to either skip or apply checks for HTTP response headers the payload content."/>
  <jurisdiction>
    <coding>
      <system value="urn:iso:std:iso:3166"/>
      <code value="US"/>
      <display value="United States of America"/>
    </coding>
  </jurisdiction>
  <copyright value="(c) AEGIS.net, Inc. 2015+"/>
  <profile id="patient-profile">
    <reference value="http://hl7.org/fhir/StructureDefinition/Patient"/>
  </profile>
  <variable>
    <name value="NotFoundPatientResourceId"/>
    <description
                 value="Enter a Patient resource id that does not exist on the destination system."/>
    <hint value="[Not Found Resource Id]"/>
  </variable>
  <test id="01-ReadNotFoundJSON">
    <name value="ReadNotFoundJSON"/>
    <description
                 value="Test the read operation for a known, not found (never existed) Patient resource instance. The expected HTTP response is 404 (Not Found) and optional content of an OperationOutcome resource in JSON format."/>
    <action>
      <operation>
        <type>
          <system
                  value="http://terminology.hl7.org/CodeSystem/testscript-operation-codes"/>
          <code value="read"/>
        </type>
        <resource value="Patient"/>
        <description
                     value="Patient read operation for a known, not found (never existed) resource instance."/>
        <accept value="json"/>
        <encodeRequestUrl value="true"/>
        <params value="/${NotFoundPatientResourceId}"/>
      </operation>
    </action>
    <action>
      <assert>
        <extension
                   url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail">
          <valueBoolean value="false"/>
        </extension>
        <description
                     value="Confirm that the returned HTTP status is 404(Not Found)."/>
        <direction value="response"/>
        <responseCode value="404"/>
        <warningOnly value="false"/>
      </assert>
    </action>
    <action>
      <assert>
        <extension
                   url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-ruleset">
          <extension url="rulesetId">
            <valueId value="RulesetPatientNotFound"/>
          </extension>
          <extension url="rule">
            <extension url="ruleId">
              <valueId value="assertContentTypeMimeTypeIfBody"/>
            </extension>
            <extension url="param">
              <extension url="name">
                <valueString value="headerExpectedValue"/>
              </extension>
              <extension url="value">
                <valueString value="application/fhir+json"/>
              </extension>
            </extension>
          </extension>
          <extension url="rule">
            <extension url="ruleId">
              <valueId value="assertResourceIfBody"/>
            </extension>
            <extension url="param">
              <extension url="name">
                <valueString value="resource"/>
              </extension>
              <extension url="value">
                <valueString value="OperationOutcome"/>
              </extension>
            </extension>
          </extension>
        </extension>
        <description
                     value="Complex ruleset assertion to conditionally validate expected HTTP Headers and payload."/>
        <direction value="response"/>
        <warningOnly value="false"/>
      </assert>
    </action>
  </test>
</TestScript>