Inferno is an open source tool that tests whether patients can access their health data through a standard interface. It makes HTTP(S) requests to test your server's conformance to authentication, authorization, and FHIR content standards and reports the results back to you.
This application creates test clients that exercise the range of requirements of a SMART on FHIR server. These clients have tests for the SMART App Launch Framework, Argonaut Implementation Guides, and FHIR DSTU2.
If you are new to FHIR or SMART-on-FHIR, you may want to review the Inferno Quick Start Guide.
Docker is the recommended installation method for Windows devices and can also be used on Linux and MacOS hosts.
- Install Docker for the host platform as well as the docker-compose tool (which may be included in the distribution, as is the case for Windows and MacOS).
- Download the latest release of the
inferno
project to your local computer on a directory of your choice. - Open a terminal in the directory where the project was downloaded (above).
- Run the command
docker-compose up
to start the server. This will automatically build the Docker image and launch both the ruby server (using unicorn) and an NGINX web server. - Navigate to http://localhost:8080 to find the running application.
If the docker image gets out of sync with the underlying system, such as when new dependencies are added to the application, you need to run docker-compose up -- build
to rebuild the containers.
Inferno can installed and run locally on your machine. Install the following dependencies first:
And run the following commands from the terminal:
# MacOS or Linux
git clone https://github.com/siteadmin/inferno
cd inferno
bundle install
rackup
Inferno can then be accessed at http://localhost:4567 in a web browser.
If you would like to use a different port it can be specified when calling rackup
. For example, the following command would host Inferno on port 3000:
rackup -p 3000
Inferno can also be deployed onto a server to test many different instances of the FHIR Servers by multiple users. Test results are kept private at a unique, unguessable URI that can be saved for future reference or shared.
Deployment on a remote server can be done by using a modified form of the Docker containers provided (see above) or by direct installation on the remote host.
Please see the file deployment-configuration.md for details.
While it is recommended that users install Inferno locally, a reference implementation of Inferno is hosted at https://inferno.healthit.gov
Users that would like to try out Inferno before installing locally can use that reference implementation, but should be forewarned that the database will be periodically refreshed and there is no guarantee that previous test runs will be available in perpetuity.
Inferno has been tested on the latest versions of Chrome, Firefox, Safari, and Edge. Internet Explorer is not supported at this time.
Inferno contains a robust set of self-tests to ensure that the test clients conform to the specification and performs as intended. To run these tests, execute the following command:
bundle exec rake
Tests are written to be easily understood, even by those who aren't familiar with Ruby. They can be viewed directly in this repository.
Tests contain metadata that provide additional details and traceability to standards. The active tests and related metadata can be exported into CSV format and saved to a file named testlist.csv
with the following command:
bundle exec rake inferno:tests_to_csv
Arguments can be provided to the task in order to export a specific set of tests or to specify the output file.
The currently supported groups of tests are all
, active
or inactive
. For example:
bundle exec rake inferno:tests_to_csv[all,all_tests.csv]
Testing sequences can be run from the command line via a rake task which takes the sequence (or sequences) to be run and server url as arguments:
bundle exec rake inferno:execute[https://my-server.org/data,Conformance]
Instructions and examples are available in the Continuous Integration Section of the Wiki.
Copyright 2018 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.