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

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

Raw json


{
  "resourceType" : "TestScript",
  "id" : "patient-read-summary-rule-with-param-json",
  "meta" : {
    "profile" : [
      "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript"
    ]
  },
  "text" : {
    "status" : "extensions",
    "div" : "<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 Rule Extension</b></p><h3>Urls</h3><table class=\"grid\"><tr><td>-</td></tr><tr><td>*</td></tr></table><p><b>value</b>: RuleContentTypeIfBody</p><h3>Urls</h3><table class=\"grid\"><tr><td>-</td></tr><tr><td>*</td></tr></table><p><b>value</b>: /FHIRCommon/_reference/rule/AssertHeaderIfBody.groovy</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></blockquote><p><b>url</b>: <a href=\"http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-with-param-json\">http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-with-param-json</a></p><p><b>version</b>: 1.1.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>: <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>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><h3>Ids</h3><table class=\"grid\"><tr><td>-</td></tr><tr><td>*</td></tr></table><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><span title=\"{http://terminology.hl7.org/CodeSystem/testscript-operation-codes read}\">Read</span></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>"
  },
  "extension" : [
    {
      "extension" : [
        {
          "url" : "ruleId",
          "valueId" : "RuleContentTypeIfBody"
        },
        {
          "url" : "path",
          "valueString" : "/FHIRCommon/_reference/rule/AssertHeaderIfBody.groovy"
        },
        {
          "extension" : [
            {
              "url" : "name",
              "valueString" : "header"
            },
            {
              "url" : "value",
              "valueString" : "Content-Type"
            }
          ],
          "url" : "param"
        },
        {
          "extension" : [
            {
              "url" : "name",
              "valueString" : "headerOperator"
            },
            {
              "url" : "value",
              "valueString" : "notEmpty"
            }
          ],
          "url" : "param"
        },
        {
          "extension" : [
            {
              "url" : "name",
              "valueString" : "bodyOperator"
            },
            {
              "url" : "value",
              "valueString" : "notEmpty"
            }
          ],
          "url" : "param"
        }
      ],
      "url" : "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-rule"
    }
  ],
  "url" : "http://touchstone.aegis.net/touchstone/fhir/testing/TestScript/patient-read-summary-rule-with-param-json",
  "version" : "1.1.0",
  "name" : "PatientReadSummaryRuleWithParamJson",
  "status" : "active",
  "date" : "2020-05-29",
  "publisher" : "AEGIS.net, Inc.",
  "contact" : [
    {
      "name" : "Touchstone Support",
      "telecom" : [
        {
          "system" : "email",
          "value" : "Touchstone_Support@aegis.net",
          "use" : "work"
        }
      ]
    }
  ],
  "description" : "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.",
  "jurisdiction" : [
    {
      "coding" : [
        {
          "system" : "urn:iso:std:iso:3166",
          "code" : "US",
          "display" : "United States of America"
        }
      ]
    }
  ],
  "copyright" : "(c) AEGIS.net, Inc. 2015+",
  "profile" : [
    {
      "id" : "patient-profile",
      "reference" : "http://hl7.org/fhir/StructureDefinition/Patient"
    }
  ],
  "variable" : [
    {
      "name" : "patientResourceId",
      "hint" : "Enter a known Patient resource id"
    }
  ],
  "test" : [
    {
      "id" : "PatientReadSummaryRuleWithParam",
      "name" : "PatientReadSummaryRuleWithParam",
      "description" : "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" : "http://terminology.hl7.org/CodeSystem/testscript-operation-codes",
              "code" : "read"
            },
            "resource" : "Patient",
            "description" : "Read the created Patient. The destination server must support the _summary=true parameter.",
            "accept" : "json",
            "encodeRequestUrl" : false,
            "params" : "/${patientResourceId}?_summary=true"
          }
        },
        {
          "assert" : {
            "extension" : [
              {
                "url" : "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail",
                "valueBoolean" : false
              }
            ],
            "description" : "Confirm that the returned HTTP status is 200(OK).",
            "direction" : "response",
            "response" : "okay",
            "warningOnly" : false
          }
        },
        {
          "assert" : {
            "extension" : [
              {
                "extension" : [
                  {
                    "url" : "ruleId",
                    "valueId" : "RuleContentTypeIfBody"
                  },
                  {
                    "extension" : [
                      {
                        "url" : "name",
                        "valueString" : "headerOperator"
                      },
                      {
                        "url" : "value",
                        "valueString" : "notEmpty"
                      }
                    ],
                    "url" : "param"
                  }
                ],
                "url" : "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-rule"
              },
              {
                "url" : "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail",
                "valueBoolean" : false
              }
            ],
            "description" : "Complex rule assertion to evaluate if Content-Type header is present if a payload is returned.",
            "direction" : "response",
            "warningOnly" : false
          }
        },
        {
          "assert" : {
            "extension" : [
              {
                "url" : "http://touchstone.aegis.net/touchstone/fhir/testing/StructureDefinition/testscript-assert-stopTestOnFail",
                "valueBoolean" : true
              }
            ],
            "description" : "Confirm that the returned resource type is Patient.",
            "direction" : "response",
            "resource" : "Patient",
            "warningOnly" : false
          }
        },
        {
          "assert" : {
            "description" : "Validate that the returned resource conforms to the base FHIR Patient profile.",
            "direction" : "response",
            "validateProfileId" : "patient-profile",
            "warningOnly" : false
          }
        }
      ]
    }
  ]
}