The ONC Certification (g)(10) Standardized API Test Kit is a testing tool for Health IT systems seeking to meet the requirements of the Standardized API for Patient and Population Services criterion § 170.315(g)(10) in the 2015 Edition Cures Update.
The ONC Certification (g)(10) Standardized API Test Kit is the successor to Inferno Program Edition. Currently, systems can use either Inferno Program Edition v1.9 or the ONC Certification (g)(10) Standardized API Test Kit v2.0+ to certify to the ONC (g)(10) criteria. Users should expect Inferno Program Edition to be sunsetted over the coming months.
The (g)(10) Standardized API Test Kit behaves like an API consumer, making a series of HTTP requests that mimic a real world client to ensure that the API supports all required standards, including:
- Health Level 7 (HL7®) Fast Healthcare Interoperability Resources (FHIR®) Release 4.0.1
- FHIR US Core Implementation Guide (IG) STU 3.1.1
- SMART Application Launch Framework Implementation Guide Release 1.0.0
- HL7 FHIR Bulk Data Access (Flat FHIR) (v1.0.0: STU 1)
This test kit is open source and freely available for use or adoption by the health IT community including EHR vendors, health app developers, and testing labs. It can be used as a testing tool for the EHR Certification program supported by the Office of the National Coordinator for Health IT (ONC).
The (g)(10) Standarized API Test Kit is built using the Inferno Framework. The Inferno Framework is designed for reuse and aims to make it easier to build test kits for any FHIR-based data exchanges.
Please report any issues with this set of tests in the GitHub Issues section of this repository.
- Clone this repo.
- run
setup.sh
- run
run.sh
- navigate to
http://localhost
In order to validate terminologies, Inferno must be loaded with files generated from the Unified Medical Language System (UMLS). The UMLS is distributed by the National Library of Medicine (NLM) and requires an account to access.
Inferno provides some rake tasks which may make this process easier, as well as a Dockerfile and docker-compose file that will create the validators in a self-contained environment.
Prerequisites:
- A UMLS account
- A working Docker toolchain, which has been assigned at least 10GB of RAM (The
Metathesaurus step requires 8GB of RAM for the Java process)
- Note: the Docker terminology process will not run unless Docker has access to at least 10GB of RAM.
- At least 90 GB of free disk space on the Host OS, for
downloading/unzipping/processing the terminology files.
- Note: this space needs to be allocated on the host because Docker maps these files through to the Host, to allow for building in the dedicated terminology container.
- Note: see the
.env
file section below for a way to reduce this space requirement to around 40 GB.
- A copy of the Inferno repository, which contains the required Docker and Ruby files
- Run
setup.sh
to initialize Inferno's database
You can prebuild the terminology docker container by running the following command:
docker-compose -f terminology_compose.yml build
Once the container is built, you will have to add your UMLS API key to a file
named .env
at the root of the inferno project. This API key is used to
authenticate the user to download the UMLS zip files. To find your UMLS API key,
sign into the UTS homepage, click on My Profile
in the top right, and copy the API KEY
value from the UMLS Licensee Profile
.
The relevant entries in the .env
file should look like this (replacing
your_api_key
with your UMLS API key):
UMLS_API_KEY=your_api_key
CLEANUP=true
Note that anything after the equals sign in .env
will be considered part of
the variable, so don't wrap your API key in quotation marks.
Optionally: you can add a second environment variable, named CLEANUP
and set
to true
, to that same file. This tells the build system to delete the "build
files"--everything except for the finished databases--between each version
build. This caps the space requirement at ~40 GB, rather than 90 GB.
Once that file exists, you can run the terminology creation task by using the following command:
docker-compose -f terminology_compose.yml up
This will run the terminology creation steps in order. These tasks may take
several hours. If the creation task is cancelled in progress and restarted, it
will restart after the last completed step. Intermediate files are saved to
tmp/terminology
in the Inferno repository that the Docker Compose job is run
from, and the validators are saved to resources/terminology/validators/bloom
,
where Inferno can use them for validation.
Once the terminology building is done, you should remove your UMLS API key from the system.
Optionally, the files and folders in tmp/terminology/
can be deleted after
terminology building to free up space, as they are several GB in size. If you
intend to re-run the terminology builder, these files can be left to speed up
building in the future, since the builder will be able to skip the initial
download/preprocessing steps.
The following rake task will check that the built terminology contains the expected number of codes for each system:
bundle exec rake terminology:check_built_terminology
You can use the following rake
command to spot check the validators to make
sure they are installed correctly:
bundle exec rake "terminology:check_code[91935009,http://snomed.info/sct, http://hl7.org/fhir/us/core/ValueSet/us-core-allergy-substance]"
Should return:
X http://snomed.info/sct|91935009 is not in http://hl7.org/fhir/us/core/ValueSet/us-core-allergy-substance
And
bundle exec rake "terminology:check_code[91935009,http://snomed.info/sct]"
Should return:
✓ http://snomed.info/sct|91935009 is in http://snomed.info/sct
Running instances of Inferno can be configured to exclude terminology validation for codes based on applicable categories of additional restrictions, as defined by the UMLS license agreement.
By default, Inferno will not restrict validation of codes. To configure an
instance of Inferno to exclude certain CodeSystems for validation, rename the
resources/terminology/terminology_config.yml.example
to
terminology_config.yml
, and update the file based on the example content.
Inferno will provide an informational message on the landing page that describes
which CodeSystems will not be validated in this running instance based on this
configuration file. If Inferno tests receive a code from an excluded
CodeSystem, a warning indicating that Inferno cannot validate the code will be
provided along with the test result.
TODO: Update this section
If this Docker-based method does not work based on your architecture, manual setup and creation of the terminology validators is documented on this wiki page
Some material in the UMLS Metathesaurus is from copyrighted sources of the respective copyright holders. Users of the UMLS Metathesaurus are solely responsible for compliance with any copyright, patent or trademark restrictions and are referred to the copyright, patent or trademark notices appearing in the original sources, all of which are hereby incorporated by reference.
Bodenreider O. The Unified Medical Language System (UMLS): integrating biomedical terminology.
Nucleic Acids Res. 2004 Jan 1;32(Database issue):D267-70. doi: 10.1093/nar/gkh061.
PubMed PMID: 14681409; PubMed Central PMCID: PMC308795.
Copyright 2022 The MITRE Corporation
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.