Extensions for Using Data Elements from FHIR R4 in FHIR STU3
0.1.0 - STU International flag

Extensions for Using Data Elements from FHIR R4 in FHIR STU3 - Downloaded Version null See the Directory of published versions

Resource Profile: Profile_R4_TestScript_R3 - Detailed Descriptions

Page standards status: Trial-use Maturity Level: 0

Definitions for the profile-TestScript resource profile.

Guidance on how to interpret the contents of this table can be foundhere

0. TestScript
Definition

A structured set of tests against a FHIR server implementation to determine compliance against the FHIR specification.

ShortDescribes a set of tests
Control0..*
Invariantsdom-2: If the resource is contained in another resource, it SHALL NOT contain nested Resources (contained.contained.empty())
dom-1: If the resource is contained in another resource, it SHALL NOT contain any narrative (contained.text.empty())
dom-4: If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated (contained.meta.versionId.empty() and contained.meta.lastUpdated.empty())
dom-3: If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource (contained.where(('#'+id in %resource.descendants().reference).not()).empty())
dom-2: If the resource is contained in another resource, it SHALL NOT contain nested Resources (contained.contained.empty())
dom-1: If the resource is contained in another resource, it SHALL NOT contain any narrative (contained.text.empty())
dom-4: If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated (contained.meta.versionId.empty() and contained.meta.lastUpdated.empty())
dom-3: If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource (contained.where(('#'+id in %resource.descendants().reference).not()).empty())
2. TestScript.implicitRules
Definition

A reference to a set of rules that were followed when the resource was constructed, and which must be understood when processing the content.

ShortA set of rules under which this content was created
Comments

Asserting this rule set restricts the content to be only understood by a limited set of trading partners. This inherently limits the usefulness of the data in the long term. However, the existing health eco-system is highly fractured, and not yet ready to define, collect, and exchange data in a generally computable sense. Wherever possible, implementers and/or specification writers should avoid using this element.

This element is labelled as a modifier because the implicit rules may provide additional knowledge about the resource that modifies it's meaning or interpretation.

Control0..1
Typeuri
Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
Summarytrue
4. TestScript.modifierExtension
Definition

May be used to represent additional information that is not part of the basic definition of the resource, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

ShortExtensions that cannot be ignored
Comments

There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

Control0..*
TypeExtension
Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
Alternate Namesextensions, user content
6. TestScript.url
Definition

An absolute URI that is used to identify this test script when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this test script is (or will be) published. The URL SHOULD include the major version of the test script. For more information see Technical and Business Versions.

ShortLogical URI to reference this test script (globally unique)
Comments

Can be a urn:uuid: or a urn:oid:, but real http: addresses are preferred. Multiple instances may share the same url if they have a distinct version.

Control1..1
Typeuri
Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
Summarytrue
Requirements

Allows the test script to be referenced by a single globally unique identifier.

Alternate Namesurl, authoritative-url, destination, identity
8. TestScript.name
Definition

A natural language name identifying the test script. This name should be usable as an identifier for the module by machine processing applications such as code generation.

ShortName for this test script (computer friendly)
Comments

The name is not expected to be globally unique. The name should be a simple alpha-numeric type name to ensure that it is computable friendly.

Control1..1
Typestring
Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
Summarytrue
Requirements

Support human navigation and code generation.

10. TestScript.status
Definition

The status of this test script. Enables tracking the life-cycle of the content.

Shortdraft | active | retired | unknown
Comments

Allows filtering of test scripts that are appropriate for use vs. not.
This is labeled as "Is Modifier" because applications should not use a retired test script without due consideration.

Control1..1
BindingThe codes SHALL be taken from PublicationStatushttp://hl7.org/fhir/ValueSet/publication-status|3.0.2
(required to http://hl7.org/fhir/ValueSet/publication-status|3.0.2)

The lifecycle status of a Value Set or Concept Map.

Typecode
Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
Summarytrue
12. TestScript.experimental
Definition

A boolean value to indicate that this test script is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage.

ShortFor testing purposes, not real usage
Comments

Allows filtering of test script that are appropriate for use vs. not. This is labeled as "Is Modifier" because applications should not use an experimental test script in production.

Control0..1
Typeboolean
Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
Summarytrue
Requirements

Enables experimental content to be developed following the same lifecycle that would be used for a production-level test script.

Guidance on how to interpret the contents of this table can be foundhere

0. TestScript
2. TestScript.metadata
4. TestScript.metadata.capability
6. TestScript.metadata.capability.capabilities
8. TestScript.metadata.capability.capabilities.extension
Control0..*
SlicingThis element introduces a set of slices on TestScript.metadata.capability.capabilities.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
  • value @ url
  • 10. TestScript.metadata.capability.capabilities.extension:capabilities
    Slice Namecapabilities
    Definition

    R4: TestScript.metadata.capability.capabilities additional types (canonical(http://hl7.org/fhir/StructureDefinition/CapabilityStatement)) additional types from child elements (value)

    ShortR4: capabilities additional types
    Comments

    Element TestScript.metadata.capability.capabilities is mapped to FHIR STU3 element TestScript.metadata.capability.capabilities as SourceIsBroaderThanTarget. The mappings for TestScript.metadata.capability.capabilities do not cover the following types: canonical. The mappings for TestScript.metadata.capability.capabilities do not cover the following types based on type expansion: value. The conformance statement of the server has to contain at a minimum the contents of the reference pointed to by this element.

    Control0..1
    TypeExtension(R4: capabilities additional types) (Extension Type: uri(Cross-version Profile for R4.CapabilityStatement for use in FHIR STU3, CapabilityStatement))
    12. TestScript.setup
    14. TestScript.setup.action
    16. TestScript.setup.action.operation
    18. TestScript.setup.action.operation.extension
    Control0..*
    SlicingThis element introduces a set of slices on TestScript.setup.action.operation.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
    • value @ url
    • 20. TestScript.setup.action.operation.extension:method
      Slice Namemethod
      Definition

      R4: TestScript.setup.action.operation.method (new:code)

      ShortR4: delete | get | options | patch | post | put | head (new)
      Comments

      Element TestScript.setup.action.operation.method has a context of TestScript.setup.action.operation based on following the parent source element upwards and mapping to TestScript. Element TestScript.setup.action.operation.method has no mapping targets in FHIR STU3. Typically, this is because the element has been added (is a new element). The primary purpose of the explicit HTTP method is support of HTTP POST method invocation of the FHIR search. Other uses will include support of negative testing.

      Control0..1
      TypeExtension(R4: delete | get | options | patch | post | put | head (new)) (Extension Type: code)
      22. TestScript.setup.action.operation.resource
      24. TestScript.setup.action.operation.resource.extension
      Control0..*
      SlicingThis element introduces a set of slices on TestScript.setup.action.operation.resource.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
      • value @ url
      • 26. TestScript.setup.action.operation.resource.extension:resource
        Slice Nameresource
        Definition

        R4: TestScript.setup.action.operation.resource

        ShortR4: resource
        Comments

        Element TestScript.setup.action.operation.resource is mapped to FHIR STU3 element TestScript.setup.action.operation.resource as SourceIsBroaderThanTarget. If "url" element is specified, then "targetId", "params", and "resource" elements will be ignored as "url" element will have everything needed for constructing the request url. If "params" element is specified, then "targetId" element is ignored. For FHIR operations that require a resource (e.g. "read" and "vread" operations), the "resource" element must be specified when "params" element is specified. If "url" and "params" elements are absent, then the request url will be constructed from "targetId" fixture if present. For "read" operation, the resource and id values will be extracted from "targetId" fixture and used to construct the url. For "vread" and "history" operations, the versionId value will also be used.

        Control0..1
        TypeExtension(R4: resource) (Extension Type: code)
        28. TestScript.setup.action.assert
        30. TestScript.setup.action.assert.requestMethod
        32. TestScript.setup.action.assert.requestMethod.extension
        Control0..*
        SlicingThis element introduces a set of slices on TestScript.setup.action.assert.requestMethod.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
        • value @ url
        • 34. TestScript.setup.action.assert.requestMethod.extension:requestMethod
          Slice NamerequestMethod
          Definition

          R4: TestScript.setup.action.assert.requestMethod

          ShortR4: delete | get | options | patch | post | put | head
          Comments

          Element TestScript.setup.action.assert.requestMethod is mapped to FHIR STU3 element TestScript.setup.action.assert.requestMethod as SourceIsBroaderThanTarget. If "requestMethod" is specified then it will be used in place of "value". The "requestMethod" will evaluate against the last operation's request HTTP operation.

          Control0..1
          TypeExtension(R4: delete | get | options | patch | post | put | head) (Extension Type: code)
          36. TestScript.setup.action.assert.resource
          38. TestScript.setup.action.assert.resource.extension
          Control0..*
          SlicingThis element introduces a set of slices on TestScript.setup.action.assert.resource.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
          • value @ url
          • 40. TestScript.setup.action.assert.resource.extension:resource
            Slice Nameresource
            Definition

            R4: TestScript.setup.action.assert.resource

            ShortR4: resource
            Comments

            Element TestScript.setup.action.assert.resource is mapped to FHIR STU3 element TestScript.setup.action.assert.resource as SourceIsBroaderThanTarget. This will be expected resource type in response body e.g. in read, vread, search, etc. See http://build.fhir.org/resourcelist.html for complete list of resource types; e.g. <assert > <resourceType value="Patient" </assert>.

            Control0..1
            TypeExtension(R4: resource) (Extension Type: code)

            Guidance on how to interpret the contents of this table can be foundhere

            0. TestScript
            Definition

            A structured set of tests against a FHIR server implementation to determine compliance against the FHIR specification.

            ShortDescribes a set of tests
            Control0..*
            Invariantsdom-2: If the resource is contained in another resource, it SHALL NOT contain nested Resources (contained.contained.empty())
            dom-1: If the resource is contained in another resource, it SHALL NOT contain any narrative (contained.text.empty())
            dom-4: If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated (contained.meta.versionId.empty() and contained.meta.lastUpdated.empty())
            dom-3: If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource (contained.where(('#'+id in %resource.descendants().reference).not()).empty())
            2. TestScript.id
            Definition

            The logical id of the resource, as used in the URL for the resource. Once assigned, this value never changes.

            ShortLogical id of this artifact
            Comments

            The only time that a resource does not have an id is when it is being submitted to the server using a create operation.

            Control0..1
            Typeid
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            4. TestScript.meta
            Definition

            The metadata about the resource. This is content that is maintained by the infrastructure. Changes to the content may not always be associated with version changes to the resource.

            ShortMetadata about the resource
            Control0..1
            TypeMeta
            Summarytrue
            6. TestScript.implicitRules
            Definition

            A reference to a set of rules that were followed when the resource was constructed, and which must be understood when processing the content.

            ShortA set of rules under which this content was created
            Comments

            Asserting this rule set restricts the content to be only understood by a limited set of trading partners. This inherently limits the usefulness of the data in the long term. However, the existing health eco-system is highly fractured, and not yet ready to define, collect, and exchange data in a generally computable sense. Wherever possible, implementers and/or specification writers should avoid using this element.

            This element is labelled as a modifier because the implicit rules may provide additional knowledge about the resource that modifies it's meaning or interpretation.

            Control0..1
            Typeuri
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            8. TestScript.language
            Definition

            The base language in which the resource is written.

            ShortLanguage of the resource content
            Comments

            Language is provided to support indexing and accessibility (typically, services such as text to speech use the language tag). The html language tag in the narrative applies to the narrative. The language tag on the resource may be used to specify the language of other presentations generated from the data in the resource Not all the content has to be in the base language. The Resource.language should not be assumed to apply to the narrative automatically. If a language is specified, it should it also be specified on the div element in the html (see rules in HTML5 for information about the relationship between xml:lang and the html lang attribute).

            Control0..1
            BindingUnless not suitable, these codes SHALL be taken from Common Languages
            (extensible to http://hl7.org/fhir/ValueSet/languages|3.0.2)

            A human language.

            Additional BindingsPurpose
            All LanguagesMax Binding
            Typecode
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            10. TestScript.text
            Definition

            A human-readable narrative that contains a summary of the resource, and may be used to represent the content of the resource to a human. The narrative need not encode all the structured data, but is required to contain sufficient detail to make it "clinically safe" for a human to just read the narrative. Resource definitions may define what content should be represented in the narrative to ensure clinical safety.

            ShortText summary of the resource, for human interpretation
            Comments

            Contained resources do not have narrative. Resources that are not contained SHOULD have a narrative. In some cases, a resource may only have text with little or no additional discrete data (as long as all minOccurs=1 elements are satisfied). This may be necessary for data from legacy systems where information is captured as a "text blob" or where text is additionally entered raw or narrated and encoded in formation is added later.

            Control0..1
            This element is affected by the following invariants: dom-1
            TypeNarrative
            Alternate Namesnarrative, html, xhtml, display
            12. TestScript.contained
            Definition

            These resources do not have an independent existence apart from the resource that contains them - they cannot be identified independently, and nor can they have their own independent transaction scope.

            ShortContained, inline Resources
            Comments

            This should never be done when the content can be identified properly, as once identification is lost, it is extremely difficult (and context dependent) to restore it again.

            Control0..*
            TypeResource
            Alternate Namesinline resources, anonymous resources, contained resources
            14. TestScript.extension
            Definition

            May be used to represent additional information that is not part of the basic definition of the resource. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

            ShortAdditional Content defined by implementations
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Alternate Namesextensions, user content
            16. TestScript.modifierExtension
            Definition

            May be used to represent additional information that is not part of the basic definition of the resource, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

            ShortExtensions that cannot be ignored
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Alternate Namesextensions, user content
            18. TestScript.url
            Definition

            An absolute URI that is used to identify this test script when it is referenced in a specification, model, design or an instance. This SHALL be a URL, SHOULD be globally unique, and SHOULD be an address at which this test script is (or will be) published. The URL SHOULD include the major version of the test script. For more information see Technical and Business Versions.

            ShortLogical URI to reference this test script (globally unique)
            Comments

            Can be a urn:uuid: or a urn:oid:, but real http: addresses are preferred. Multiple instances may share the same url if they have a distinct version.

            Control1..1
            Typeuri
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            Requirements

            Allows the test script to be referenced by a single globally unique identifier.

            Alternate Namesurl, authoritative-url, destination, identity
            20. TestScript.identifier
            Definition

            A formal identifier that is used to identify this test script when it is represented in other formats, or referenced in a specification, model, design or an instance.

            ShortAdditional identifier for the test script
            Comments

            Typically, this is used for identifiers that can go in an HL7 V3 II (instance identifier) data type, e.g., to identify this test script outside of FHIR, where it is not possible to use the logical URI.

            NoteThis is a business identifier, not a resource identifier (see discussion)
            Control0..1
            TypeIdentifier
            Summarytrue
            Requirements

            Allows externally provided and/or usable business identifiers to be easily associated with the module.

            22. TestScript.version
            Definition

            The identifier that is used to identify this version of the test script when it is referenced in a specification, model, design or instance. This is an arbitrary value managed by the test script author and is not expected to be globally unique. For example, it might be a timestamp (e.g. yyyymmdd) if a managed version is not available. There is also no expectation that versions can be placed in a lexicographical sequence.

            ShortBusiness version of the test script
            Comments

            There may be different test script instances that have the same identifier but different versions. The version can be appended to the url in a reference to allow a refrence to a particular business version of the test script with the format [url]|[version].

            NoteThis is a business version Id, not a resource version Id (see discussion)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            24. TestScript.name
            Definition

            A natural language name identifying the test script. This name should be usable as an identifier for the module by machine processing applications such as code generation.

            ShortName for this test script (computer friendly)
            Comments

            The name is not expected to be globally unique. The name should be a simple alpha-numeric type name to ensure that it is computable friendly.

            Control1..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            Requirements

            Support human navigation and code generation.

            26. TestScript.title
            Definition

            A short, descriptive, user-friendly title for the test script.

            ShortName for this test script (human friendly)
            Comments

            This name does not need to be machine-processing friendly and may contain punctuation, white-space, etc.

            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            28. TestScript.status
            Definition

            The status of this test script. Enables tracking the life-cycle of the content.

            Shortdraft | active | retired | unknown
            Comments

            Allows filtering of test scripts that are appropriate for use vs. not.
            This is labeled as "Is Modifier" because applications should not use a retired test script without due consideration.

            Control1..1
            BindingThe codes SHALL be taken from PublicationStatus
            (required to http://hl7.org/fhir/ValueSet/publication-status|3.0.2)

            The lifecycle status of a Value Set or Concept Map.

            Typecode
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            30. TestScript.experimental
            Definition

            A boolean value to indicate that this test script is authored for testing purposes (or education/evaluation/marketing), and is not intended to be used for genuine usage.

            ShortFor testing purposes, not real usage
            Comments

            Allows filtering of test script that are appropriate for use vs. not. This is labeled as "Is Modifier" because applications should not use an experimental test script in production.

            Control0..1
            Typeboolean
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            Requirements

            Enables experimental content to be developed following the same lifecycle that would be used for a production-level test script.

            32. TestScript.date
            Definition

            The date (and optionally time) when the test script was published. The date must change if and when the business version changes and it must change if the status code changes. In addition, it should change when the substantive content of the test script changes.

            ShortDate this was last changed
            Comments

            Note that this is not the same as the resource last-modified-date, since the resource may be a secondary representation of the test script. Additional specific dates may be added as extensions or be found by consulting Provenances associated with past versions of the resource.

            Control0..1
            TypedateTime
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            Alternate NamesRevision Date
            34. TestScript.publisher
            Definition

            The name of the individual or organization that published the test script.

            ShortName of the publisher (organization or individual)
            Comments

            Usually an organization, but may be an individual. The publisher (or steward) of the test script is the organization or individual primarily responsible for the maintenance and upkeep of the test script. This is not necessarily the same individual or organization that developed and initially authored the content. The publisher is the primary point of contact for questions or issues with the test script. This item SHOULD be populated unless the information is available from context.

            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Summarytrue
            Requirements

            Helps establish the "authority/credibility" of the test script. May also allow for contact.

            36. TestScript.contact
            Definition

            Contact details to assist a user in finding and communicating with the publisher.

            ShortContact details for the publisher
            Comments

            May be a web site, an email address, a telephone number, etc.

            Control0..*
            TypeContactDetail
            Summarytrue
            38. TestScript.description
            Definition

            A free text natural language description of the test script from a consumer's perspective.

            ShortNatural language description of the test script
            Comments

            This description can be used to capture details such as why the test script was built, comments about misuse, instructions for clinical use and interpretation, literature references, examples from the paper world, etc. It is not a rendering of the test script as conveyed in the 'text' field of the resource itself. This item SHOULD be populated unless the information is available from context (e.g. the language of the profile is presumed to be the predominant language in the place the profile was created).

            Control0..1
            Typemarkdown
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            40. TestScript.useContext
            Definition

            The content was developed with a focus and intent of supporting the contexts that are listed. These terms may be used to assist with indexing and searching for appropriate test script instances.

            ShortContext the content is intended to support
            Comments

            When multiple useContexts are specified, there is no expectation whether all or any of the contexts apply.

            Control0..*
            TypeUsageContext
            Summarytrue
            Requirements

            Assist in searching for appropriate content.

            42. TestScript.jurisdiction
            Definition

            A legal or geographic region in which the test script is intended to be used.

            ShortIntended jurisdiction for test script (if applicable)
            Comments

            It may be possible for the test script to be used in jurisdictions other than those for which it was originally designed or intended.

            Control0..*
            BindingUnless not suitable, these codes SHALL be taken from Jurisdiction ValueSet
            (extensible to http://hl7.org/fhir/ValueSet/jurisdiction|3.0.2)

            Countries and regions within which this artifact is targeted for use

            TypeCodeableConcept
            Summarytrue
            44. TestScript.purpose
            Definition

            Explaination of why this test script is needed and why it has been designed as it has.

            ShortWhy this test script is defined
            Comments

            This element does not describe the usage of the test script Instead it provides traceability of ''why'' the resource is either needed or ''why'' it is defined as it is. This may be used to point to source materials or specifications that drove the structure of this test script.

            Control0..1
            Typemarkdown
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            46. TestScript.copyright
            Definition

            A copyright statement relating to the test script and/or its contents. Copyright statements are generally legal restrictions on the use and publishing of the test script.

            ShortUse and/or publishing restrictions
            Control0..1
            Typemarkdown
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Requirements

            Consumers must be able to determine any legal restrictions on the use of the test script and/or its content.

            Alternate NamesLicense, Restrictions
            48. TestScript.origin
            Definition

            An abstract server used in operations within this test script in the origin element.

            ShortAn abstract server representing a client or sender in a message exchange
            Comments

            The purpose of this element is to define the profile of an origin element used elsewhere in the script. Test engines could then use the origin-profile mapping to offer a filtered list of test systems that can serve as the sender for the interaction.

            Control0..*
            TypeBackboneElement
            Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
            50. TestScript.origin.id
            Definition

            unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

            Shortxml:id (or equivalent in JSON)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            XML FormatIn the XML format, this property is represented as an attribute.
            52. TestScript.origin.extension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

            ShortAdditional Content defined by implementations
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Alternate Namesextensions, user content
            54. TestScript.origin.modifierExtension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

            ShortExtensions that cannot be ignored
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Summarytrue
            Alternate Namesextensions, user content, modifiers
            56. TestScript.origin.index
            Definition

            Abstract name given to an origin server in this test script. The name is provided as a number starting at 1.

            ShortThe index of the abstract origin server starting at 1
            Comments

            A given origin index (e.g. 1) can appear only once in the list (e.g. Origin 1 cannot be specified twice ... once as FormFiller and and again as FormProcessor within the same script as that could get confusing during test configuration).

            Different origin indices could play the same actor in the same test script (e.g. You could have two different test systems acting as Form-Filler).

            The origin indices provided elsewhere in the test script must be one of these origin indices.

            Control1..1
            Typeinteger
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            58. TestScript.origin.profile
            Definition

            The type of origin profile the test system supports.

            ShortFHIR-Client | FHIR-SDC-FormFiller
            Comments

            Must be a "sender"/"client" profile.

            Control1..1
            BindingUnless not suitable, these codes SHALL be taken from TestScriptProfileOriginType
            (extensible to http://hl7.org/fhir/ValueSet/testscript-profile-origin-types|3.0.2)

            The type of origin profile the test system supports.

            TypeCoding
            Meaning if MissingFHIR-Client
            60. TestScript.destination
            Definition

            An abstract server used in operations within this test script in the destination element.

            ShortAn abstract server representing a destination or receiver in a message exchange
            Comments

            The purpose of this element is to define the profile of a destination element used elsewhere in the script. Test engines could then use the destination-profile mapping to offer a filtered list of test systems that can serve as the receiver for the interaction.

            Control0..*
            TypeBackboneElement
            Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
            62. TestScript.destination.id
            Definition

            unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

            Shortxml:id (or equivalent in JSON)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            XML FormatIn the XML format, this property is represented as an attribute.
            64. TestScript.destination.extension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

            ShortAdditional Content defined by implementations
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Alternate Namesextensions, user content
            66. TestScript.destination.modifierExtension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

            ShortExtensions that cannot be ignored
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Summarytrue
            Alternate Namesextensions, user content, modifiers
            68. TestScript.destination.index
            Definition

            Abstract name given to a destination server in this test script. The name is provided as a number starting at 1.

            ShortThe index of the abstract destination server starting at 1
            Comments

            A given destination index (e.g. 1) can appear only once in the list (e.g. Destination 1 cannot be specified twice ... once as Form-Manager and again as Form-Processor within the same script as that could get confusing during test configuration).

            Different destination indices could play the same actor in the same test script (e.g. You could have two different test systems acting as Form-Manager).

            The destination indices provided elsewhere in the test script must be one of these destination indices.

            Control1..1
            Typeinteger
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            70. TestScript.destination.profile
            Definition

            The type of destination profile the test system supports.

            ShortFHIR-Server | FHIR-SDC-FormManager | FHIR-SDC-FormReceiver | FHIR-SDC-FormProcessor
            Comments

            Must be a "receiver"/"server" profile.

            Control1..1
            BindingUnless not suitable, these codes SHALL be taken from TestScriptProfileDestinationType
            (extensible to http://hl7.org/fhir/ValueSet/testscript-profile-destination-types|3.0.2)

            The type of destination profile the test system supports.

            TypeCoding
            Meaning if MissingFHIR-Server
            72. TestScript.metadata
            Definition

            The required capability must exist and are assumed to function correctly on the FHIR server being tested.

            ShortRequired capability that is assumed to function correctly on the FHIR server being tested
            Control0..1
            TypeBackboneElement
            Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
            inv-4: TestScript metadata capability SHALL contain required or validated or both. (capability.required.exists() or capability.validated.exists())
            74. TestScript.metadata.id
            Definition

            unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

            Shortxml:id (or equivalent in JSON)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            XML FormatIn the XML format, this property is represented as an attribute.
            76. TestScript.metadata.extension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

            ShortAdditional Content defined by implementations
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Alternate Namesextensions, user content
            78. TestScript.metadata.modifierExtension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

            ShortExtensions that cannot be ignored
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Summarytrue
            Alternate Namesextensions, user content, modifiers
            80. TestScript.metadata.link
            Definition

            A link to the FHIR specification that this test is covering.

            ShortLinks to the FHIR specification
            Control0..*
            TypeBackboneElement
            Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
            82. TestScript.metadata.link.id
            Definition

            unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

            Shortxml:id (or equivalent in JSON)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            XML FormatIn the XML format, this property is represented as an attribute.
            84. TestScript.metadata.link.extension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

            ShortAdditional Content defined by implementations
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Alternate Namesextensions, user content
            86. TestScript.metadata.link.modifierExtension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

            ShortExtensions that cannot be ignored
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Summarytrue
            Alternate Namesextensions, user content, modifiers
            88. TestScript.metadata.link.url
            Definition

            URL to a particular requirement or feature within the FHIR specification.

            ShortURL to the specification
            Control1..1
            Typeuri
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            90. TestScript.metadata.link.description
            Definition

            Short description of the link.

            ShortShort description
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            92. TestScript.metadata.capability
            Definition

            Capabilities that must exist and are assumed to function correctly on the FHIR server being tested.

            ShortCapabilities that are assumed to function correctly on the FHIR server being tested
            Comments

            When the metadata capabilities section is defined at TestScript.metadata or at TestScript.setup.metadata, and the server's conformance statement does not contain the elements defined in the minimal conformance statement, then all the tests in the TestScript are skipped. When the metadata capabilities section is defined at TestScript.test.metadata and the server's conformance statement does not contain the elements defined in the minimal conformance statement, then only that test is skipped. The "metadata.capabilities.required" and "metadata.capabilities.validated" elements only indicate whether the capabilities are the primary focus of the test script or not. They do not impact the skipping logic. Capabilities whose "metadata.capabilities.validated" flag is true are the primary focus of the test script.

            Control1..*
            TypeBackboneElement
            Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
            94. TestScript.metadata.capability.id
            Definition

            unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

            Shortxml:id (or equivalent in JSON)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            XML FormatIn the XML format, this property is represented as an attribute.
            96. TestScript.metadata.capability.extension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

            ShortAdditional Content defined by implementations
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Alternate Namesextensions, user content
            98. TestScript.metadata.capability.modifierExtension
            Definition

            May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

            ShortExtensions that cannot be ignored
            Comments

            There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

            Control0..*
            TypeExtension
            Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
            Summarytrue
            Alternate Namesextensions, user content, modifiers
            100. TestScript.metadata.capability.required
            Definition

            Whether or not the test execution will require the given capabilities of the server in order for this test script to execute.

            ShortAre the capabilities required?
            Control0..1
            Typeboolean
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Default Valuefalse
            102. TestScript.metadata.capability.validated
            Definition

            Whether or not the test execution will validate the given capabilities of the server in order for this test script to execute.

            ShortAre the capabilities validated?
            Control0..1
            Typeboolean
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            Default Valuefalse
            104. TestScript.metadata.capability.description
            Definition

            Description of the capabilities that this test script is requiring the server to support.

            ShortThe expected capabilities of the server
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            106. TestScript.metadata.capability.origin
            Definition

            Which origin server these requirements apply to.

            ShortWhich origin server these requirements apply to
            Control0..*
            Typeinteger
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            108. TestScript.metadata.capability.destination
            Definition

            Which server these requirements apply to.

            ShortWhich server these requirements apply to
            Control0..1
            Typeinteger
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            110. TestScript.metadata.capability.link
            Definition

            Links to the FHIR specification that describes this interaction and the resources involved in more detail.

            ShortLinks to the FHIR specification
            Control0..*
            Typeuri
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            112. TestScript.metadata.capability.capabilities
            Definition

            Minimum capabilities required of server for test script to execute successfully. If server does not meet at a minimum the referenced capability statement, then all tests in this script are skipped.

            ShortRequired Capability Statement
            Comments

            The conformance statement of the server has to contain at a minimum the contents of the reference pointed to by this element.

            Control1..1
            TypeReference(CapabilityStatement)
            114. TestScript.metadata.capability.capabilities.id
            Definition

            unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

            Shortxml:id (or equivalent in JSON)
            Control0..1
            Typestring
            Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
            XML FormatIn the XML format, this property is represented as an attribute.
            116. TestScript.metadata.capability.capabilities.extension
            Definition

            An Extension

            ShortExtension
            Control0..*
            TypeExtension
            SlicingThis element introduces a set of slices on TestScript.metadata.capability.capabilities.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
            • value @ url
            • 118. TestScript.metadata.capability.capabilities.extension:capabilities
              Slice Namecapabilities
              Definition

              R4: TestScript.metadata.capability.capabilities additional types (canonical(http://hl7.org/fhir/StructureDefinition/CapabilityStatement)) additional types from child elements (value)

              ShortR4: capabilities additional types
              Comments

              Element TestScript.metadata.capability.capabilities is mapped to FHIR STU3 element TestScript.metadata.capability.capabilities as SourceIsBroaderThanTarget. The mappings for TestScript.metadata.capability.capabilities do not cover the following types: canonical. The mappings for TestScript.metadata.capability.capabilities do not cover the following types based on type expansion: value. The conformance statement of the server has to contain at a minimum the contents of the reference pointed to by this element.

              Control1..1
              TypeExtension(R4: capabilities additional types) (Extension Type: uri(Cross-version Profile for R4.CapabilityStatement for use in FHIR STU3, CapabilityStatement))
              120. TestScript.metadata.capability.capabilities.reference
              Definition

              A reference to a location at which the other resource is found. The reference may be a relative reference, in which case it is relative to the service base URL, or an absolute URL that resolves to the location where the resource is found. The reference may be version specific or not. If the reference is not to a FHIR RESTful server, then it should be assumed to be version specific. Internal fragment references (start with '#') refer to contained resources.

              ShortLiteral reference, Relative, internal or absolute URL
              Comments

              Using absolute URLs provides a stable scalable approach suitable for a cloud/web context, while using relative/logical references provides a flexible approach suitable for use when trading across closed eco-system boundaries. Absolute URLs do not need to point to a FHIR RESTful server, though this is the preferred approach. If the URL conforms to the structure "/[type]/[id]" then it should be assumed that the reference is to a FHIR RESTful server.

              Control0..1
              This element is affected by the following invariants: ref-1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              Summarytrue
              122. TestScript.metadata.capability.capabilities.identifier
              Definition

              An identifier for the other resource. This is used when there is no way to reference the other resource directly, either because the entity is not available through a FHIR server, or because there is no way for the author of the resource to convert a known identifier to an actual location. There is no requirement that a Reference.identifier point to something that is actually exposed as a FHIR instance, but it SHALL point to a business concept that would be expected to be exposed as a FHIR instance, and that instance would need to be of a FHIR resource type allowed by the reference.

              ShortLogical reference, when literal reference is not known
              Comments

              When an identifier is provided in place of a reference, any system processing the reference will only be able to resolve the identifier to a reference if it understands the business context in which the identifier is used. Sometimes this is global (e.g. a national identifier) but often it is not. For this reason, none of the useful mechanisms described for working with references (e.g. chaining, includes) are possible, nor should servers be expected to be able resolve the reference. Servers may accept an identifier based reference untouched, resolve it, and/or reject it - see CapabilityStatement.rest.resource.referencePolicy.

              When both an identifier and a literal reference are provided, the literal reference is preferred. Applications processing the resource are allowed - but not required - to check that the identifier matches the literal reference

              Applications converting a logical reference to a literal reference may choose to leave the logical reference present, or remove it.

              NoteThis is a business identifier, not a resource identifier (see discussion)
              Control0..1
              TypeIdentifier
              Summarytrue
              124. TestScript.metadata.capability.capabilities.display
              Definition

              Plain text narrative that identifies the resource in addition to the resource reference.

              ShortText alternative for the resource
              Comments

              This is generally not the same as the Resource.text of the referenced resource. The purpose is to identify what's being referenced, not to fully describe it.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              Summarytrue
              126. TestScript.fixture
              Definition

              Fixture in the test script - by reference (uri). All fixtures are required for the test script to execute.

              ShortFixture in the test script - by reference (uri)
              Control0..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              128. TestScript.fixture.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              130. TestScript.fixture.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              132. TestScript.fixture.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              134. TestScript.fixture.autocreate
              Definition

              Whether or not to implicitly create the fixture during setup. If true, the fixture is automatically created on each server being tested during setup, therefore no create operation is required for this fixture in the TestScript.setup section.

              ShortWhether or not to implicitly create the fixture during setup
              Control0..1
              Typeboolean
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              Default Valuefalse
              136. TestScript.fixture.autodelete
              Definition

              Whether or not to implicitly delete the fixture during teardown. If true, the fixture is automatically deleted on each server being tested during teardown, therefore no delete operation is required for this fixture in the TestScript.teardown section.

              ShortWhether or not to implicitly delete the fixture during teardown
              Control0..1
              Typeboolean
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              Default Valuefalse
              138. TestScript.fixture.resource
              Definition

              Reference to the resource (containing the contents of the resource needed for operations).

              ShortReference of the resource
              Comments

              See http://hl7.org/fhir/STU3/resourcelist.html for complete list of resource types.

              Control0..1
              TypeReference(Resource)
              140. TestScript.profile
              Definition

              Reference to the profile to be used for validation.

              ShortReference of the validation profile
              Comments

              See http://hl7.org/fhir/STU3/resourcelist.html for complete list of resource types.

              Control0..*
              TypeReference(Resource)
              142. TestScript.variable
              Definition

              Variable is set based either on element value in response body or on header field value in the response headers.

              ShortPlaceholder for evaluated elements
              Comments

              Variables would be set based either on XPath/JSONPath expressions against fixtures (static and response), or headerField evaluations against response headers. If variable evaluates to nodelist or anything other than a primitive value, then test engine would report an error. Variables would be used to perform clean replacements in "operation.params", "operation.requestHeader.value", and "operation.url" element values during operation calls and in "assert.value" during assertion evaluations. This limits the places that test engines would need to look for placeholders "${}". Variables are scoped to the whole script. They are NOT evaluated at declaration. They are evaluated by test engine when used for substitutions in "operation.params", "operation.requestHeader.value", and "operation.url" element values during operation calls and in "assert.value" during assertion evaluations. See example testscript-search.xml.

              Control0..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              inv-3: Variable can only contain one of expression, headerField or path. (expression.empty() or headerField.empty() or path.empty())
              144. TestScript.variable.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              146. TestScript.variable.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              148. TestScript.variable.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              150. TestScript.variable.name
              Definition

              Descriptive name for this variable.

              ShortDescriptive name for this variable
              Comments

              Placeholders would contain the variable name wrapped in ${} in "operation.params", "operation.requestHeader.value", and "operation.url" elements. These placeholders would need to be replaced by the variable value before the operation is executed.

              Control1..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              152. TestScript.variable.defaultValue
              Definition

              A default, hard-coded, or user-defined value for this variable.

              ShortDefault, hard-coded, or user-defined value for this variable
              Comments

              The purpose of this element is to allow for a pre-defined value that can be used as a default or as an override value. Test engines can optionally use this as a placeholder for user-defined execution time values.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              154. TestScript.variable.description
              Definition

              A free text natural language description of the variable and its purpose.

              ShortNatural language description of the variable
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              156. TestScript.variable.expression
              Definition

              The fluentpath expression to evaluate against the fixture body. When variables are defined, only one of either expression, headerField or path must be specified.

              ShortThe fluentpath expression against the fixture body
              Comments

              If headerField is defined, then the variable will be evaluated against the headers that sourceId is pointing to. If expression or path is defined, then the variable will be evaluated against the fixture body that sourceId is pointing to. It is an error to define any combination of expression, headerField and path.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              158. TestScript.variable.headerField
              Definition

              Will be used to grab the HTTP header field value from the headers that sourceId is pointing to.

              ShortHTTP header field name for source
              Comments

              If headerField is defined, then the variable will be evaluated against the headers that sourceId is pointing to. If path is defined, then the variable will be evaluated against the fixture body that sourceId is pointing to. It is an error to define both headerField and path.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              160. TestScript.variable.hint
              Definition

              Displayable text string with hint help information to the user when entering a default value.

              ShortHint help text for default value to enter
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              162. TestScript.variable.path
              Definition

              XPath or JSONPath to evaluate against the fixture body. When variables are defined, only one of either expression, headerField or path must be specified.

              ShortXPath or JSONPath against the fixture body
              Comments

              If headerField is defined, then the variable will be evaluated against the headers that sourceId is pointing to. If expression or path is defined, then the variable will be evaluated against the fixture body that sourceId is pointing to. It is an error to define any combination of expression, headerField and path.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              164. TestScript.variable.sourceId
              Definition

              Fixture to evaluate the XPath/JSONPath expression or the headerField against within this variable.

              ShortFixture Id of source expression or headerField within this variable
              Comments

              This can be a statically defined fixture (at the top of the TestScript) or a dynamically set fixture created by responseId of the action.operation element.

              Control0..1
              Typeid
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              166. TestScript.rule
              Definition

              Assert rule to be used in one or more asserts within the test script.

              ShortAssert rule used within the test script
              Comments

              Each rule should be treated by test engines as one assertion regardless of how many assertions are contained within the external rule template. The impact of negative rule evaluation on test script execution is the same as an assertion failure which is described elsewhere in the TestScript resource.

              Control0..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              168. TestScript.rule.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              170. TestScript.rule.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              172. TestScript.rule.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              174. TestScript.rule.resource
              Definition

              Reference to the resource (containing the contents of the rule needed for assertions).

              ShortAssert rule resource reference
              Control1..1
              TypeReference(Resource)
              176. TestScript.rule.param
              Definition

              Each rule template can take one or more parameters for rule evaluation.

              ShortRule parameter template
              Comments

              The parameter value can be dynamic at runtime.

              Control0..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              178. TestScript.rule.param.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              180. TestScript.rule.param.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              182. TestScript.rule.param.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              184. TestScript.rule.param.name
              Definition

              Descriptive name for this parameter that matches the external assert rule parameter name.

              ShortParameter name matching external assert rule parameter
              Comments

              The external rule template would be looking for the parameter by this name.

              Control1..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              186. TestScript.rule.param.value
              Definition

              The explicit or dynamic value for the parameter that will be passed on to the external rule template.

              ShortParameter value defined either explicitly or dynamically
              Comments

              This value can be overwritten by the assert.rule.param.value i.e. TestScript.rule.param.value will be used if assert.rule.param.value is not specified. The param value can be a string-representation of a number, string, or boolean that is expected. Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before supplying this value to the external rule template.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              188. TestScript.ruleset
              Definition

              Contains one or more rules. Offers a way to group rules so assertions could reference the group of rules and have them all applied.

              ShortAssert ruleset used within the test script
              Comments

              Each rule within a ruleset should be treated by test engines as one assertion regardless of how many assertions are contained within the external rule template. The impact of negative rule evaluation on test script execution is the same as an assertion failure which is described elsewhere in the TestScript resource.

              Control0..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              190. TestScript.ruleset.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              192. TestScript.ruleset.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              194. TestScript.ruleset.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              196. TestScript.ruleset.resource
              Definition

              Reference to the resource (containing the contents of the ruleset needed for assertions).

              ShortAssert ruleset resource reference
              Control1..1
              TypeReference(Resource)
              198. TestScript.ruleset.rule
              Definition

              The referenced rule within the external ruleset template.

              ShortThe referenced rule within the ruleset
              Comments

              This qualifies each param name so that a parameter with the same name can be used differently by the different rules with the ruleset.

              Control1..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              200. TestScript.ruleset.rule.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              202. TestScript.ruleset.rule.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              204. TestScript.ruleset.rule.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              206. TestScript.ruleset.rule.ruleId
              Definition

              Id of the referenced rule within the external ruleset template.

              ShortId of referenced rule within the ruleset
              Control1..1
              Typeid
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              208. TestScript.ruleset.rule.param
              Definition

              Each rule template can take one or more parameters for rule evaluation.

              ShortRuleset rule parameter template
              Comments

              The parameter value can be dynamic at runtime.

              Control0..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              210. TestScript.ruleset.rule.param.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              212. TestScript.ruleset.rule.param.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              214. TestScript.ruleset.rule.param.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              216. TestScript.ruleset.rule.param.name
              Definition

              Descriptive name for this parameter that matches the external assert ruleset rule parameter name.

              ShortParameter name matching external assert ruleset rule parameter
              Comments

              The external rule template would be looking for the parameter by this name.

              Control1..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              218. TestScript.ruleset.rule.param.value
              Definition

              The value for the parameter that will be passed on to the external ruleset rule template.

              ShortParameter value defined either explicitly or dynamically
              Comments

              This value can be overwritten by the assert.ruleset.rule.param.value i.e. TestScript.ruleset.rule.param.value will be used if assert.ruleset.rule.param.value is not specified. The param value can be a string-representation of a number, string, or boolean that is expected. Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before supplying this value to the external rule template.

              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              220. TestScript.setup
              Definition

              A series of required setup operations before tests are executed.

              ShortA series of required setup operations before tests are executed
              Control0..1
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              222. TestScript.setup.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              224. TestScript.setup.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              226. TestScript.setup.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              228. TestScript.setup.action
              Definition

              Action would contain either an operation or an assertion.

              ShortA setup operation or assert to perform
              Comments

              An action should contain either an operation or an assertion but not both. It can contain any number of variables.

              Control1..*
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              inv-1: Setup action SHALL contain either an operation or assert but not both. (operation.exists() xor assert.exists())
              230. TestScript.setup.action.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              232. TestScript.setup.action.extension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

              ShortAdditional Content defined by implementations
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Alternate Namesextensions, user content
              234. TestScript.setup.action.modifierExtension
              Definition

              May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

              ShortExtensions that cannot be ignored
              Comments

              There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

              Control0..*
              TypeExtension
              Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
              Summarytrue
              Alternate Namesextensions, user content, modifiers
              236. TestScript.setup.action.operation
              Definition

              The operation to perform.

              ShortThe setup operation to perform
              Control0..1
              TypeBackboneElement
              Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
              inv-7: Setup operation SHALL contain either sourceId or targetId or params or url. (sourceId.exists() or (targetId.count() + url.count() + params.count() = 1) or (type.code in ('capabilities' |'search' | 'transaction' | 'history')))
              238. TestScript.setup.action.operation.id
              Definition

              unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

              Shortxml:id (or equivalent in JSON)
              Control0..1
              Typestring
              Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
              XML FormatIn the XML format, this property is represented as an attribute.
              240. TestScript.setup.action.operation.extension
              Definition

              An Extension

              ShortExtension
              Control0..*
              TypeExtension
              SlicingThis element introduces a set of slices on TestScript.setup.action.operation.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
              • value @ url
              • 242. TestScript.setup.action.operation.extension:method
                Slice Namemethod
                Definition

                R4: TestScript.setup.action.operation.method (new:code)

                ShortR4: delete | get | options | patch | post | put | head (new)
                Comments

                Element TestScript.setup.action.operation.method has a context of TestScript.setup.action.operation based on following the parent source element upwards and mapping to TestScript. Element TestScript.setup.action.operation.method has no mapping targets in FHIR STU3. Typically, this is because the element has been added (is a new element). The primary purpose of the explicit HTTP method is support of HTTP POST method invocation of the FHIR search. Other uses will include support of negative testing.

                Control0..1
                This element is affected by the following invariants: ele-1
                TypeExtension(R4: delete | get | options | patch | post | put | head (new)) (Extension Type: code)
                Is Modifierfalse
                Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists())
                244. TestScript.setup.action.operation.modifierExtension
                Definition

                May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                ShortExtensions that cannot be ignored
                Comments

                There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                Control0..*
                TypeExtension
                Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                Summarytrue
                Alternate Namesextensions, user content, modifiers
                246. TestScript.setup.action.operation.type
                Definition

                Server interaction or operation type.

                ShortThe operation code type that will be executed
                Comments

                See http://hl7.org/fhir/STU3/http.html for list of server interactions.

                Control0..1
                BindingUnless not suitable, these codes SHALL be taken from TestScriptOperationCode .
                (extensible to http://hl7.org/fhir/ValueSet/testscript-operation-codes|3.0.2)

                The allowable operation code types.

                TypeCoding
                248. TestScript.setup.action.operation.resource
                Definition

                The type of the resource. See http://hl7.org/fhir/STU3/resourcelist.html.

                ShortResource type
                Comments

                If "url" element is specified, then "targetId", "params", and "resource" elements will be ignored as "url" element will have everything needed for constructing the request url. If "params" element is specified, then "targetId" element is ignored. For FHIR operations that require a resource (e.g. "read" and "vread" operations), the "resource" element must be specified when "params" element is specified. If "url" and "params" elements are absent, then the request url will be constructed from "targetId" fixture if present. For "read" operation, the resource and id values will be extracted from "targetId" fixture and used to construct the url. For "vread" and "history" operations, the versionId value will also be used.

                Control0..1
                BindingThe codes SHALL be taken from FHIRDefinedType .
                (required to http://hl7.org/fhir/ValueSet/defined-types|3.0.2)

                Either a resource or a data type.

                Typecode
                Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                250. TestScript.setup.action.operation.resource.id
                Definition

                unique id for the element within a resource (for internal references)

                Shortxml:id (or equivalent in JSON)
                Control0..1
                Typestring
                Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                XML FormatIn the XML format, this property is represented as an attribute.
                252. TestScript.setup.action.operation.resource.extension
                Definition

                An Extension

                ShortExtension
                Control0..*
                TypeExtension
                SlicingThis element introduces a set of slices on TestScript.setup.action.operation.resource.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
                • value @ url
                • 254. TestScript.setup.action.operation.resource.extension:resource
                  Slice Nameresource
                  Definition

                  R4: TestScript.setup.action.operation.resource

                  ShortR4: resource
                  Comments

                  Element TestScript.setup.action.operation.resource is mapped to FHIR STU3 element TestScript.setup.action.operation.resource as SourceIsBroaderThanTarget. If "url" element is specified, then "targetId", "params", and "resource" elements will be ignored as "url" element will have everything needed for constructing the request url. If "params" element is specified, then "targetId" element is ignored. For FHIR operations that require a resource (e.g. "read" and "vread" operations), the "resource" element must be specified when "params" element is specified. If "url" and "params" elements are absent, then the request url will be constructed from "targetId" fixture if present. For "read" operation, the resource and id values will be extracted from "targetId" fixture and used to construct the url. For "vread" and "history" operations, the versionId value will also be used.

                  Control0..1
                  This element is affected by the following invariants: ele-1
                  TypeExtension(R4: resource) (Extension Type: code)
                  Is Modifierfalse
                  Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                  ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists())
                  256. TestScript.setup.action.operation.resource.value
                  Definition

                  Primitive value for code

                  ShortPrimitive value for code
                  Control0..1
                  Typecode
                  XML FormatIn the XML format, this property is represented as an attribute.
                  258. TestScript.setup.action.operation.label
                  Definition

                  The label would be used for tracking/logging purposes by test engines.

                  ShortTracking/logging operation label
                  Comments

                  This has no impact on the verification itself.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  260. TestScript.setup.action.operation.description
                  Definition

                  The description would be used by test engines for tracking and reporting purposes.

                  ShortTracking/reporting operation description
                  Comments

                  This has no impact on the verification itself.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  262. TestScript.setup.action.operation.accept
                  Definition

                  The content-type or mime-type to use for RESTful operation in the 'Accept' header.

                  Shortxml | json | ttl | none
                  Comments

                  If this is specified, then test engine shall set the 'Accept' header to the corresponding value. If 'xml' is specified, then 'Accept' header of 'application/fhir+xml' will be set. If 'json' is specified, then 'application/fhir+json' will be used. If you'd like to explicitly set the 'Accept' to some other value then use the 'requestHeader' element.

                  Control0..1
                  BindingThe codes SHALL be taken from ContentType
                  (required to http://hl7.org/fhir/ValueSet/content-type|3.0.2)

                  The content or mime type.

                  Typecode
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  Meaning if Missingxml
                  264. TestScript.setup.action.operation.contentType
                  Definition

                  The content-type or mime-type to use for RESTful operation in the 'Content-Type' header.

                  Shortxml | json | ttl | none
                  Comments

                  If this is specified, then test engine shall set the 'Content-Type' header to the corresponding value. If 'xml' is specified, then 'Content-Type' header of 'application/fhir+xml' will be set. If 'json' is specified, then 'application/fhir+json' will be used. If you'd like to explicitly set the 'Content-Type' to some other value then use the 'requestHeader' element.

                  Control0..1
                  BindingThe codes SHALL be taken from ContentType
                  (required to http://hl7.org/fhir/ValueSet/content-type|3.0.2)

                  The content or mime type.

                  Typecode
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  Meaning if Missingxml
                  266. TestScript.setup.action.operation.destination
                  Definition

                  The server where the request message is destined for. Must be one of the server numbers listed in TestScript.destination section.

                  ShortServer responding to the request
                  Comments

                  If multiple TestScript.destination elements are defined and operation.destination is undefined, test engine will report an error as it cannot determine what destination to use for the exchange.

                  Control0..1
                  Typeinteger
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  268. TestScript.setup.action.operation.encodeRequestUrl
                  Definition

                  Whether or not to implicitly send the request url in encoded format. The default is true to match the standard RESTful client behavior. Set to false when communicating with a server that does not support encoded url paths.

                  ShortWhether or not to send the request url in encoded format
                  Control0..1
                  Typeboolean
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  Default Valuetrue
                  270. TestScript.setup.action.operation.origin
                  Definition

                  The server where the request message originates from. Must be one of the server numbers listed in TestScript.origin section.

                  ShortServer initiating the request
                  Comments

                  If absent, test engine will send the message. When present, test engine will not send the request message but will wait for the request message to be sent from this origin server.

                  Control0..1
                  Typeinteger
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  272. TestScript.setup.action.operation.params
                  Definition

                  Path plus parameters after [type]. Used to set parts of the request URL explicitly.

                  ShortExplicitly defined path parameters
                  Comments

                  If "url" element is specified, then "targetId", "params", and "resource" elements will be ignored as "url" element will have everything needed for constructing the request url. If "params" element is specified, then "targetId" element is ignored. For FHIR operations that require a resource (e.g. "read" and "vread" operations), the "resource" element must be specified when "params" element is specified. If "url" and "params" elements are absent, then the request url will be constructed from "targetId" fixture if present. For "read" operation, the resource and id values will be extracted from "targetId" fixture and used to construct the url. For "vread" and "history" operations, the versionId value will also be used. Test engines would append whatever is specified for "params" to the URL after the resource type without tampering with the string (beyond encoding the URL for HTTP). The "params" element does not correspond exactly to "search parameters". Nor is it the "path". It corresponds to the part of the URL that comes after the [type] (when "resource" element is specified); e.g. It corresponds to "/[id]/history/[vid] {?format=[mime-type]}" in the following operation: GET [base]/[type]/[id]/history/[vid] {?format=[mime-type]} Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before sending the request.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  274. TestScript.setup.action.operation.requestHeader
                  Definition

                  Header elements would be used to set HTTP headers.

                  ShortEach operation can have one or more header elements
                  Comments

                  This gives control to test-script writers to set headers explicitly based on test requirements. It will allow for testing using: - "If-Modified-Since" and "If-None-Match" headers. See http://hl7.org/fhir/STU3/http.html#2.1.0.5.1 - "If-Match" header. See http://hl7.org/fhir/STU3/http.html#2.1.0.11 - Conditional Create using "If-None-Exist". See http://hl7.org/fhir/STU3/http.html#2.1.0.13.1 - Invalid "Content-Type" header for negative testing. - etc.

                  Control0..*
                  TypeBackboneElement
                  Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                  276. TestScript.setup.action.operation.requestHeader.id
                  Definition

                  unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                  Shortxml:id (or equivalent in JSON)
                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  XML FormatIn the XML format, this property is represented as an attribute.
                  278. TestScript.setup.action.operation.requestHeader.extension
                  Definition

                  May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                  ShortAdditional Content defined by implementations
                  Comments

                  There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                  Control0..*
                  TypeExtension
                  Alternate Namesextensions, user content
                  280. TestScript.setup.action.operation.requestHeader.modifierExtension
                  Definition

                  May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                  ShortExtensions that cannot be ignored
                  Comments

                  There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                  Control0..*
                  TypeExtension
                  Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                  Summarytrue
                  Alternate Namesextensions, user content, modifiers
                  282. TestScript.setup.action.operation.requestHeader.field
                  Definition

                  The HTTP header field e.g. "Accept".

                  ShortHTTP header field name
                  Comments

                  If header element is specified, then field is required.

                  Control1..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  284. TestScript.setup.action.operation.requestHeader.value
                  Definition

                  The value of the header e.g. "application/fhir+xml".

                  ShortHTTP headerfield value
                  Comments

                  If header element is specified, then value is required. No conversions will be done by the test engine e.g. "xml" to "application/fhir+xml". The values will be set in HTTP headers "as-is". Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before sending the request.

                  Control1..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  286. TestScript.setup.action.operation.requestId
                  Definition

                  The fixture id (maybe new) to map to the request.

                  ShortFixture Id of mapped request
                  Comments

                  If a requestId is supplied, then the resulting request (both headers and body) is mapped to the fixture ID (which may be entirely new and previously undeclared) designated by "requestId". If requestId is not specified, it is the test engine's responsibility to store the request and use it as the requestId in subsequent assertions when assertion path and/or headerField is specified, direction is equal to request, and the requestId in not specified.

                  Control0..1
                  Typeid
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  288. TestScript.setup.action.operation.responseId
                  Definition

                  The fixture id (maybe new) to map to the response.

                  ShortFixture Id of mapped response
                  Comments

                  If a responseId is supplied, and the server responds, then the resulting response (both headers and body) is mapped to the fixture ID (which may be entirely new and previously undeclared) designated by "responseId". If responseId is not specified, it is the test engine's responsibility to store the response and use it as the responseId in subsequent assertions when assertion path and/or headerField is specified and the responseId is not specified.

                  Control0..1
                  Typeid
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  290. TestScript.setup.action.operation.sourceId
                  Definition

                  The id of the fixture used as the body of a PUT or POST request.

                  ShortFixture Id of body for PUT and POST requests
                  Control0..1
                  Typeid
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  292. TestScript.setup.action.operation.targetId
                  Definition

                  Id of fixture used for extracting the [id], [type], and [vid] for GET requests.

                  ShortId of fixture used for extracting the [id], [type], and [vid] for GET requests
                  Comments

                  If "url" element is specified, then "targetId", "params", and "resource" elements will be ignored as "url" element will have everything needed for constructing the request url. If "params" element is specified, then "targetId" element is ignored. For FHIR operations that require a resource (e.g. "read" and "vread" operations), the "resource" element must be specified when "params" element is specified. If "url" and "params" elements are absent, then the request url will be constructed from "targetId" fixture if present. For "read" operation, the resource and id values will be extracted from "targetId" fixture and used to construct the url. For "vread" and "history" operations, the versionId value will also be used.

                  Control0..1
                  Typeid
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  294. TestScript.setup.action.operation.url
                  Definition

                  Complete request URL.

                  ShortRequest URL
                  Comments

                  Used to set the request URL explicitly. If "url" element is defined, then "targetId", "resource", and "params" elements will be ignored. Test engines would use whatever is specified in "url" without tampering with the string (beyond encoding the URL for HTTP). Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before sending the request.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  296. TestScript.setup.action.assert
                  Definition

                  Evaluates the results of previous operations to determine if the server under test behaves appropriately.

                  ShortThe assertion to perform
                  Comments

                  In order to evaluate an assertion, the request, response, and results of the most recently executed operation must always be maintained by the test engine.

                  Control0..1
                  TypeBackboneElement
                  Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                  inv-5: Only a single assertion SHALL be present within setup action assert element. (contentType.count() + expression.count() + headerField.count() + minimumId.count() + navigationLinks.count() + path.count() + requestMethod.count() + resource.count() + responseCode.count() + response.count() + rule.count() + ruleset.count() + validateProfileId.count() <=1)
                  inv-10: Setup action assert SHALL contain either compareToSourceId and compareToSourceExpression, compareToSourceId and compareToSourcePath or neither. (compareToSourceId.empty() xor (compareToSourceExpression.exists() or compareToSourcePath.exists()))
                  inv-12: Setup action assert response and responseCode SHALL be empty when direction equals request ((response.empty() and responseCode.empty() and direction = 'request') or direction.empty() or direction = 'response')
                  298. TestScript.setup.action.assert.id
                  Definition

                  unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                  Shortxml:id (or equivalent in JSON)
                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  XML FormatIn the XML format, this property is represented as an attribute.
                  300. TestScript.setup.action.assert.extension
                  Definition

                  May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                  ShortAdditional Content defined by implementations
                  Comments

                  There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                  Control0..*
                  TypeExtension
                  Alternate Namesextensions, user content
                  302. TestScript.setup.action.assert.modifierExtension
                  Definition

                  May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                  ShortExtensions that cannot be ignored
                  Comments

                  There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                  Control0..*
                  TypeExtension
                  Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                  Summarytrue
                  Alternate Namesextensions, user content, modifiers
                  304. TestScript.setup.action.assert.label
                  Definition

                  The label would be used for tracking/logging purposes by test engines.

                  ShortTracking/logging assertion label
                  Comments

                  This has no impact on the verification itself.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  306. TestScript.setup.action.assert.description
                  Definition

                  The description would be used by test engines for tracking and reporting purposes.

                  ShortTracking/reporting assertion description
                  Comments

                  This has no impact on the verification itself.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  308. TestScript.setup.action.assert.direction
                  Definition

                  The direction to use for the assertion.

                  Shortresponse | request
                  Comments

                  If the direction is specified as "response" (the default), then the processing of this assert is against the received response message. If the direction is specified as "request", then the processing of this assert is against the sent request message.

                  Control0..1
                  BindingThe codes SHALL be taken from AssertionDirectionType
                  (required to http://hl7.org/fhir/ValueSet/assert-direction-codes|3.0.2)

                  The type of direction to use for assertion.

                  Typecode
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  310. TestScript.setup.action.assert.compareToSourceId
                  Definition

                  Id of the source fixture used as the contents to be evaluated by either the "source/expression" or "sourceId/path" definition.

                  ShortId of the source fixture to be evaluated
                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  312. TestScript.setup.action.assert.compareToSourceExpression
                  Definition

                  The fluentpath expression to evaluate against the source fixture. When compareToSourceId is defined, either compareToSourceExpression or compareToSourcePath must be defined, but not both.

                  ShortThe fluentpath expression to evaluate against the source fixture
                  Comments

                  Thefhirpath expression to be evaluated against the expected fixture to compare to. Ignored if "assert.value" is used. The evaluation will be done before the assertion is evaluated.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  314. TestScript.setup.action.assert.compareToSourcePath
                  Definition

                  XPath or JSONPath expression to evaluate against the source fixture. When compareToSourceId is defined, either compareToSourceExpression or compareToSourcePath must be defined, but not both.

                  ShortXPath or JSONPath expression to evaluate against the source fixture
                  Comments

                  The XPath or JSONPath expression to be evaluated against the expected fixture to compare to. Ignored if "assert.value" is used. The evaluation will be done before the assertion is evaluated.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  316. TestScript.setup.action.assert.contentType
                  Definition

                  The content-type or mime-type to use for RESTful operation in the 'Content-Type' header.

                  Shortxml | json | ttl | none
                  Comments

                  If this is specified, then test engine shall confirm that the content-type of the last operation's headers is set to this value. If "assert.sourceId" element is specified, then the evaluation will be done against the headers mapped to that sourceId (and not the last operation's headers). If 'xml' is specified, then 'Content-Type' header of 'application/fhir+xml' will be confirmed. If 'json' is specified, then 'application/fhir+json' will be used. If you'd like to have more control over the string, then use 'assert.headerField' instead.

                  Control0..1
                  BindingThe codes SHALL be taken from ContentType
                  (required to http://hl7.org/fhir/ValueSet/content-type|3.0.2)

                  The content or mime type.

                  Typecode
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  Meaning if Missingxml
                  318. TestScript.setup.action.assert.expression
                  Definition

                  The fluentpath expression to be evaluated against the request or response message contents - HTTP headers and payload.

                  ShortThe fluentpath expression to be evaluated
                  Comments

                  If both "expression" and a "fixtureId" are specified, then the expression will be evaluated against the request or response body mapped to the fixtureId. If "expression" is specified and a "fixtureId" is not, then the expression will be evaluated against the response body of the last operation. Test engines are to store the request and response body and headers of the last operation at all times for subsequent assertions.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  320. TestScript.setup.action.assert.headerField
                  Definition

                  The HTTP header field name e.g. 'Location'.

                  ShortHTTP header field name
                  Comments

                  If "headerField" is specified then "value" must be specified. If "sourceId" is not specified, then "headerField" will be evaluated against the last operation's response headers. Test engines are to keep track of the last operation's response body and response headers.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  322. TestScript.setup.action.assert.minimumId
                  Definition

                  The ID of a fixture. Asserts that the response contains at a minimum the fixture specified by minimumId.

                  ShortFixture Id of minimum content resource
                  Comments

                  Asserts that the response contains all the element/content in another fixture pointed to by minimumId. This can be a statically defined fixture or one that is dynamically set via responseId.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  324. TestScript.setup.action.assert.navigationLinks
                  Definition

                  Whether or not the test execution performs validation on the bundle navigation links.

                  ShortPerform validation on navigation links?
                  Comments

                  Asserts that the Bundle contains first, last, and next links.

                  Control0..1
                  Typeboolean
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  326. TestScript.setup.action.assert.operator
                  Definition

                  The operator type defines the conditional behavior of the assert. If not defined, the default is equals.

                  Shortequals | notEquals | in | notIn | greaterThan | lessThan | empty | notEmpty | contains | notContains | eval
                  Comments

                  Operators are useful especially for negative testing. If operator is not specified, then the "equals" operator is assumed; e.g. <code> <assert> <operator value="in" /> <responseCode value="200,201,204" /> </assert> <assert> <operator value="notEquals" /> <response value="okay"/> </assert> <assert> <operator value="greaterThan" /> <responseHeader> <field value="Content-Length" /> <value value="0" /> <responseHeader/> </assert> </code>.

                  Control0..1
                  BindingThe codes SHALL be taken from AssertionOperatorType
                  (required to http://hl7.org/fhir/ValueSet/assert-operator-codes|3.0.2)

                  The type of operator to use for assertion.

                  Typecode
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  328. TestScript.setup.action.assert.path
                  Definition

                  The XPath or JSONPath expression to be evaluated against the fixture representing the response received from server.

                  ShortXPath or JSONPath expression
                  Comments

                  If both "path" and a "fixtureId" are specified, then the path will be evaluated against the request or response body mapped to the fixtureId. If "path" is specified and a "fixtureId" is not, then the path will be evaluated against the response body of the last operation. Test engines are to store the request and response body and headers of the last operation at all times for subsequent assertions.

                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  330. TestScript.setup.action.assert.requestMethod
                  Definition

                  The request method or HTTP operation code to compare against that used by the client system under test.

                  Shortdelete | get | options | patch | post | put
                  Comments

                  If "requestMethod" is specified then it will be used in place of "value". The "requestMethod" will evaluate against the last operation's request HTTP operation.

                  Control0..1
                  BindingThe codes SHALL be taken from TestScriptRequestMethodCode .
                  (required to http://hl7.org/fhir/ValueSet/http-operations|3.0.2)

                  The allowable request method or HTTP operation codes.

                  Typecode
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  332. TestScript.setup.action.assert.requestMethod.id
                  Definition

                  unique id for the element within a resource (for internal references)

                  Shortxml:id (or equivalent in JSON)
                  Control0..1
                  Typestring
                  Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                  XML FormatIn the XML format, this property is represented as an attribute.
                  334. TestScript.setup.action.assert.requestMethod.extension
                  Definition

                  An Extension

                  ShortExtension
                  Control0..*
                  TypeExtension
                  SlicingThis element introduces a set of slices on TestScript.setup.action.assert.requestMethod.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
                  • value @ url
                  • 336. TestScript.setup.action.assert.requestMethod.extension:requestMethod
                    Slice NamerequestMethod
                    Definition

                    R4: TestScript.setup.action.assert.requestMethod

                    ShortR4: delete | get | options | patch | post | put | head
                    Comments

                    Element TestScript.setup.action.assert.requestMethod is mapped to FHIR STU3 element TestScript.setup.action.assert.requestMethod as SourceIsBroaderThanTarget. If "requestMethod" is specified then it will be used in place of "value". The "requestMethod" will evaluate against the last operation's request HTTP operation.

                    Control0..1
                    This element is affected by the following invariants: ele-1
                    TypeExtension(R4: delete | get | options | patch | post | put | head) (Extension Type: code)
                    Is Modifierfalse
                    Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                    ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists())
                    338. TestScript.setup.action.assert.requestMethod.value
                    Definition

                    Primitive value for code

                    ShortPrimitive value for code
                    Control0..1
                    Typecode
                    XML FormatIn the XML format, this property is represented as an attribute.
                    340. TestScript.setup.action.assert.requestURL
                    Definition

                    The value to use in a comparison against the request URL path string.

                    ShortRequest URL comparison value
                    Comments

                    If "requestURL" is specified then it will be used in place of "value". The "requestURL" will evaluate against the last operation's full request URL path string.

                    Control0..1
                    Typestring
                    Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                    342. TestScript.setup.action.assert.resource
                    Definition

                    The type of the resource. See http://hl7.org/fhir/STU3/resourcelist.html.

                    ShortResource type
                    Comments

                    This will be expected resource type in response body e.g. in read, vread, search, etc. See http://hl7.org/fhir/STU3/resourcelist.html for complete list of resource types; e.g. <assert > <resourceType value="Patient" </assert>.

                    Control0..1
                    BindingThe codes SHALL be taken from FHIRDefinedType .
                    (required to http://hl7.org/fhir/ValueSet/defined-types|3.0.2)

                    Either a resource or a data type.

                    Typecode
                    Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                    344. TestScript.setup.action.assert.resource.id
                    Definition

                    unique id for the element within a resource (for internal references)

                    Shortxml:id (or equivalent in JSON)
                    Control0..1
                    Typestring
                    Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                    XML FormatIn the XML format, this property is represented as an attribute.
                    346. TestScript.setup.action.assert.resource.extension
                    Definition

                    An Extension

                    ShortExtension
                    Control0..*
                    TypeExtension
                    SlicingThis element introduces a set of slices on TestScript.setup.action.assert.resource.extension. The slices areUnordered and Open, and can be differentiated using the following discriminators:
                    • value @ url
                    • 348. TestScript.setup.action.assert.resource.extension:resource
                      Slice Nameresource
                      Definition

                      R4: TestScript.setup.action.assert.resource

                      ShortR4: resource
                      Comments

                      Element TestScript.setup.action.assert.resource is mapped to FHIR STU3 element TestScript.setup.action.assert.resource as SourceIsBroaderThanTarget. This will be expected resource type in response body e.g. in read, vread, search, etc. See http://build.fhir.org/resourcelist.html for complete list of resource types; e.g. <assert > <resourceType value="Patient" </assert>.

                      Control0..1
                      This element is affected by the following invariants: ele-1
                      TypeExtension(R4: resource) (Extension Type: code)
                      Is Modifierfalse
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      ext-1: Must have either extensions or value[x], not both (extension.exists() != value.exists())
                      350. TestScript.setup.action.assert.resource.value
                      Definition

                      Primitive value for code

                      ShortPrimitive value for code
                      Control0..1
                      Typecode
                      XML FormatIn the XML format, this property is represented as an attribute.
                      352. TestScript.setup.action.assert.response
                      Definition

                      okay | created | noContent | notModified | bad | forbidden | notFound | methodNotAllowed | conflict | gone | preconditionFailed | unprocessable.

                      Shortokay | created | noContent | notModified | bad | forbidden | notFound | methodNotAllowed | conflict | gone | preconditionFailed | unprocessable
                      Comments

                      This is a shorter way of achieving similar verifications via "assert.responseCode". If you need more control, then use "assert.responseCode" e.g. <assert> <contentType value="json" /> <response value="okay"/> </assert>.

                      Control0..1
                      BindingThe codes SHALL be taken from AssertionResponseTypes
                      (required to http://hl7.org/fhir/ValueSet/assert-response-code-types|3.0.2)

                      The type of response code to use for assertion.

                      Typecode
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      354. TestScript.setup.action.assert.responseCode
                      Definition

                      The value of the HTTP response code to be tested.

                      ShortHTTP response code to test
                      Comments

                      To be used with "operator" attribute value. Asserts that the response code equals this value if "operator" is not specified. If the operator is "in" or "notIn" then the responseCode would be a comma-separated list of values e.g. "200,201". Otherwise, it's expected to be a numeric value. If "fixture" is not specified, then the "responseBodyId" value of the last operation is assumed.

                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      356. TestScript.setup.action.assert.rule
                      Definition

                      The TestScript.rule this assert will evaluate.

                      ShortThe reference to a TestScript.rule
                      Comments

                      Each rule should get evaluated by test engines as one assertion regardless of how many assertions are contained within the external rule template. The impact of negative rule evaluation on test script execution is the same as an assertion failure which is descibed elsewhere in the TestScript resource.

                      Control0..1
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      358. TestScript.setup.action.assert.rule.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      360. TestScript.setup.action.assert.rule.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      362. TestScript.setup.action.assert.rule.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      364. TestScript.setup.action.assert.rule.ruleId
                      Definition

                      The TestScript.rule id value this assert will evaluate.

                      ShortId of the TestScript.rule
                      Control1..1
                      Typeid
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      366. TestScript.setup.action.assert.rule.param
                      Definition

                      Each rule template can take one or more parameters for rule evaluation.

                      ShortRule parameter template
                      Comments

                      The parameter value can be dynamic at runtime.

                      Control0..*
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      368. TestScript.setup.action.assert.rule.param.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      370. TestScript.setup.action.assert.rule.param.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      372. TestScript.setup.action.assert.rule.param.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      374. TestScript.setup.action.assert.rule.param.name
                      Definition

                      Descriptive name for this parameter that matches the external assert rule parameter name.

                      ShortParameter name matching external assert rule parameter
                      Comments

                      The external rule template would be looking for the parameter by this name.

                      Control1..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      376. TestScript.setup.action.assert.rule.param.value
                      Definition

                      The value for the parameter that will be passed on to the external rule template.

                      ShortParameter value defined either explicitly or dynamically
                      Comments

                      This value overwrites the value (if any) specified in TestScript.rule.param.value. The param value can be a string-representation of a number, string, or boolean that is expected. Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before supplying this value to the external rule template.

                      Control1..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      378. TestScript.setup.action.assert.ruleset
                      Definition

                      The TestScript.ruleset this assert will evaluate.

                      ShortThe reference to a TestScript.ruleset
                      Comments

                      Each rule within a ruleset should get evaluated by test engines as a separate assertion. The impact of negative rule evaluation on test script execution is the same as an assertion failure which is descibed elsewhere in the TestScript resource. If the first rule within the ruleset results in a failed assertion, then test engines do not have to evaluate the rest of the rules within the ruleset.

                      Control0..1
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      380. TestScript.setup.action.assert.ruleset.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      382. TestScript.setup.action.assert.ruleset.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      384. TestScript.setup.action.assert.ruleset.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      386. TestScript.setup.action.assert.ruleset.rulesetId
                      Definition

                      The TestScript.ruleset id value this assert will evaluate.

                      ShortId of the TestScript.ruleset
                      Control1..1
                      Typeid
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      388. TestScript.setup.action.assert.ruleset.rule
                      Definition

                      The referenced rule within the external ruleset template.

                      ShortThe referenced rule within the ruleset
                      Comments

                      This qualifies each param name so that a parameter with the same name can be used differently by the different rules with the ruleset.

                      Control0..*
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      390. TestScript.setup.action.assert.ruleset.rule.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      392. TestScript.setup.action.assert.ruleset.rule.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      394. TestScript.setup.action.assert.ruleset.rule.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      396. TestScript.setup.action.assert.ruleset.rule.ruleId
                      Definition

                      Id of the referenced rule within the external ruleset template.

                      ShortId of referenced rule within the ruleset
                      Control1..1
                      Typeid
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      398. TestScript.setup.action.assert.ruleset.rule.param
                      Definition

                      Each rule template can take one or more parameters for rule evaluation.

                      ShortRule parameter template
                      Comments

                      The parameter value can be dynamic at runtime.

                      Control0..*
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      400. TestScript.setup.action.assert.ruleset.rule.param.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      402. TestScript.setup.action.assert.ruleset.rule.param.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      404. TestScript.setup.action.assert.ruleset.rule.param.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      406. TestScript.setup.action.assert.ruleset.rule.param.name
                      Definition

                      Descriptive name for this parameter that matches the external assert ruleset rule parameter name.

                      ShortParameter name matching external assert ruleset rule parameter
                      Comments

                      The external rule template would be looking for the parameter by this name.

                      Control1..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      408. TestScript.setup.action.assert.ruleset.rule.param.value
                      Definition

                      The value for the parameter that will be passed on to the external ruleset rule template.

                      ShortParameter value defined either explicitly or dynamically
                      Comments

                      This value overwrites the value (if any) specified in TestScript.ruleset.rule.param.value. The param value can be a string-representation of a number, string, or boolean that is expected. Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before supplying this value to the external rule template.

                      Control1..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      410. TestScript.setup.action.assert.sourceId
                      Definition

                      Fixture to evaluate the XPath/JSONPath expression or the headerField against.

                      ShortFixture Id of source expression or headerField
                      Comments

                      This can be a statically defined fixture (at the top of the testscript) or a dynamically set fixture created by responseId of the action.operation element.

                      Control0..1
                      Typeid
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      412. TestScript.setup.action.assert.validateProfileId
                      Definition

                      The ID of the Profile to validate against.

                      ShortProfile Id of validation profile reference
                      Comments

                      The ID of a Profile fixture. Asserts that the response is valid according to the Profile specified by validateProfileId.

                      Control0..1
                      Typeid
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      414. TestScript.setup.action.assert.value
                      Definition

                      The value to compare to.

                      ShortThe value to compare to
                      Comments

                      The string-representation of a number, string, or boolean that is expected. Test engines do have to look for placeholders (${}) and replace the variable placeholders with the variable values at runtime before comparing this value to the actual value.

                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      416. TestScript.setup.action.assert.warningOnly
                      Definition

                      Whether or not the test execution will produce a warning only on error for this assert.

                      ShortWill this assert produce a warning only on error?
                      Comments

                      If this element is specified and it is true, then assertion failures can be logged by test engine but should not stop the test script execution from proceeding. There are likely cases where the spec is not clear on what should happen. If the spec says something is optional (maybe a response header for example), but a server doesn’t do it, we could choose to issue a warning.

                      Control0..1
                      Typeboolean
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      Default Valuefalse
                      418. TestScript.test
                      Definition

                      A test in this script.

                      ShortA test in this script
                      Control0..*
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      420. TestScript.test.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      422. TestScript.test.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      424. TestScript.test.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      426. TestScript.test.name
                      Definition

                      The name of this test used for tracking/logging purposes by test engines.

                      ShortTracking/logging name of this test
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      428. TestScript.test.description
                      Definition

                      A short description of the test used by test engines for tracking and reporting purposes.

                      ShortTracking/reporting short description of the test
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      430. TestScript.test.action
                      Definition

                      Action would contain either an operation or an assertion.

                      ShortA test operation or assert to perform
                      Comments

                      An action should contain either an operation or an assertion but not both. It can contain any number of variables.

                      Control1..*
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      inv-2: Test action SHALL contain either an operation or assert but not both. (operation.exists() xor assert.exists())
                      432. TestScript.test.action.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      434. TestScript.test.action.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      436. TestScript.test.action.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      438. TestScript.test.action.operation
                      Definition

                      An operation would involve a REST request to a server.

                      ShortThe setup operation to perform
                      Control0..1
                      TypeSeettp://hl7.org/fhir/StructureDefinition/TestScript#TestScript.setup.action.operation
                      Invariantsinv-8: Test operation SHALL contain either sourceId or targetId or params or url. (sourceId.exists() or (targetId.count() + url.count() + params.count() = 1) or (type.code in ('capabilities' | 'search' | 'transaction' | 'history')))
                      440. TestScript.test.action.assert
                      Definition

                      Evaluates the results of previous operations to determine if the server under test behaves appropriately.

                      ShortThe setup assertion to perform
                      Comments

                      In order to evaluate an assertion, the request, response, and results of the most recently executed operation must always be maintained by the test engine.

                      Control0..1
                      TypeSeettp://hl7.org/fhir/StructureDefinition/TestScript#TestScript.setup.action.assert
                      Invariantsinv-6: Only a single assertion SHALL be present within test action assert element. (contentType.count() + expression.count() + headerField.count() + minimumId.count() + navigationLinks.count() + path.count() + requestMethod.count() + resource.count() + responseCode.count() + response.count() + rule.count() + ruleset.count() + validateProfileId.count() <=1)
                      inv-11: Test action assert SHALL contain either compareToSourceId and compareToSourceExpression, compareToSourceId and compareToSourcePath or neither. (compareToSourceId.empty() xor (compareToSourceExpression.exists() or compareToSourcePath.exists()))
                      inv-13: Test action assert response and response and responseCode SHALL be empty when direction equals request ((response.empty() and responseCode.empty() and direction = 'request') or direction.empty() or direction = 'response')
                      442. TestScript.teardown
                      Definition

                      A series of operations required to clean up after the all the tests are executed (successfully or otherwise).

                      ShortA series of required clean up steps
                      Control0..1
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      444. TestScript.teardown.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      446. TestScript.teardown.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      448. TestScript.teardown.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      450. TestScript.teardown.action
                      Definition

                      The teardown action will only contain an operation.

                      ShortOne or more teardown operations to perform
                      Comments

                      An action should contain either an operation or an assertion but not both. It can contain any number of variables.

                      Control1..*
                      TypeBackboneElement
                      Invariantsele-1: All FHIR elements must have a @value or children (hasValue() | (children().count() > id.count()))
                      452. TestScript.teardown.action.id
                      Definition

                      unique id for the element within a resource (for internal references). This may be any string value that does not contain spaces.

                      Shortxml:id (or equivalent in JSON)
                      Control0..1
                      Typestring
                      Primitive ValueThis primitive element may be present, or absent, or replaced by an extension
                      XML FormatIn the XML format, this property is represented as an attribute.
                      454. TestScript.teardown.action.extension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension.

                      ShortAdditional Content defined by implementations
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Alternate Namesextensions, user content
                      456. TestScript.teardown.action.modifierExtension
                      Definition

                      May be used to represent additional information that is not part of the basic definition of the element, and that modifies the understanding of the element that contains it. Usually modifier elements provide negation or qualification. In order to make the use of extensions safe and manageable, there is a strict set of governance applied to the definition and use of extensions. Though any implementer is allowed to define an extension, there is a set of requirements that SHALL be met as part of the definition of the extension. Applications processing a resource are required to check for modifier extensions.

                      ShortExtensions that cannot be ignored
                      Comments

                      There can be no stigma associated with the use of extensions by any application, project, or standard - regardless of the institution or jurisdiction that uses or defines the extensions. The use of extensions is what allows the FHIR specification to retain a core level of simplicity for everyone.

                      Control0..*
                      TypeExtension
                      Is Modifiertrue because No Modifier Reason provideed in previous versions of FHIR
                      Summarytrue
                      Alternate Namesextensions, user content, modifiers
                      458. TestScript.teardown.action.operation
                      Definition

                      An operation would involve a REST request to a server.

                      ShortThe teardown operation to perform
                      Control1..1
                      TypeSeettp://hl7.org/fhir/StructureDefinition/TestScript#TestScript.setup.action.operation
                      Invariantsinv-9: Teardown operation SHALL contain either sourceId or targetId or params or url. (sourceId.exists() or (targetId.count() + url.count() + params.count() = 1) or (type.code in ('capabilities' | 'search' | 'transaction' | 'history')))