Skip to content

Commit

Permalink
Merge pull request #1 from inferno-framework/suite_description_breakouts
Browse files Browse the repository at this point in the history
Updates based off of ONC feedback to documentation and test organization
  • Loading branch information
karlnaden authored Apr 29, 2024
2 parents 5421a93 + 9d665e2 commit b0577ad
Show file tree
Hide file tree
Showing 94 changed files with 850 additions and 636 deletions.
6 changes: 3 additions & 3 deletions Gemfile.lock
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
PATH
remote: .
specs:
davinci_pas_test_kit (0.9.0)
davinci_pas_test_kit (0.9.1)
inferno_core (~> 0.4.34)

GEM
Expand Down Expand Up @@ -183,11 +183,11 @@ GEM
kramdown (2.4.0)
rexml
language_server-protocol (3.17.0.3)
method_source (1.0.0)
method_source (1.1.0)
mime-types (3.5.2)
mime-types-data (~> 3.2015)
mime-types-data (3.2024.0305)
mini_portile2 (2.8.5)
mini_portile2 (2.8.6)
minitest (5.22.3)
multi_json (1.15.0)
multi_xml (0.6.0)
Expand Down
48 changes: 26 additions & 22 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ feedback on the tests. Future versions of these tests may validate other
requirements and may change how these are tested.

Additional details on the IG requirements that underlie this test kit, including those
that are not currently tested, can be found in [this spreadsheet](docs/PAS%20Requirements%20Interpretation.xlsx). The spreadsheet includes
that are not currently tested, can be found in [this spreadsheet](lib/davinci_pas_test_kit/docs/PAS%20Requirements%20Interpretation.xlsx). The spreadsheet includes

- a list of requirements extracted from the IG.
- the requirements tested by this DRAFT test kit.
Expand All @@ -38,11 +38,12 @@ that are not currently tested, can be found in [this spreadsheet](docs/PAS%20Req
## Test Scope and Limitations

Neither the server nor client test suite included test the full scope of the PAS IG.
Documentation within the tests include details on what is currently tested
and what is out of scope and why. Start a session with either test kit or see the description in these files
([server](lib/davinci_pas_test_kit/generated/v2.0.1/server_suite.rb),
[client](lib/davinci_pas_test_kit/client_suite.rb)) for details beyond what
is included here.
Documentation of what is currently tested and what is out of scope and why can be
found in the suite descriptions when the tests are run, or within this repository
for the [server](lib/davinci_pas_test_kit/docs/server_suite_description_v201.md#testing-limitations)
and [client](lib/davinci_pas_test_kit/docs/client_suite_description_v201.md#testing-limitations).

### In-Scope Requirements

At a high-level, in-scope requirements include:

Expand All @@ -53,18 +54,20 @@ At a high-level, in-scope requirements include:
- The ability of the system to produce and receive (currently server tests only)
all PAS-defined profiles and their must support elements.

Out of scope details that are not yet tested include:
### Out-of-Scope Requirements

Out of scope requirements from the IG that are not yet tested include:

- Subscriptions
- Prior Authorization update workflows
- Requests for additional information handled through the CDex framework
- PDF, CDA, and JPG attachments
- US Core profile support for supporting information
- (Server) Inquiry matching and subsetting logic
- (Server) Inquiry requests from non-submitting systems
- (Server) Collection of metrics
- (Client) The ability to handle responses containing all PAS-defined profiles and must support elements
- (Client) Most details requiring manual review of the client system, e.g., the requirement that clinicians can update details of the prior authorization request before submitting them
- Subscriptions (see details [here](https://hl7.org/fhir/us/davinci-pas/STU2/specification.html#subscription))
- Prior Authorization update workflows (see details [here](https://hl7.org/fhir/us/davinci-pas/STU2/specification.html#updating-authorization-requests))
- Requests for additional information handled through the CDex framework (see details [here](https://hl7.org/fhir/us/davinci-pas/STU2/additionalinfo.html))
- PDF, CDA, and JPG attachments (see details in the 3rd paragraph [here](https://hl7.org/fhir/us/davinci-pas/STU2/specification.html#prior-authorization-submission))
- US Core profile support for supporting information (see details [here](https://hl7.org/fhir/us/davinci-pas/STU2/specification.html#integration-with-other-implementation-guides))
- (Server) Inquiry matching and subsetting logic (see details in the 2nd paragraph and 2 bullet [here](https://hl7.org/fhir/us/davinci-pas/STU2/specification.html#prior-authorization-inquiries))
- (Server) Inquiry requests from non-submitting systems (see details in the 3rd paragraph [here](https://hl7.org/fhir/us/davinci-pas/STU2/specification.html#pended-authorization-responses))
- (Server) Collection and dissemination of metrics (see details [here](https://hl7.org/fhir/us/davinci-pas/STU2/metrics.html))
- (Client) The ability to handle responses containing all PAS-defined profiles and must support elements (see details under the 3rd bullet [here](https://hl7.org/fhir/us/davinci-pas/STU2/background.html#must-support))
- (Client) Most details requiring manual review of the client system, e.g., the requirement that clinicians can update details of the prior authorization request before submitting them (see details in the 1st paragraph [here](https://hl7.org/fhir/us/davinci-pas/STU2/usecases.html#submit-prior-authorization))

### Limitations

Expand Down Expand Up @@ -93,13 +96,14 @@ the test home pages include instructions for trying out the tests, including
([code on github](https://github.com/HL7-DaVinci/prior-auth))
- For client testing: a [sample postman collection](config/PAS%20Test%20Kit%20Client%20Test%20Demo.postman_collection.json)

Start a session with either test kit or see the description in these files
([server](lib/davinci_pas_test_kit/generated/v2.0.1/server_suite.rb),
[client](lib/davinci_pas_test_kit/client_suite.rb)) for detailed instructions.
Detailed instructions can be found in the suite descriptions when the tests
are run, or within this repository for the
[server](lib/davinci_pas_test_kit/docs/server_suite_description_v201.md#running-the-tests) and
[client](lib/davinci_pas_test_kit/docs/client_suite_description_v201.md#running-the-tests).

### ONC Hosted Instance

You can run these tests via the [ONC Inferno](https://inferno.healthit.gov/test-kits/) website by choosing the “Da Vinci Prior Authorization Support (PAS) v2.0.1” test kit.
You can run the PAS test kit via the [ONC Inferno](https://inferno.healthit.gov/test-kits/davinci-pas/) website by choosing the “Da Vinci Prior Authorization Support (PAS) v2.0.1” test kit.

### Local Inferno Instance

Expand All @@ -113,7 +117,7 @@ You can run these tests via the [ONC Inferno](https://inferno.healthit.gov/test-

We welcome feedback on the tests, including but not limited to the following areas:
- Validation logic, such as potential bugs, lax checks, and unexpected failures.
- Requirements coverage, such as requirements that have been missed, tests that necessitate features that the IG does not require, or other issues with the [interpretation](docs/Plan%20Net%20Requirements%20Interpretation.xlsx) of the IG's requirements.
- Requirements coverage, such as requirements that have been missed, tests that necessitate features that the IG does not require, or other issues with the [interpretation](lib/davinci_pas_test_kit/docs/PAS%20Requirements%20Interpretation.xlsx) of the IG's requirements.
- User experience, such as confusing or missing information in the test UI.

Please report any issues with this set of tests in the issues section of this repository.
Expand Down
1 change: 1 addition & 0 deletions davinci_pas_test_kit.gemspec
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ Gem::Specification.new do |spec|
Dir['lib/**/*.rb'],
Dir['lib/**/*.json'],
Dir['lib/**/*.yml'],
Dir['lib/**/*.md'],
'LICENSE'
].flatten

Expand Down
170 changes: 1 addition & 169 deletions lib/davinci_pas_test_kit/client_suite.rb
Original file line number Diff line number Diff line change
Expand Up @@ -20,175 +20,7 @@ class ClientSuite < Inferno::TestSuite
id :davinci_pas_client_suite_v201
title 'Da Vinci PAS Client Suite v2.0.1'
version VERSION
description %(
The Da Vinci PAS Test Kit Client Suite validates the conformance of client
systems to the STU 2 version of the HL7® FHIR®
[Da Vinci Prior Authorization Support Implementation Guide](https://hl7.org/fhir/us/davinci-pas/STU2/).
## Scope
These tests are a **DRAFT** intended to allow PAS client implementers to perform
preliminary checks of their clients against PAS IG requirements and [provide
feedback](https://github.com/inferno-framework/davinci-pas-test-kit/issues)
on the tests. Future versions of these tests may validate other
requirements and may change the test validation logic.
## Test Methodology
Inferno will simulate a PAS server for the client under test to interact with. The client
will be expected to initiate requests to the server and demonstrate its ability to react
to the returned responses. Over the course of these interactions,
Inferno will seek to observe conformant handling of PAS requirements, including
- The ability of the client to initiate and react to
- The approval of a prior authorization request
- The denial of a prior authorization request
- The pending of a prior authorization request and a subsequent final decision
- The ability of the client to provide data covering the full scope of required by PAS, including
- The ability to send prior auth requests and inquiries with all PAS profiles and all must support elements on
those profiles
- The ability to handle responses that contain all PAS profiles and all must support elements on those
profiles (not included in the current version of these tests)
Because X12 details, including coded values indicating details like “denied” and “pended”,
are not public, Inferno is not currently able to generate a full set of responses to requests
or otherwise provide details on specific codes used to represent those concepts
and is limited to responses that look similar to the examples in the IG (e.g., [here](https://hl7.org/fhir/us/davinci-pas/STU2/Bundle-ReferralAuthorizationResponseBundleExample.html)).
Thus,
- In order to demonstrate specific workflows, namely pend and denial, users will need to provide the expected
response for Inferno to send back
- The current tests do not return to the client all PAS profiles and must support elements to confirm support.
For further details on limitations of these tests, see the *Testing Limitations* section below.
All requests and responses will be checked for conformance to the PAS
IG requirements individually and used in aggregate to determine whether
required features and functionality are present. HL7® FHIR® resources are
validated with the Java validator using `tx.fhir.org` as the terminology server.
## Running the Tests
### Quick Start
For Inferno to simulate a server that always returns approved responses, it needs
only to know the bearer token that the client will send on requests, for which there are two options.
1. If you want to choose your own bearer token, then
1. Select the "2. PAS Client Validation" test from the list on the left.
2. Click the '*Run All Tests*' button on the right.
3. In the "access_token" field, enter the bearer token that will be sent by the client under test (as part
of the Authorization header - Bearer: <provided value>).
4. Click the '*Submit*' button at the bottom of the dialog.
2. If you want to use a client_id to obtain an access token, then
1. Click the '*Run All Tests*' button on the right.
2. Provide the client's registered id "client_id" field of the input (NOTE, Inferno doesn't support the
registration API, so this must be obtained from another system or configured manually).
3. Click the '*Submit*' button at the bottom of the dialog.
4. Make a token request that includes the specified client id to the
`<inferno host>/custom/davinci_pas_client_suite_v201/mock_auth/token` endpoint to get
an access token to use on the request of the requests.
In either case, the tests will continue from that point, requesting the user to
direct the client to make certain requests to demonstrate PAS client capabilities.
Note: authentication options for these tests have not been finalized and are subject to change.
### Complete Setup
The *Quick Start* approach does not test pended or deny workflows. To test these, provide a
json-encoded FHIR bundle in the "Claim pended response JSON" and "Claim deny response JSON" input field after
clicking the '*Run All Tests*' button. These responses will be echoed back when a request
is made during the corresponding test.
### Postman-based Demo
If you do not have a PAS client but would like to try the tests out, you can use
[this postman collection](https://raw.githubusercontent.com/inferno-framework/davinci-pas-test-kit/blob/main/config/PAS%20Test%20Kit%20Client%20Test%20Demo.postman_collection.json)
to make requests against Inferno. The following requests and example responses from that collection can be used.
- Configuration
- *Deny Response* example under the *Homecare Prior Authorization Request*: use as the value of the
"Claim denied response JSON" input field. NOTE: this contains a placeholder code `DENIEDCODE` for the
X12 code representing the denied status. Replace with the X12-specified code before providing to Inferno
to accurately replicate a denial workflow for the client under test.
- *Pend Response* example under the *Medical Services Prior Authorization Request*: use as the value of the
"Claim pended response JSON" input field. NOTE: this contains a placeholder code `PENDEDCODE` for the
X12 code representing the pended status. Replace with the X12-specified code before providing to Inferno
to accurately replicate a pend workflow for the client under test.
- Submissions
- *mock token*: for submitting a client id to get back an access token to use on the rest of the tests. Set the
collection's access_token variable to the result.
- *Referral Prior Authorization Request*: use for the "Approval" workflow test submission.
- *Medical Services Prior Authorization Request*: use for the "Pended" workflow test submission.
- *Medical Services Inquiry Request*: use for the "Pended" workflow test inquiry.
No additional requests are present to submit as a part of the must support tests, so
testers can simply click the link to indicate they are done submitting requests. Note
that the requests within the Postman client are not expected to fully pass the tests as they
do not contain all must support items.
## Testing Limitations
### Private X12 details
HIPAA [requires](https://hl7.org/fhir/us/davinci-pas/STU2/regulations.html) electronic prior authorization
processing to use the X12 278 standard. While recent CMS rule-making suggests that [this requirement
will not be enforced in the future](https://www.cms.gov/newsroom/fact-sheets/cms-interoperability-and-prior-authorization-final-rule-cms-0057-f),
the current PAS IG relies heavily on X12. As the IG authors note at the
top of the [IG home page](https://hl7.org/fhir/us/davinci-pas/STU2/index.html):
> Note that this implementation guide is intended to support mapping between FHIR and X12 transactions. To respect
> X12 intellectual property, all mapping and X12-specific terminology information will be solely published by X12
> and made available in accordance with X12 rules - which may require membership and/or payment. Please see this
> [Da Vinci External Reference page](https://confluence.hl7.org/display/DVP/Da+Vinci+Reference+to+External+Standards+and+Terminologies)
> for details on how to get this mapping.
>
> There are many situationally required fields that are specified in the X12 TRN03 guide that do not have guidance
> in this Implementation Guide. Implementers need to consult the X12 PAS guides to know the requirements for these
> fields.
>
> Several of the profiles will require use of terminologies that are part of X12 which we anticipate being made
> publicly available. At such time as this occurs, the implementation guide will be updated to bind to these as
> external terminologies.
The implications of this reliance on proprietary information that is not publicly available means that this test
kit:
- Cannot verify the correct usage of X12-based terminology: terminology requirements for all elements bound to X12
value sets will not be validated.
- Cannot verify the meaning of codes: validation that a given response conveys something specific, e.g., approval
or pending, is not performed.
- Cannot verify matching semantics on inquiries: no checking of the identity of the ClaimResponse returned for an
inquiry, e.g., that it matches the input or the original request.
These limitations may be removed in future versions of these tests. In the meantime, testers should consider these
requirements to be verified through attestation and should not represent their systems to have passed these tests
if these requirements are not met.
### Underspecified Subscription Details
The current PAS specification around subscriptions and notifications
is not detailed enough to support testing. Notably,
- There are no examples of what a notification payload looks like
- There is no instruction on how to turn the notification payload into an inquiry
Once these details have been clarified, validation of the notification workflows
will be added to these tests.
### Future Details
The PAS IG places additional requirements on clients that are not currently tested by this test kit, including
- Prior Authorization update workflows
- Requests for additional information handled through the CDex framework
- PDF, CDA, and JPG attachments
- US Core profile support for supporting information
- The ability to handle responses containing all PAS-defined profiles and must support elements
- Most details requiring manual review of the client system, e.g., the requirement that clinicians can update
details of the prior authorization request before submitting them
These and any other requirements found in the PAS IG may be tested in future versions of these tests.
)
description File.read(File.join(__dir__, 'docs', 'client_suite_description_v201.md'))

links [
{
Expand Down
Loading

0 comments on commit b0577ad

Please sign in to comment.