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

XML Format: TestScript-patient-read-summary-rule-no-param-json

Raw xml



<TestScript xmlns="http://hl7.org/fhir">
  <id value="patient-read-summary-rule-no-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><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-no-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>: RulePatientSummaryTrue</p><p><b>value</b>: ../_reference/rule/PatientSummaryTrue.groovy</p></blockquote><p><b>url</b>: <code>http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-no-param-json</code></p><p><b>version</b>: 1.5.0</p><p><b>name</b>: PatientReadSummaryRuleNoParamJson</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 the entire returned Patient resource contents.</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>: PatientReadSummaryRuleNoParam</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>ContentType</b></td><td><b>WarningOnly</b></td></tr><tr><td>*</td><td></td><td>Confirm that the returned format is JSON.</td><td>response</td><td>json</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>Extension</b></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></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><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 returned Patient and determine if any non-summary elements were returned.</td><td>response</td><td>false</td></tr></table></blockquote></blockquote></div>
  </text>
  <extension
             url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-rule">
    <extension url="ruleId">
      <valueId value="RulePatientSummaryTrue"/>
    </extension>
    <extension url="path">
      <valueString value="../_reference/rule/PatientSummaryTrue.groovy"/>
    </extension>
  </extension>
  <url
       value="http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-no-param-json"/>
  <version value="1.5.0"/>
  <name value="PatientReadSummaryRuleNoParamJson"/>
  <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 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 the entire returned Patient resource contents."/>
  <jurisdiction>
    <coding>
      <system value="urn:iso:std:iso:3166"/>
      <code value="US"/>
    </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="patientResourceId"/>
    <hint value="Enter a known Patient resource id"/>
  </variable>
  <test id="PatientReadSummaryRuleNoParam">
    <name value="PatientReadSummaryRuleNoParam"/>
    <description
                 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."/>
    <action>
      <operation>
        <type>
          <system
                  value="http://terminology.hl7.org/CodeSystem/testscript-operation-codes"/>
          <code value="read"/>
        </type>
        <resource value="Patient"/>
        <description
                     value="Read the created Patient. The destination server must support the _summary=true parameter."/>
        <accept value="json"/>
        <encodeRequestUrl value="false"/>
        <params value="/${patientResourceId}?_summary=true"/>
      </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 200(OK)."/>
        <direction value="response"/>
        <response value="okay"/>
        <warningOnly value="false"/>
      </assert>
    </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 format is JSON."/>
        <direction value="response"/>
        <contentType value="json"/>
        <warningOnly value="false"/>
      </assert>
    </action>
    <action>
      <assert>
        <extension
                   url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail">
          <valueBoolean value="true"/>
        </extension>
        <description value="Confirm that the returned resource type is Patient."/>
        <direction value="response"/>
        <resource value="Patient"/>
        <warningOnly value="false"/>
      </assert>
    </action>
    <action>
      <assert>
        <extension
                   url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail">
          <valueBoolean value="false"/>
        </extension>
        <description
                     value="Validate that the returned resource conforms to the base FHIR Patient profile."/>
        <direction value="response"/>
        <validateProfileId value="patient-profile"/>
        <warningOnly value="false"/>
      </assert>
    </action>
    <action>
      <assert>
        <extension
                   url="http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-rule">
          <extension url="ruleId">
            <valueId value="RulePatientSummaryTrue"/>
          </extension>
        </extension>
        <description
                     value="Complex rule assertion to evaluate returned Patient and determine if any non-summary elements were returned."/>
        <direction value="response"/>
        <warningOnly value="false"/>
      </assert>
    </action>
  </test>
</TestScript>