STU3 Candidate

This page is part of the FHIR Specification (v1.8.0: STU 3 Draft). The current version which supercedes this version is 5.0.0. For a full list of available versions, see the Directory of published versions . Page versions: R5 R4B R4 R3

Testscript-example-multisystem.json

Raw JSON (canonical form)

Multisystem TestScript Example

{
  "resourceType": "TestScript",
  "id": "testscript-example-multisystem",
  "text": {
    "status": "generated",
    "div": "<div xmlns=\"http://www.w3.org/1999/xhtml\"><p><b>Generated Narrative with Details</b></p><p><b>id</b>: testscript-example-multisystem</p><p><b>url</b>: <a>http://hl7.org/fhir/TestScript/testscript-example-multisystem</a></p><p><b>identifier</b>: urn:oid:1.3.6.1.4.1.21367.2005.3.7.9878</p><p><b>version</b>: 1.0</p><p><b>name</b>: Multisystem Test Script</p><p><b>status</b>: draft</p><p><b>experimental</b>: true</p><p><b>publisher</b>: HL7</p><p><b>contact</b>: </p><p><b>date</b>: 26/09/2016</p><p><b>description</b>: TestScript example resource showing use of origin and destination for multisystem support. The single origin will execute a Patient read against the two destination systems using user defined dynamic variables. The test engine will wait at each operation action with a defined origin and destination for the origin test system to send the expected FHIR operation to the destination test system. Once the expected request and response is observed, the test engine will continue with the test execution.</p><p><b>jurisdiction</b>: United States of America (the) <span>(Details : {urn:iso:std:iso:3166 code 'US' = 'US', given as 'United States of America (the)'})</span></p><p><b>purpose</b>: Patient Read Operation</p><p><b>copyright</b>: © HL7.org 2011+</p><h3>Origins</h3><table><tr><td>-</td><td><b>Index</b></td><td><b>Profile</b></td></tr><tr><td>*</td><td>1</td><td>FHIR-Client (Details: [not stated] code FHIR-Client = 'FHIR-Client', stated as 'null')</td></tr></table><blockquote><p><b>destination</b></p><p><b>index</b>: 1</p><p><b>profile</b>: FHIR-Server (Details: [not stated] code FHIR-Server = 'FHIR-Server', stated as 'null')</p></blockquote><blockquote><p><b>destination</b></p><p><b>index</b>: 2</p><p><b>profile</b>: FHIR-Server (Details: [not stated] code FHIR-Server = 'FHIR-Server', stated as 'null')</p></blockquote><blockquote><p><b>metadata</b></p><blockquote><p><b>capability</b></p><p><b>required</b>: true</p><p><b>validated</b>: false</p><p><b>description</b>: Patient Read Operation</p><p><b>origin</b>: 1</p><p><b>destination</b>: 1</p><p><b>link</b>: <a>http://hl7.org/fhir/http.html#read</a></p><p><b>capabilities</b>: <a>CapabilityStatement/example</a></p></blockquote><blockquote><p><b>capability</b></p><p><b>required</b>: true</p><p><b>validated</b>: false</p><p><b>description</b>: Patient Read Operation</p><p><b>origin</b>: 1</p><p><b>destination</b>: 2</p><p><b>link</b>: <a>http://hl7.org/fhir/http.html#read</a></p><p><b>capabilities</b>: <a>CapabilityStatement/example</a></p></blockquote></blockquote><blockquote><p><b>variable</b></p><p><b>name</b>: Dest1PatientResourceId</p><p><b>defaultValue</b>: example</p></blockquote><blockquote><p><b>variable</b></p><p><b>name</b>: Dest2PatientResourceId</p><p><b>defaultValue</b>: example</p></blockquote><blockquote><p><b>test</b></p><p><b>name</b>: ReadPatient-Destination1</p><p><b>description</b>: Read a Patient from the first destination test system using the user defined dynamic variable ${Dest1PatientResourceId}. Perform basic validation.</p><blockquote><p><b>action</b></p><h3>Operations</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote></blockquote><blockquote><p><b>test</b></p><p><b>name</b>: ReadPatient-Destination2</p><p><b>description</b>: Read a Patient from the second destination test system using the user defined dynamic variable ${Dest2PatientResourceId}. Perform basic validation.</p><blockquote><p><b>action</b></p><h3>Operations</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote><blockquote><p><b>action</b></p><h3>Asserts</h3><table><tr><td>-</td></tr><tr><td>*</td></tr></table></blockquote></blockquote></div>"
  },
  "url": "http://hl7.org/fhir/TestScript/testscript-example-multisystem",
  "identifier": {
    "system": "urn:ietf:rfc:3986",
    "value": "urn:oid:1.3.6.1.4.1.21367.2005.3.7.9878"
  },
  "version": "1.0",
  "name": "Multisystem Test Script",
  "status": "draft",
  "experimental": true,
  "publisher": "HL7",
  "contact": [
    {
      "name": "Support",
      "telecom": [
        {
          "system": "email",
          "value": "support@HL7.org",
          "use": "work"
        }
      ]
    }
  ],
  "date": "2016-09-26",
  "description": "TestScript example resource showing use of origin and destination for multisystem support. The single origin will execute a Patient read against the two destination systems using user defined dynamic variables. The test engine will wait at each operation action with a defined origin and destination for the origin test system to send the expected FHIR operation to the destination test system. Once the expected request and response is observed, the test engine will continue with the test execution.",
  "jurisdiction": [
    {
      "coding": [
        {
          "system": "urn:iso:std:iso:3166",
          "code": "US",
          "display": "United States of America (the)"
        }
      ]
    }
  ],
  "purpose": "Patient Read Operation",
  "copyright": "© HL7.org 2011+",
  "origin": [
    {
      "index": 1,
      "profile": {
        "code": "FHIR-Client"
      }
    }
  ],
  "destination": [
    {
      "index": 1,
      "profile": {
        "code": "FHIR-Server"
      }
    },
    {
      "index": 2,
      "profile": {
        "code": "FHIR-Server"
      }
    }
  ],
  "metadata": {
    "capability": [
      {
        "required": true,
        "validated": false,
        "description": "Patient Read Operation",
        "origin": [
          1
        ],
        "destination": 1,
        "link": [
          "http://hl7.org/fhir/http.html#read"
        ],
        "capabilities": {
          "reference": "CapabilityStatement/example"
        }
      },
      {
        "required": true,
        "validated": false,
        "description": "Patient Read Operation",
        "origin": [
          1
        ],
        "destination": 2,
        "link": [
          "http://hl7.org/fhir/http.html#read"
        ],
        "capabilities": {
          "reference": "CapabilityStatement/example"
        }
      }
    ]
  },
  "variable": [
    {
      "name": "Dest1PatientResourceId",
      "defaultValue": "example"
    },
    {
      "name": "Dest2PatientResourceId",
      "defaultValue": "example"
    }
  ],
  "test": [
    {
      "id": "01-ReadPatient-Destination1",
      "name": "ReadPatient-Destination1",
      "description": "Read a Patient from the first destination test system using the user defined dynamic variable ${Dest1PatientResourceId}. Perform basic validation.",
      "action": [
        {
          "operation": {
            "type": {
              "system": "http://hl7.org/fhir/testscript-operation-codes",
              "code": "read"
            },
            "resource": "Patient",
            "description": "Read a Patient from the first destination test system and perform basic validation.",
            "accept": "xml",
            "contentType": "xml",
            "destination": 1,
            "origin": 1,
            "params": "/${Dest1PatientResourceId}"
          }
        },
        {
          "assert": {
            "description": "Confirm that the client requested an Accept of xml.",
            "direction": "request",
            "headerField": "Accept",
            "operator": "contains",
            "value": "xml"
          }
        },
        {
          "assert": {
            "description": "Confirm that the returned HTTP status is 200(OK).",
            "direction": "response",
            "response": "okay"
          }
        },
        {
          "assert": {
            "description": "Confirm that the returned format is XML.",
            "direction": "response",
            "contentType": "xml"
          }
        },
        {
          "assert": {
            "description": "Confirm that the returned resource type is Patient.",
            "direction": "response",
            "resource": "Patient"
          }
        }
      ]
    },
    {
      "id": "02-ReadPatient-Destination2",
      "name": "ReadPatient-Destination2",
      "description": "Read a Patient from the second destination test system using the user defined dynamic variable ${Dest2PatientResourceId}. Perform basic validation.",
      "action": [
        {
          "operation": {
            "type": {
              "system": "http://hl7.org/fhir/testscript-operation-codes",
              "code": "read"
            },
            "resource": "Patient",
            "description": "Read a Patient from the second destination test system and perform basic validation.",
            "accept": "xml",
            "contentType": "xml",
            "destination": 2,
            "origin": 1,
            "params": "/${Dest2PatientResourceId}"
          }
        },
        {
          "assert": {
            "description": "Confirm that the client requested an Accept of xml.",
            "direction": "request",
            "headerField": "Accept",
            "operator": "contains",
            "value": "xml"
          }
        },
        {
          "assert": {
            "description": "Confirm that the returned HTTP status is 200(OK).",
            "direction": "response",
            "response": "okay"
          }
        },
        {
          "assert": {
            "description": "Confirm that the returned format is XML.",
            "direction": "response",
            "contentType": "xml"
          }
        },
        {
          "assert": {
            "description": "Confirm that the returned resource type is Patient.",
            "direction": "response",
            "resource": "Patient"
          }
        }
      ]
    }
  ]
}

Usage note: every effort has been made to ensure that the examples are correct and useful, but they are not a normative part of the specification.