Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Additional US Core Docs update #224

Merged
merged 11 commits into from
Jan 14, 2025
27 changes: 17 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,20 +9,27 @@ for the US Core Implementation Guide
[v7.0.0](https://hl7.org/fhir/us/core/STU7/). This test kit
provides testing for US Core Servers.

Visit the [US Core Test Kit Manual](https://github.com/inferno-framework/us-core-test-kit/wiki) for more information on using this test kit.
Visit the [US Core Test Kit
Documentation](https://github.com/inferno-framework/us-core-test-kit/wiki) for
more information on using this test kit.

## Instructions
## Getting Started

It is highly recommended that you use [Docker](https://www.docker.com/) to run
these tests. This test kit requires at least 10 GB of memory are available to Docker.
The Inferno on HealthIT.gov platform hosts a [public
instance](https://inferno.healthit.gov/test-kits/us-core/) of this test
kit that developers and testers are welcome to use. However, users are
encouraged to download and run this tool locally.

- Clone this repo.
- Run `setup.sh` in this repo.
- Run `run.sh` in this repo.
- Navigate to `http://localhost`. The US Core test suite will be available.
The quickest way to run this test kit locally is with [Docker](https://www.docker.com/).

See the [Inferno Documentation](https://inferno-framework.github.io/docs/)
for more information on running Inferno.
- Install Docker
- Clone this repository, or download an [official release](/releases).
- Run `./setup.sh` within the test kit directory to download necessary dependencies
- Run `./run.sh` within the test kit directory to start the application
- Navigate to `http://localhost`

See the [Inferno Documentation](https://inferno-framework.github.io/docs/getting-started-users.html#running-an-existing-test-kit)
for more information on running Inferno locally.

## License

Expand Down
19 changes: 9 additions & 10 deletions docs/Overview.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
# US Core Test Kit Overview

The US Core Test Kit provides server testing for several versions of US Core.
Tests are designed to simulate a realistic client that would like to access all
Expand All @@ -9,13 +8,13 @@ and optional queries are checked.

The US Core Test Kit serves two purposes:
* Provide general testing to servers implementing the US Core Implementation Guide
* Provide tests to other Test Kits that target other implementation guides, or
* Provide tests to other test kits that target other implementation guides, or
certification criterion, that may reference US Core.

This guide is targeting users who would like to run the US Core Test Kit without
being the context of another Implementation Guide or certification criterion.

# Testing Options
## Testing Options

Users of the test kit are presented with two options:

Expand All @@ -29,37 +28,37 @@ Please note that US Core states that at least version SMART App Launch v2.0 is
used in US Core 7; however, these tests allow testers to select SMART App Launch
v1 for any US Core version.

# Test Prerequisites
## Test Prerequisites

Systems do not need to load a specific set of data to run these tests. However,
the tests do require that the system under test has a set of data that is
representative of the data that the system will be handling.

# Conformance Criteria
## Conformance Criteria

Systems do NOT need to pass all tests within this Test Kit to be considered 'US
Systems do NOT need to pass all tests within this test kit o be considered 'US
Core Conformant'. US Core allows systems to support a subset of content
arscan marked this conversation as resolved.
Show resolved Hide resolved
relevant to their use case. The US Core Test Kit allows testers to choose which
tests to run, and it is up to the tester to decide which set of tests are
relevant to a given system. Tests are divided in a logical way that should align
with common boundaries associated with real-world systems; e.g. you may run
tests relevant to a certain profile while skipping tests for other profiles.

# Test Groups
## Test Groups

This test kit is organized into the following high-level test groups. The system
under test can choose which test groups are relevant to their system.


## 1 SMART App Launch
### 1 SMART App Launch

This group provides two tests: an EHR launch test and a standalone launch test,
based on the SMART App Launch guide. When used, a bearer token is stored
that can be used in the US Core FHIR API test section.

Read the description provided in each test with instructions on their use.

## 2 US Core FHIR API
### 2 US Core FHIR API

This group contains the majority of the US Core tests that are applicable to the
US Core Implementation Guide. Users may either run all tests, or select a
Expand All @@ -76,7 +75,7 @@ directly reference
a patient ID (e.g.; Organization, Practitioner) should not be run individually.
They can only be run when the entire group US Core FHIR API group is run.

## 3 US Core SMART Granular Scopes (US Core v6+, SMART App Launch v2+)
### 3 US Core SMART Granular Scopes (US Core v6+, SMART App Launch v2+)

This group tests the specific implementation details surrounding use of granular
SMART App Launch scopes within US Core.
43 changes: 18 additions & 25 deletions docs/README.md
Original file line number Diff line number Diff line change
@@ -1,31 +1,24 @@
# US Core Test Kit Manual

The US Core Test Kit is an automated testing tool for servers
implementing the US Core FHIR Implementation Guide. It contains server
tests for v3.1.1, v4.0.0, v5.0.1, v6.1.0, and v7.0.0 of US Core.

> *To update this manual, please update the associated files within the
`/docs/` directory of this git repository. Manual updates to this wiki will be discarded
by GitHub on each push to the `main` branch.*

# Installation

Information on downloading and running this application, including prerequisites
and system requirements, are provided in the repository [README](../).

# Using this Test Kit
* [Test Kit Overview](Overview): An overview of the Test Kit and its tests.

# Maintaining this Test Kit
Developers contributing to this Test Kit should be familiar with authoring
Inferno Framework test suites. The following guides provide additional
information about the design and implementation of this Test Kit to aid
The **US Core Test Kit** is an automated conformance testing tool for servers
implementing the [US Core FHIR Implementation
Guide](https://hl7.org/fhir/us/core/) . It contains server tests for several
versions of US Core, including v3.1.1, v4.0.0, v5.0.1, v6.1.0, and v7.0.0 of US
Core. The following documentation describes how to use and contribute to this
test kit.

## Using this Test Kit
* [Getting Started](https://github.com/inferno-framework/us-core-test-kit/?tab=readme-ov-file#getting-started): Installation instructions for this test kit.
* [Test Kit Overview](Overview.md): An overview of the test kit and its tests.

## Contributing to this Test Kit
Developers contributing to this test kit should be familiar with [authoring
Inferno Framework test suites](https://inferno-framework.github.io/docs/writing-tests/). The following guides provide additional
information about the design and implementation of this test kit to aid
contributing to these tests:

* [Technical Overview](Technical-Overview): An overview of the technical design of this Test Kit.
* [Standards Update Guide](Version-Update-Guide): A step by step guide on updating this test kit to support new versions of US Core.
* [Technical Overview](Technical-Overview.md): An overview of the technical design of this test kit.
* [Version Update Guide](Version-Update-Guide.md): A step by step guide on updating this test kit to support new versions of the US Core Implementation Guide.

# Support
## Support

For questions or issues with this Test Kit, please reach out to the Inferno team
on the [#Inferno FHIR Zulip
Expand Down
66 changes: 33 additions & 33 deletions docs/Technical-Overview.md
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
# Background
This technical overview orients developers to the technical design of this test
kit. While the [Inferno Framework has
documentation](https://inferno-framework.github.io) on how to create tests,
additional documentation on the organization of this test kit is necessary due
to the complexity involved in developing tests for the US Core guide.

This guide orients developers to the technical design of this Test Kit. While
the Inferno Framework has documentation on how to create tests, additional
documentation on the organization of this test kit is necessary due to the
complexity involved in developing tests for the US Core guide.
Prior to reviewing this document, the developer is expected to be familiar with
the US Core Implementation Guide, using this test kit, and building tests with
the [Inferno Framework](https://inferno-framework.github.io).

Prior to reviewing this document, the developer is expected to be familiar
with the US Core Test Kit and building tests with the Inferno Framework.
## Test Design Principles and Features

# Test Design Principles and Features

Tests for this Test Kit have been designed with the following principles:
Tests for this test kit have been designed with the following principles:

* Easy testing: Users should be able to run the tests with minimal input or
configuration, and tests should complete in a reasonable amount of time.
Expand All @@ -30,7 +30,7 @@ Features of this test kit reflect these principles. For example:
* Testers supply a very limited amount of information to the
tests; the tests themselves learn about data provided by the system to
and automatically generate inputs for subsequent tests.
* This Test Kit generates tests from machine-readable content each time US Core
* This test kit generates tests from machine-readable content each time US Core
is updated. Additionally, the tests use the HL7 FHIR Validator to do runtime
validation of resources against profiles provided within US Core.
* Occasionally, the US Core Test Kit overrides machine-readable rules in narrative;
Expand All @@ -42,11 +42,11 @@ The US Core Test Kit manages this complexity through standard software design
practices and approaches, leveraging the functionality provided by the Ruby
programming language. And while this code is intended to be accessible to
developers new to the Ruby language, developers are expected to learn the basics
of Ruby development before attempting to alter these tests. This Test Kit also
of Ruby development before attempting to alter these tests. This test kit also
uses RSpec to "unit test" components of these tests, and developers are expected
to learn the basics of RSpec as well.

# US Core Test Kit Project Source Code Structure:
## US Core Test Kit Project Source Code Structure:

Below is a description of the source code structure for the US Core Test Kit:

Expand Down Expand Up @@ -78,9 +78,9 @@ Importantly, code within the `generated` folder is generated using the
generation script and should *not* be manually edited. Instead, changes to the
generator should be made in the `generator` folder.

# Related Systems and Dependencies
## Related Systems and Dependencies

## Reference Server
### Reference Server

The Inferno Reference Server serves as a reference implementation server,
supporting the US Core Implementation Guide, SMART App Launch, and Bulk Data
Expand All @@ -94,7 +94,7 @@ Inferno Reference Server to ensure it conforms to the latest Implementation
Guide. For detailed instructions on how to load data into the server database,
please refer to the README.md file on the GitHub repository.

## SMART App Launch Test Kit
### SMART App Launch Test Kit

The Inferno US Core Test Kit incorporates a test group from the SMART App Launch
Test Kit. The purpose of the SMART App Launch Test Kit is to confirm a server's
Expand All @@ -108,14 +108,14 @@ in response to any potential ambiguity that results from the combination of
FHIR, US Core and SMART App Launch, particularly when relevant to certification
activities in the US.

# Testing Code Changes
## Testing Code Changes

This test kit includes comprehensive "self testing" functionality to provide
confidence that the tests perform as expected. Prior to committing changes to
this test kit, developers should ensure that both RSpec tests and End-to-End
tests pass.

## RSpec Tests
### RSpec Tests

The test kit contains many "unit" tests within the `spec` directory. These
tests are written in RSpec, and can be run with the following command:
Expand All @@ -128,30 +128,30 @@ that the code base achieves 100% test coverage; instead, the team has followed a
common sense approach to testing components that 1) are complicated or 2) are
likely to change.

## End-to-End testing
### End-to-End testing

Besides the unit tests provided within this Test Kit, after each update
Besides the unit tests provided within this test kit, after each update
the tests should be validated against a complete server implementation
that is known to be correct. The Inferno Reference Server provides this functionality,
and contains data that passes all of these tests. Note that if test changes
have been made that require data on the Reference Server to change as well,
that data set needs to be updated.

# Updating the Test Kit
## Updating the Test Kit

**To update this test kit in response to a new version of the US Core Implementation
Guide, please see the [Version Update Guide](Version-Update-Guide). The Version
Update Guide provides a detailed walkthrough of the components of the Test Kit
that are changed during this process.**
Guide, please see the [Version Update Guide](Version-Update-Guide.md). The Version
Update Guide provides a detailed walkthrough of the components of the test kit
at are changed during this process.**

arscan marked this conversation as resolved.
Show resolved Hide resolved
While developers of this Test Kit should aim to have completely correct tests,
issues will likely be identified by the community over time. Because this Test Kit
exports tests to the ONC Certification (g)(10) Test Kit, incorrect tests may delay
While developers of this test kit should aim to have completely correct tests,
issues will likely be identified by the community over time. Because this test kit
ports tests to the ONC Certification (g)(10) Test Kit, incorrect tests may delay
certification activities for implementers, or even worse, encourage improper
arscan marked this conversation as resolved.
Show resolved Hide resolved
implementations just to make incorrect tests pass. Therefore,
the tests should be updated to include the test fixes as soon as possible.

## Updating Generating Tests
### Updating Generating Tests

The main testing logic for these tests are generated from machine-readable data
provided by each version of the US Core Implementation Guide. The code for
Expand All @@ -169,7 +169,7 @@ To regenerate the files, run:
Tests will be created for each version of the implementation guide provided in
the `lib/us_core_test_kit/igs` directory.

## Updating shared component tests
### Updating shared component tests

While the generator creates code for each suite, the generated code typically
references shared component tests. These component tests reside in the
Expand All @@ -181,7 +181,7 @@ Tests that are version specific reside in the
`lib/us_core_test_kit/custom_groups` directory.


## Overriding US Core IG Machine-readable Content
### Overriding US Core IG Machine-readable Content

Occasionally, the US Core authors publish incorrect content within the
implementation guide that affects the generation of tests, or validation of
Expand All @@ -204,7 +204,7 @@ in:
Please see those files for examples of how to modify the behavior of the generator
based on issues in the published implementation guide.

## Overriding HL7 Validator Behavior
### Overriding HL7 Validator Behavior

The HL7 Validator is used to validate resources at runtime. Occasionally, the
HL7 Validator will report validation errors that are considered to be out of
Expand All @@ -217,9 +217,9 @@ only applies to a certain version of US Core, you can update the
`lib/us_core_test_kit/generator/suite_generator.rb` file by adding a version-specific
exception.

# Unusual Implementation Details
## Unusual Implementation Details

While code in this Test Kit is intended to be as simple and as easy-to-understand
While code in this test kit is intended to be as simple and as easy-to-understand
as possible, sometimes unanticipated testing requirements are introduced that
require special handling by the US Core test kit. The ability for Inferno
to accommodate these requirements is a key feature of the Inferno framework. However,
Expand Down
12 changes: 5 additions & 7 deletions docs/Version-Update-Guide.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
# Background

This guide walks developers through the process of creating tests for new
versions of the US Core Implementation Guide. While this test kit provides
tools to support the creation of these tests based on machine-readable content
Expand All @@ -10,13 +8,13 @@ be automated.

Prior to reviewing this document, the developer is expected to be familiar with
using the US Core Test Kit and building test kits using the Inferno Framework.
Please review the [Technical Overview](Technical-Overview) document for a
Please review the [Technical Overview](Technical-Overview.md) document for a
high-level overview of the test kit's design.

This document should be updated after each new version of the US Core
Implementation guide is incorporated into the Test Kit.

# Versions of US Core Test Kit to Support
## Supporting US Core Versions

This test kit should be updated to provide testing for all versions of the US
Core Implementation Guide that is approved for certification within the
Expand All @@ -41,10 +39,10 @@ release. A general convention that this test kit has taken is to name suites
that refer to a ballot using "-ballot" appended to the end of the suite ID. Once
the final version is released, the ballot version is deleted.

# How to Update the Test Kit
## Updating the Test Kit

Tests for a new version of the US Core Implementation Guide can be created
for this Test Kit using the following steps:
for this test kit using the following steps:

1. Perform a structured review of the updates to the IG
2. Generate a new version-specific suite
Expand Down Expand Up @@ -74,7 +72,7 @@ Guide, which is a good starting point for this activity.

## Step 2. Generate a New Version-specific Suite

This Test Kit is organized into several version-specific test suites. For example,
This test kit is organized into several version-specific test suites. For example,
there is a US Core v3.1.1 test suite, and a US Core v4.0.0 test suite. In order to
support a new version of US Core, the test developer will create a new test suite
by using the generator script that is provided a the US Core IG as a versioned packaged.
Expand Down
5 changes: 5 additions & 0 deletions docs/_Footer.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
_Test kit documentation is stored within the [./docs](../tree/main/docs) folder of
this repository and is automatically synchronized to this wiki with each update
to the `main` branch using the [Publish Docs Wiki
workflow](../actions/workflows/publish-docs-wiki.yml). Do not change content
within this wiki directly as changes will be overwritten._
9 changes: 9 additions & 0 deletions docs/_Sidebar.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
**[Documentation Home](Home)**

**Using this Test Kit**
- [Getting Started](https://github.com/inferno-framework/us-core-test-kit/?tab=readme-ov-file#getting-started)
- [Test Kit Overview](Overview.md)

**Contributing to this Test Kit**
- [Technical Overview](Technical-Overview)
- [Version Update Guide](SVAP-Update-Guide)
Loading