-
Notifications
You must be signed in to change notification settings - Fork 166
Integration Tests Notes
PASS: 2096
FAIL: 11
SKIP: 345
ERROR: 1
TBD
TBD
Before, it was only using POSTed data.
Unsupported properties removed:
- AllergyIntolerance.clinicalStatus
- Binary.clinicalStatus
- Condition.clinicalStatus
- DiagnosticReport.clinicalStatus
- DocumentReference.clinicalStatus
- MedicationStatement.clinicalStatus
- Observation.derivedFrom
Commands executed:
db.resources.update(
{ resourceType: {$in:["AllergyIntolerance", "Binary", "Condition", "DiagnosticReport", "DocumentReference", "MedicationStatement"]} },
{ $unset: { clinicalStatus: "" } },false,true
);
db.resources.update(
{ resourceType: {$in:["Observation"]} },
{ $unset: { derivedFrom: "" } },false,true
)
Patient id counter restarted from 1000. Previously it was 3 which caused some tests to fail.
db.counters.update(
{ _id: "Patient" },
{ "last": NumberInt(1000) }
);
It was assuming that the binary contents is requested instead of searching for it.
Spec says:
The search parameter _id
refers to the logical id of the resource, and can be used when the search context specifies a resource type:
GET [base]/Patient?_id=23
This search finds the patient resource with the given id (there can only be one resource for a given id). Functionally, this is equivalent to a simple read operation:
GET [base]/Patient/23
However it was using partial match by default which was translated to this regexp:
/^23/i
which produced multiple results.
Changed to exact match (always).
- All validation tests (
X060
,X065
andX067
).$validate
is not yet implemented. - Some "Argonaut" tests relaying on some data presense and security enabled on server. Argonaut tests are for DSTU2 only.
-
XFER5
(Fetch patient record and then present the unaltered record as an update transaction)
Reason: server doesn't return entry id if updating something with bundle PUT interaction but without any changes. Solution: return entry id?
https://github.com/FirelyTeam/spark/issues/304
-
XFER4
(Transaction Processing Order of Operations),XFER11
(Create Patient Record and then Batch create and search Observations)
Reason: server currently doesn't support GET Batch interaction Solution: implement GET interactions?
-
XFER10
(Invalid Batch with Interdependencies)
Reason: server doesn't perform resource interdependence check.
-
SE07P
,SE07G
(Search patient and _revinclude)
Reason: search _revinclude
is not supported.
Solution: implement _revinclude
search param?
-
SE21P
,SE21G
(Search for quantity (in observation) - precision tests)
Reason: Search by quantity with units is not working. Solution: fix it
More details:
http://hl7.org/fhir/DSTU2/search.html#quantity
> db.resources.find({resourceType: "Observation", "id":"80"}, {"valueQuantity":1});
{ "_id" : "Observation/80/_history/1", "valueQuantity" : { "value" : 2, "unit" : "mmol", "system" : "http://unitsofmeasure.org" } }
> db.searchindex.find({"internal_id" : "Observation/80"}, {"value-quantity":1, "internal_justid":1})
{ "_id" : ObjectId("5f9d5bde896f3f0b43f23d8b"), "internal_justid" : "80", "value-quantity" : { "system" : "http://unitsofmeasure.org", "value" : 2, "decimals" : "E00x2.0", "unit" : "" } }
{{baseUrl}}/fhir/Observation?value-quantity=2.0||mmol
{
"find" : "searchindex",
"filter" : {
"internal_level" : 0,
"internal_resource" : "Observation",
"$or" : [
{
"value-quantity" : {
"$elemMatch" : {
"decimals" : /^E21x1.2/,
"unit" : ""
}
}
},
{
"value-quantity" : {
"$not" : {
"$type" : 4
}
},
"value-quantity.decimals" : /^E21x1.2/,
"value-quantity.unit" : ""
}
]
},
"projection" : {
"internal_selflink" : 1
},
"$db" : "spark",
"lsid" : {
"id" : UUID("3bcf5075-2e89-4ccd-80ea-37667866dcd3")
}
}
db.searchindex.count({
"internal_level" : 0,
"internal_resource" : "Observation",
"$or" : [
{
"value-quantity" : {
"$elemMatch" : {
"decimals" : /^E21x1.2/,
"unit" : ""
}
}
},
{
"value-quantity" : {
"$not" : {
"$type" : 4
}
},
"value-quantity.decimals" : /^E21x1.2/,
"value-quantity.unit" : ""
}
]
});
0
-
SE22P
,SE22G
(Search for quantity (in observation) - operators)
Reason: may be related to 2.?
-
SE25P
,SE25G
(Search with malformed parameters)
Reason: passing malformed parameter produces 400 result. Solution: fix it so it returns 200 + some operation outcome, like warning, as it's done in https://vonk.fire.ly/
- Implement validation, enable tests
X060
,X065
andX067
- Fix all the bugs? Reach 100% test passed?
- Make the same for STU3 and R4 tests.