Exec Id: 202207081343145484029078
Start Time: 07/08/2022 01:44:04PM
End Time: 07/08/2022 01:44:04PM
Status: Failed
Duration: 0.722s
Version: 2 Latest: 3
Validator: FHIR 4.0.1
Description: FHIR Server Consent Basic Operation Tests - XML - Client Assigned Resource Id - Create, Delete, History, Read, Search, Update, Vread. Support for referenced resource type Patient, Organization, and RelatedPerson Update, Delete and Search is also required.
Executed By: John Smith
Organization: Aidbox
Origin:
TouchstoneFHIR
Destination:
Aidbox - Aidbox FHIR platformC https://cmpl.aidbox.app/fhir
Test Script: /FHIR4-0-1-Basic/A-C/Consent/Client Assigned Id/Consent-client-id-xml
Interactions
0% passed Pass Fail Warn Other Total
Summary
0 0 0 14 14
delete Consent
0 0 0 1 1
history-instance Consent
0 0 0 1 1
read Consent
0 0 0 2 2
search-type Consent
0 0 0 1 1
update Consent
0 0 0 1 1
updateCreate Consent
0 0 0 1 1
vread Consent
0 0 0 1 1
create Organization
0 0 0 1 1
search-type Organization
0 0 0 1 1
create Patient
0 0 0 1 1
search-type Patient
0 0 0 1 1
create RelatedPerson
0 0 0 1 1
search-type RelatedPerson
0 0 0 1 1

Setup

[hide]Duration: 0.068sStatus: Failed
Error:
Failed to prepare target server for test execution. OAuth2 Token Endpoint not defined for test system 'Aidbox-Aidbox_Mike'.

Tests

Test Name Description Status Duration
Create a new Consent in XML format where the client assigns the resource id. The expected response code is 201 (Created) with a content of either the created Consent resource in XML format, an OperationOutcome resource in XML format or an empty payload.
Read the Consent in XML format created in step 1. The expected response code is 200 (OK) with a content of the found Consent resource in XML format.
Update the Consent created in step 1 in XML format. The expected response code is 200 (OK) with a content of either the updated Consent resource in XML format, an OperationOutcome resource in XML format or an empty payload.
Retrieve the updated Consent instance's history in XML format. The expected response code is 200 (OK) with a Bundle resource in XML format of type history containing the created and updated versions of the Consent.
Retrieve a initially created version of a Consent instance in XML format. The expected response code, if versioning is supported, is 200 (OK) with a content of the updated Consent resource in XML format; if versioning is not supported, a 404 (Not Found) with an OperationOutcome resource in XML format or an empty payload.
Search for Consent resources in XML format with an identifier equal to ${searchParamIdentifier}. The expected response code is 200 (OK) with a Bundle resource in XML format of type history containing the found instances of the Consent.
Delete a Consent instance in XML format. The expected response is either a 200 (OK) with an optional OperationOutcome in XML format or 204 (No Content) and the content is empty; i.e. no content.

Static Fixtures

Id Resource Version Latest Type Contents
resource-create Consent 1 1 XML Raw Resolved
resource-update Consent 1 1 XML Raw Resolved
reference-patient-create Patient 1 1 XML Raw Resolved
reference-organization-create Organization 1 1 XML Raw Resolved
reference-relatedperson-create RelatedPerson 1 1 XML Raw Resolved

Profiles

Id Source Contents
bundle-profile http://hl7.org/fhir/StructureDefinition/Bundle XML JSON  
operationoutcome-profile http://hl7.org/fhir/StructureDefinition/OperationOutcome XML JSON  
resource-profile http://hl7.org/fhir/StructureDefinition/Consent XML JSON  

Variables

Name Definition
createResourceId sourceId: resource-create path: Consent/id
createVersionId sourceId: create-read-response path: Consent/meta/versionId
searchParamIdentifier sourceId: resource-create path: Consent/identifier/value
referencePatientResourceId sourceId: setup-create-patient-search-response path: Bundle/entry[1]/resource/Patient/id
searchReferencePatientIdentifier sourceId: reference-patient-create path: Patient/identifier/value
referenceOrganizationResourceId sourceId: setup-create-organization-search-response path: Bundle/entry[1]/resource/Organization/id
searchReferenceOrganizationIdentifier sourceId: reference-organization-create path: Organization/identifier/value
referenceRelatedPersonResourceId sourceId: setup-create-relatedperson-search-response path: Bundle/entry[1]/resource/RelatedPerson/id
searchReferenceRelatedPersonIdentifier sourceId: reference-relatedperson-create path: RelatedPerson/identifier/value

RuleSets

Id Version Latest Rules
ruleset-versioning-headers 2 2
Id Params Version Latest
assertETagIfSupported
header: 'ETag'
headerExpectedValue
headerOperator: 'notEmpty'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists())'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'versioning'
resource: 'Consent'
4 4
assertLastModifiedIfSupported
header: 'Last-Modified'
headerExpectedValue
headerOperator: 'notEmpty'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists())'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'versioning'
resource: 'Consent'
4 4
ruleset-createok-headers-body 1 1
Id Params Version Latest
assertContentTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'notEmpty'
bodyOperator: 'notEmpty'
4 4
assertContentTypeMimeTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertContentTypeCharsetIfBody
header: 'Content-Type'
headerExpectedValue: 'charset=utf-8'
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertResourceTypesIfBody
resource: 'Consent,OperationOutcome'
resourceOperator: 'in'
bodyOperator: 'notEmpty'
4 4
assertProfileIfOperationOutcome
validateProfileId: 'operationoutcome-profile'
resource: 'OperationOutcome'
resourceOperator: 'equals'
3 3
assertProfileIfResource
validateProfileId: 'resource-profile'
resource: 'Consent'
resourceOperator: 'equals'
3 3
ruleset-updateok-headers-body 3 3
Id Params Version Latest
assertContentTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'notEmpty'
bodyOperator: 'notEmpty'
4 4
assertContentTypeMimeTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertContentTypeCharsetIfBody
header: 'Content-Type'
headerExpectedValue: 'charset=utf-8'
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertResourceTypesIfBody
resource: 'Consent,OperationOutcome'
resourceOperator: 'in'
bodyOperator: 'notEmpty'
4 4
assertProfileIfOperationOutcome
validateProfileId: 'operationoutcome-profile'
resource: 'OperationOutcome'
resourceOperator: 'equals'
3 3
assertProfileIfResource
validateProfileId: 'resource-profile'
resource: 'Consent'
resourceOperator: 'equals'
3 3
assertVersionIdIfResourceAndSupported
fhirPath
xPath: 'meta/versionId'
jsonPath: '.meta.versionId'
pathOperator: 'notEmpty'
pathExpectedValue
resource: 'Consent'
resourceOperator: 'equals'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists())'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'versioning'
3 3
ruleset-vreadok-headers-body-if-versioning 4 4
Id Params Version Latest
assertResponseCodeOkIfVersioning
responseCode: '200'
responseCodeOperator: 'equals'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists())'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'versioning'
resource: 'Consent'
3 3
assertResponseCodeNotFoundIfNotVersioning
responseCode: '404'
responseCodeOperator: 'equals'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists()).not()'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'no versioning'
resource: 'Consent'
3 3
assertETagIfSupported
header: 'ETag'
headerExpectedValue
headerOperator: 'notEmpty'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists())'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'versioning'
resource: 'Consent'
4 4
assertLastModifiedIfSupported
header: 'Last-Modified'
headerExpectedValue
headerOperator: 'notEmpty'
confFhirPath: '(CapabilityStatement.rest.where(mode = 'server').resource.where(type = '${param.resource}').where(versioning = 'versioned' or versioning = 'versioned-update').exists())'
confXPath
confJsonPath
confOperator
confPathValue
confPathLabel: 'versioning'
resource: 'Consent'
4 4
assertContentTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'notEmpty'
bodyOperator: 'notEmpty'
4 4
assertContentTypeMimeTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertContentTypeCharsetIfBody
header: 'Content-Type'
headerExpectedValue: 'charset=utf-8'
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertResourceTypesIfBody
resource: 'Consent,OperationOutcome'
resourceOperator: 'in'
bodyOperator: 'notEmpty'
4 4
assertProfileIfOperationOutcome
validateProfileId: 'operationoutcome-profile'
resource: 'OperationOutcome'
resourceOperator: 'equals'
3 3
assertProfileIfResource
validateProfileId: 'resource-profile'
resource: 'Consent'
resourceOperator: 'equals'
3 3
assertPathIfResource
fhirPath
xPath
jsonPath
pathOperator: 'equals'
pathExpectedValue
resource
resourceOperator: 'equals'
3 3
ruleset-deletevalid-headers-body 1 1
Id Params Version Latest
assertResponseCodeOkIfBody
responseCode: '200'
responseCodeOperator: 'equals'
bodyOperator: 'notEmpty'
3 3
assertResponseCodeNoContentIfNoBody
responseCode: '204,404'
responseCodeOperator: 'in'
bodyOperator: 'empty'
3 3
assertContentTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'notEmpty'
bodyOperator: 'notEmpty'
4 4
assertContentTypeMimeTypeIfBody
header: 'Content-Type'
headerExpectedValue
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertContentTypeCharsetIfBody
header: 'Content-Type'
headerExpectedValue: 'charset=utf-8'
headerOperator: 'contains'
bodyOperator: 'notEmpty'
4 4
assertOperationOutcomeIfError
resource: 'OperationOutcome'
resourceOperator: 'equals'
responseCode: '399'
responseCodeOperator: 'greaterThan'
3 3
assertProfileIfOperationOutcome
validateProfileId: 'operationoutcome-profile'
resource: 'OperationOutcome'
resourceOperator: 'equals'
3 3