davinci_pdex_test_kit 0.11.0 → 0.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. checksums.yaml +4 -4
  2. data/config/presets/pdex_payer_server_fhir_foundry_ri_preset.json +2 -2
  3. data/config/presets/pdex_payer_server_inferno_ri_preset.json +2 -2
  4. data/lib/davinci_pdex_test_kit/pdex_payer_client/client_member_match_tests/client_member_match_validation_test.rb +7 -5
  5. data/lib/davinci_pdex_test_kit/pdex_payer_client/client_workflow_interaction_test.rb +8 -7
  6. data/lib/davinci_pdex_test_kit/pdex_payer_client_suite.rb +8 -10
  7. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/device_must_support_test.rb +50 -0
  8. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/device_patient_search_test.rb +68 -0
  9. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/device_patient_type_search_test.rb +54 -0
  10. data/lib/davinci_pdex_test_kit/pdex_payer_server/{explanation_of_benefit/explanation_of_benefit_provenance_revinclude_search_test.rb → device/device_provenance_revinclude_search_test.rb} +7 -7
  11. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/device_read_test.rb +26 -0
  12. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/device_reference_resolution_test.rb +42 -0
  13. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/device_validation_test.rb +39 -0
  14. data/lib/davinci_pdex_test_kit/pdex_payer_server/device/metadata.yml +154 -0
  15. data/lib/davinci_pdex_test_kit/pdex_payer_server/device_group.rb +88 -0
  16. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_id_search_test.rb +7 -24
  17. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_identifier_search_test.rb +10 -24
  18. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_must_support_test.rb +37 -5
  19. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_patient_lastupdated_search_test.rb +48 -0
  20. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_patient_search_test.rb +62 -0
  21. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_patient_service_date_search_test.rb +7 -23
  22. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_patient_type_search_test.rb +6 -23
  23. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_reference_resolution_test.rb +7 -4
  24. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_validation_test.rb +9 -10
  25. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/metadata.yml +276 -264
  26. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit_group.rb +62 -64
  27. data/lib/davinci_pdex_test_kit/pdex_payer_server/export_patient_group.rb +8 -9
  28. data/lib/davinci_pdex_test_kit/pdex_payer_server/export_validation_group.rb +1 -2
  29. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_must_support_test.rb +42 -0
  30. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_patient_search_test.rb +64 -0
  31. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_patient_status_search_test.rb +54 -0
  32. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_patient_status_type_search_test.rb +55 -0
  33. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_provenance_revinclude_search_test.rb +54 -0
  34. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_read_test.rb +26 -0
  35. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_reference_resolution_test.rb +42 -0
  36. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/medication_dispense_validation_test.rb +39 -0
  37. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense/metadata.yml +206 -0
  38. data/lib/davinci_pdex_test_kit/pdex_payer_server/medication_dispense_group.rb +69 -0
  39. data/lib/davinci_pdex_test_kit/pdex_payer_server/multiple_member_matches_group.rb +36 -36
  40. data/lib/davinci_pdex_test_kit/pdex_payer_server/no_member_matches_group.rb +30 -30
  41. data/lib/davinci_pdex_test_kit/pdex_payer_server/patient_operation_in_capability_statement_validation.rb +15 -13
  42. data/lib/davinci_pdex_test_kit/pdex_payer_server/provenance/metadata.yml +173 -0
  43. data/lib/davinci_pdex_test_kit/pdex_payer_server/provenance/provenance_must_support_test.rb +51 -0
  44. data/lib/davinci_pdex_test_kit/pdex_payer_server/provenance/provenance_read_test.rb +26 -0
  45. data/lib/davinci_pdex_test_kit/pdex_payer_server/provenance/provenance_reference_resolution_test.rb +46 -0
  46. data/lib/davinci_pdex_test_kit/pdex_payer_server/provenance/provenance_validation_test.rb +39 -0
  47. data/lib/davinci_pdex_test_kit/pdex_payer_server/provenance_group.rb +59 -0
  48. data/lib/davinci_pdex_test_kit/pdex_payer_server/workflow_clinical_data_group.rb +22 -11
  49. data/lib/davinci_pdex_test_kit/pdex_payer_server/workflow_everything_group.rb +19 -6
  50. data/lib/davinci_pdex_test_kit/pdex_payer_server/workflow_export_group.rb +22 -16
  51. data/lib/davinci_pdex_test_kit/pdex_payer_server/workflow_member_match_group.rb +44 -25
  52. data/lib/davinci_pdex_test_kit/pdex_payer_server_suite.rb +123 -110
  53. data/lib/davinci_pdex_test_kit/pdex_provider_client_suite.rb +8 -8
  54. data/lib/davinci_pdex_test_kit/requirements/davinci-pdex-test-kit_out_of_scope_requirements.csv +1 -0
  55. data/lib/davinci_pdex_test_kit/requirements/davinci-pdex-test-kit_requirements.csv +64 -0
  56. data/lib/davinci_pdex_test_kit/requirements/generated/davinci-pdex-test-kit_requirements_coverage.csv +64 -0
  57. data/lib/davinci_pdex_test_kit/version.rb +2 -2
  58. data/lib/davinci_pdex_test_kit.rb +1 -0
  59. data/lib/inferno_requirements_tools/ext/inferno_core/runnable.rb +22 -0
  60. data/lib/inferno_requirements_tools/rake/rakefile_template +19 -0
  61. data/lib/inferno_requirements_tools/tasks/requirements_coverage.rb +284 -0
  62. data/lib/requirements_config.yaml +17 -0
  63. metadata +56 -11
  64. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_patient_last_updated_search_test.rb +0 -64
  65. data/lib/davinci_pdex_test_kit/pdex_payer_server/explanation_of_benefit/explanation_of_benefit_patient_use_search_test.rb +0 -69
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 318708e3bf373fe0429d145f0bec49fe07739eea1a296dff8b6aedef2769b361
4
- data.tar.gz: d2ab19dc58bc8734324f60b6eda28350df3e999c94e15218ba614df630fc02e2
3
+ metadata.gz: 156bd66077651d476dcdcd5702adb592e87633dbcd60f705d4dc3f636757ff94
4
+ data.tar.gz: 989ee31b122e338cde2612a58c208c20052bb4485da560d1c8ab71773cb6c493
5
5
  SHA512:
6
- metadata.gz: 57c7352a6207c74197bf2511a7e1305fca155c2d0135456aa725cc209f89cedb5ef8733daffa2f546042a12b6c2f91f94bb1fe9f58c4f3aa6a3253c051d58896
7
- data.tar.gz: 7cbb1b8afee0ddc8e04fe6e19853b0a13f82981feff200d3197b92597fd248104c49cb3570a3ce0e0b4a183350a8c78a8d0c3a7feca16cf42ab8f201edbe08e6
6
+ metadata.gz: 5fe2f9b6f7ef8b42d1ac3869a1a844e6a68392da6d6ea545355046a56a0d879377d5f8ab0075cb16eebab113dbeea4232d135cfa3fba3574cbf7336ae0393ac4
7
+ data.tar.gz: 76b2d345ea43cd1529362ba300d60c1fe1ac26cd4e2b0bbd529ada0cb7b50852904bebfd502dd7282177a33004583e909301261e56b98079a01ac7b4ba719474
@@ -10,10 +10,10 @@
10
10
  "_type": "text"
11
11
  },
12
12
  {
13
- "name": "credentials",
13
+ "name": "smart_auth_info",
14
14
  "value": null,
15
15
  "_title": "OAuth Credentials",
16
- "_type": "oauth_credentials",
16
+ "_type": "auth_info",
17
17
  "_optional": true
18
18
  },
19
19
  {
@@ -10,10 +10,10 @@
10
10
  "_type": "text"
11
11
  },
12
12
  {
13
- "name": "credentials",
13
+ "name": "smart_auth_info",
14
14
  "value": null,
15
15
  "_title": "OAuth Credentials",
16
- "_type": "oauth_credentials",
16
+ "_type": "auth_info",
17
17
  "_optional": true
18
18
  },
19
19
  {
@@ -1,10 +1,10 @@
1
- require_relative '../client_validation_test.rb'
1
+ require_relative '../client_validation_test'
2
2
 
3
3
  module DaVinciPDexTestKit
4
4
  module PDexPayerClient
5
5
  class PDexInitialMemberMatchValidationTest < Inferno::Test
6
6
  include ClientValidationTest
7
-
7
+
8
8
  id :pdex_initial_member_match_validation
9
9
  title 'Client provides a valid $member-match request'
10
10
  description %(
@@ -12,10 +12,12 @@ module DaVinciPDexTestKit
12
12
  [HRex member-match-in profile](http://hl7.org/fhir/us/davinci-hrex/StructureDefinition/hrex-parameters-member-match-in).
13
13
  )
14
14
  input :access_token
15
-
15
+
16
+ verifies_requirements 'hl7.fhir.us.davinci-pdex_2.0.0@29'
17
+
16
18
  run do
17
- skip_if !member_match_request.present?, "No previous $member-match request received"
18
-
19
+ skip_if !member_match_request.present?, 'No previous $member-match request received'
20
+
19
21
  parameters = FHIR.from_contents(member_match_request.request_body)
20
22
  assert_resource_type(:parameters, resource: parameters)
21
23
  assert_valid_resource(resource: parameters, profile_url: 'http://hl7.org/fhir/us/davinci-hrex/StructureDefinition/hrex-parameters-member-match-in')
@@ -1,7 +1,6 @@
1
1
  module DaVinciPDexTestKit
2
2
  module PDexPayerClient
3
3
  class PDexClientWorkflowInteractionTest < Inferno::Test
4
-
5
4
  id :pdex_client_workflow_interaction
6
5
  title 'Client makes requests to Inferno'
7
6
  description %(
@@ -13,21 +12,23 @@ module DaVinciPDexTestKit
13
12
  )
14
13
  input :access_token
15
14
  config options: { accepts_multiple_requests: true }
16
-
15
+
16
+ verifies_requirements 'hl7.fhir.us.davinci-pdex_2.0.0@27', 'hl7.fhir.us.davinci-pdex_2.0.0@41'
17
+
17
18
  run do
18
19
  wait(
19
20
  identifier: access_token,
20
21
  message: %(
21
22
  Submit PDex requests to find a matching member and retrieve clinical data covering the
22
- complete scope of [member health history data defined by
23
+ complete scope of [member health history data defined by
23
24
  PDex](https://hl7.org/fhir/us/davinci-pdex/STU2/introduction.html#member-health-history).
24
- Available APIs under the Inferno base FHIR include:
25
+ Available APIs under the Inferno base FHIR include:
25
26
  * Single patient $member-match: `#{member_match_url}`
26
- * Single Resource read and search API: `#{submit_url}`, with `:endpoint` replaced with
27
+ * Single Resource read and search API: `#{submit_url}`, with `:endpoint` replaced with
27
28
  the target resource type.
28
29
  * Patient-level $everything: `#{everything_url}`, with `:patient` replaced with the
29
30
  id for the target patient.
30
- * All Patients $export: see workflow process at
31
+ * All Patients $export: see workflow process at
31
32
  the [Bulk Data IG](https://hl7.org/fhir/uv/bulkdata/STU2/export.html#sequence-overview)
32
33
  * Kick-off requests: `#{export_url}`.
33
34
  * Export status requests: `#{export_status_url}?_jobId=:job` as returned in the `content-location`
@@ -35,7 +36,7 @@ module DaVinciPDexTestKit
35
36
  * Retrieval file Requests: `#{binary_url}` with `:id` replaced with an actual id as indicated
36
37
  in the JSON manifest returned with the export status request when the job is completed.
37
38
  Note that the `Accept` header should be `application/fhir+ndjson` on these requests.
38
-
39
+
39
40
  All requests must include the `Authorization` header with value `Bearer #{access_token}`.
40
41
 
41
42
  [Click here](#{resume_clinical_data_url}?token=#{access_token}) when finished making requests
@@ -1,4 +1,3 @@
1
- require 'inferno/dsl/oauth_credentials'
2
1
  require_relative 'pdex_payer_client/urls'
3
2
  require_relative 'pdex_payer_client/tags'
4
3
  require_relative 'pdex_payer_client/collection'
@@ -41,7 +40,7 @@ module DaVinciPDexTestKit
41
40
  id :pdex_payer_client
42
41
  title 'Da Vinci PDex Payer Client Test Suite'
43
42
  description File.read(File.join(__dir__, 'docs', 'payer_client_suite_description_v200.md'))
44
-
43
+
45
44
  links [
46
45
  {
47
46
  label: 'Report Issue',
@@ -78,32 +77,32 @@ module DaVinciPDexTestKit
78
77
  resume_test_route :get, RESUME_CLINICAL_DATA_PATH do |request|
79
78
  PDexPayerClientSuite.extract_token_from_query_params(request)
80
79
  end
81
-
80
+
82
81
  resume_test_route :get, RESUME_FAIL_PATH, result: 'fail' do |request|
83
82
  PDexPayerClientSuite.extract_token_from_query_params(request)
84
83
  end
85
84
 
86
85
  group do
87
86
  run_as_group
88
- title "Workflow Tests"
87
+ title 'Workflow Tests'
89
88
  id :payer_to_payer_workflow
90
89
 
91
90
  group do
92
- title "Interaction Tests"
91
+ title 'Interaction Tests'
93
92
  id :client_workflow_interaction
94
93
 
95
94
  test from: :pdex_client_workflow_interaction
96
95
  end
97
96
 
98
97
  group do
99
- title "$member-match validation"
98
+ title '$member-match validation'
100
99
  id :member_match_validation
101
100
 
102
101
  test from: :pdex_initial_member_match_validation
103
102
  end
104
103
 
105
104
  group do
106
- title "Clinical data request validation"
105
+ title 'Clinical data request validation'
107
106
  id :clinical_data_validation
108
107
 
109
108
  test from: :pdex_clinical_data_request_check
@@ -130,8 +129,8 @@ module DaVinciPDexTestKit
130
129
  test from: :pdex_procedure_clinical_data_request
131
130
  end
132
131
  end
133
-
134
- # TODO must support validation
132
+
133
+ # TODO: must support validation
135
134
 
136
135
  private
137
136
 
@@ -140,4 +139,3 @@ module DaVinciPDexTestKit
140
139
  end
141
140
  end
142
141
  end
143
-
@@ -0,0 +1,50 @@
1
+ require 'us_core_test_kit/must_support_test'
2
+ require 'us_core_test_kit/generator/group_metadata'
3
+
4
+ module DaVinciPDexTestKit
5
+ module PDexPayerServer
6
+ class DeviceMustSupportTest < Inferno::Test
7
+ include USCoreTestKit::MustSupportTest
8
+
9
+ title 'All must support elements are provided in the Device resources returned'
10
+ description %(
11
+ PDex Responders SHALL be capable of populating all data elements as
12
+ part of the query results as specified by the PDex Server Capability
13
+ Statement. This test will look through the Device resources
14
+ found previously for the following must support elements:
15
+
16
+ * Device.distinctIdentifier
17
+ * Device.expirationDate
18
+ * Device.lotNumber
19
+ * Device.patient
20
+ * Device.serialNumber
21
+ * Device.status
22
+ * Device.type
23
+ * Device.udiCarrier
24
+ * Device.udiCarrier.carrierAIDC
25
+ * Device.udiCarrier.carrierHRF
26
+ * Device.udiCarrier.deviceIdentifier
27
+ * Device.url
28
+ )
29
+
30
+ id :pdex_device_must_support
31
+
32
+ def resource_type
33
+ 'Device'
34
+ end
35
+
36
+ def self.metadata
37
+ @metadata ||= USCoreTestKit::Generator::GroupMetadata.new(YAML.load_file(File.join(__dir__, 'metadata.yml'),
38
+ aliases: true))
39
+ end
40
+
41
+ def scratch_resources
42
+ scratch[:device_resources] ||= {}
43
+ end
44
+
45
+ run do
46
+ perform_must_support_test(all_scratch_resources)
47
+ end
48
+ end
49
+ end
50
+ end
@@ -0,0 +1,68 @@
1
+ require 'us_core_test_kit/search_test'
2
+ require 'us_core_test_kit/search_test_properties'
3
+ require 'us_core_test_kit/generator/group_metadata'
4
+
5
+ module DaVinciPDexTestKit
6
+ module PDexPayerServer
7
+ class DevicePatientSearchTest < Inferno::Test
8
+ include USCoreTestKit::SearchTest
9
+
10
+ title 'Server returns valid results for Device search by patient'
11
+ description %(
12
+ A server SHALL support searching by
13
+ patient on the Device resource. This test
14
+ will pass if resources are returned and match the search criteria. If
15
+ none are returned, the test is skipped.
16
+
17
+ This test verifies that the server supports searching by reference using
18
+ the form `patient=[id]` as well as `patient=Patient/[id]`. The two
19
+ different forms are expected to return the same number of results. US
20
+ Core requires that both forms are supported by PDex responders.
21
+
22
+ Because this is the first search of the sequence, resources in the
23
+ response will be used for subsequent tests.
24
+
25
+ Additionally, this test will check that GET and POST search methods
26
+ return the same number of results. Search by POST is required by the
27
+ FHIR R4 specification, and these tests interpret search by GET as a
28
+ requirement of PDex v2.0.0.
29
+
30
+ [PDex Server CapabilityStatement](https://hl7.org/fhir/us/davinci-pdex/STU2/CapabilityStatement-pdex-server.html)
31
+ )
32
+
33
+ id :pdex_device_patient_search
34
+ input :patient_ids,
35
+ title: 'Patient IDs',
36
+ description: 'Comma separated list of patient IDs that in sum contain all MUST SUPPORT elements'
37
+
38
+ input :implantable_device_codes,
39
+ title: 'Implantable Device Type Code',
40
+ description: 'Enter the code for an Implantable Device type, or multiple codes separated by commas. ' \
41
+ 'If blank, Inferno will validate all Device resources against the Implantable Device profile',
42
+ optional: true
43
+
44
+ def self.properties
45
+ @properties ||= USCoreTestKit::SearchTestProperties.new(
46
+ first_search: true,
47
+ resource_type: 'Device',
48
+ search_param_names: ['patient'],
49
+ test_reference_variants: true,
50
+ test_post_search: true
51
+ )
52
+ end
53
+
54
+ def self.metadata
55
+ @metadata ||= USCoreTestKit::Generator::GroupMetadata.new(YAML.load_file(File.join(__dir__, 'metadata.yml'),
56
+ aliases: true))
57
+ end
58
+
59
+ def scratch_resources
60
+ scratch[:device_resources] ||= {}
61
+ end
62
+
63
+ run do
64
+ run_search_test
65
+ end
66
+ end
67
+ end
68
+ end
@@ -0,0 +1,54 @@
1
+ require 'us_core_test_kit/search_test'
2
+ require 'us_core_test_kit/generator/group_metadata'
3
+
4
+ module DaVinciPDexTestKit
5
+ module PDexPayerServer
6
+ class DevicePatientTypeSearchTest < Inferno::Test
7
+ include USCoreTestKit::SearchTest
8
+
9
+ title 'Server returns valid results for Device search by patient + type'
10
+ description %(
11
+ A server SHOULD support searching by
12
+ patient + type on the Device resource. This test
13
+ will pass if resources are returned and match the search criteria. If
14
+ none are returned, the test is skipped.
15
+
16
+ [PDex Server CapabilityStatement](https://hl7.org/fhir/us/davinci-pdex/STU2/CapabilityStatement-pdex-server.html)
17
+ )
18
+
19
+ id :pdex_device_patient_type_search
20
+ optional
21
+
22
+ input :patient_ids,
23
+ title: 'Patient IDs',
24
+ description: 'Comma separated list of patient IDs that in sum contain all MUST SUPPORT elements'
25
+
26
+ input :implantable_device_codes,
27
+ title: 'Implantable Device Type Code',
28
+ description: 'Enter the code for an Implantable Device type, or multiple codes separated by commas. ' \
29
+ 'If blank, Inferno will validate all Device resources against the Implantable Device profile',
30
+ optional: true
31
+
32
+ def self.properties
33
+ @properties ||= USCoreTestKit::SearchTestProperties.new(
34
+ resource_type: 'Device',
35
+ search_param_names: ['patient', 'type'],
36
+ token_search_params: ['type']
37
+ )
38
+ end
39
+
40
+ def self.metadata
41
+ @metadata ||= USCoreTestKit::Generator::GroupMetadata.new(YAML.load_file(File.join(__dir__, 'metadata.yml'),
42
+ aliases: true))
43
+ end
44
+
45
+ def scratch_resources
46
+ scratch[:device_resources] ||= {}
47
+ end
48
+
49
+ run do
50
+ run_search_test
51
+ end
52
+ end
53
+ end
54
+ end
@@ -2,12 +2,12 @@ require 'us_core_test_kit/search_test'
2
2
  require 'us_core_test_kit/search_test_properties'
3
3
  require 'us_core_test_kit/generator/group_metadata'
4
4
 
5
- module USCoreTestKit
6
- module USCoreV311
7
- class ExplanationOfBenefitProvenanceRevincludeSearchTest < Inferno::Test
5
+ module DaVinciPDexTestKit
6
+ module PDexPayerServer
7
+ class DeviceProvenanceRevincludeSearchTest < Inferno::Test
8
8
  include USCoreTestKit::SearchTest
9
9
 
10
- title 'Server returns Provenance resources from ExplanationOfBenefit search by patient + revInclude:Provenance:target'
10
+ title 'Server returns Provenance resources from Device search by patient + revInclude:Provenance:target'
11
11
  description %(
12
12
  A server SHALL be capable of supporting _revIncludes:Provenance:target.
13
13
 
@@ -15,7 +15,7 @@ module USCoreTestKit
15
15
  will pass if a Provenance resource is found in the response.
16
16
  %)
17
17
 
18
- id :pdex_eob_provenance_revinclude_search
18
+ id :pdex_device_provenance_revinclude_search
19
19
 
20
20
  input :patient_ids,
21
21
  title: 'Patient IDs',
@@ -23,7 +23,7 @@ module USCoreTestKit
23
23
 
24
24
  def properties
25
25
  @properties ||= USCoreTestKit::SearchTestProperties.new(
26
- resource_type: 'ExplanationOfBenefit',
26
+ resource_type: 'Device',
27
27
  search_param_names: ['patient']
28
28
  )
29
29
  end
@@ -40,7 +40,7 @@ module USCoreTestKit
40
40
  end
41
41
 
42
42
  def scratch_resources
43
- scratch[:explanation_of_benefit_resources] ||= {}
43
+ scratch[:device_resources] ||= {}
44
44
  end
45
45
 
46
46
  def scratch_provenance_resources
@@ -0,0 +1,26 @@
1
+ require 'us_core_test_kit/read_test'
2
+
3
+ module DaVinciPDexTestKit
4
+ module PDexPayerServer
5
+ class DeviceReadTest < Inferno::Test
6
+ include USCoreTestKit::ReadTest
7
+
8
+ title 'Server returns correct Device resource from Device read interaction'
9
+ description 'A server SHALL support the Device read interaction.'
10
+
11
+ id :pdex_device_read
12
+
13
+ def resource_type
14
+ 'Device'
15
+ end
16
+
17
+ def scratch_resources
18
+ scratch[:device_resources] ||= {}
19
+ end
20
+
21
+ run do
22
+ perform_read_test(all_scratch_resources)
23
+ end
24
+ end
25
+ end
26
+ end
@@ -0,0 +1,42 @@
1
+ require 'us_core_test_kit/reference_resolution_test'
2
+ require 'us_core_test_kit/generator/group_metadata'
3
+
4
+ module DaVinciPDexTestKit
5
+ module PDexPayerServer
6
+ class DeviceReferenceResolutionTest < Inferno::Test
7
+ include USCoreTestKit::ReferenceResolutionTest
8
+
9
+ title 'MustSupport references within Device resources are valid'
10
+ description %(
11
+ This test will attempt to read external references provided within elements
12
+ marked as 'MustSupport', if any are available.
13
+
14
+ It verifies that at least one external reference for each MustSupport Reference element
15
+ can be accessed by the test client, and conforms to corresponding PDex profile.
16
+
17
+ Elements which may provide external references include:
18
+
19
+ * Device.patient
20
+ )
21
+
22
+ id :pdex_device_ref_resolution
23
+
24
+ def resource_type
25
+ 'Device'
26
+ end
27
+
28
+ def self.metadata
29
+ @metadata ||= USCoreTestKit::Generator::GroupMetadata.new(YAML.load_file(File.join(__dir__, 'metadata.yml'),
30
+ aliases: true))
31
+ end
32
+
33
+ def scratch_resources
34
+ scratch[:device_resources] ||= {}
35
+ end
36
+
37
+ run do
38
+ perform_reference_resolution_test(scratch_resources[:all])
39
+ end
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,39 @@
1
+ require 'us_core_test_kit/validation_test'
2
+
3
+ module DaVinciPDexTestKit
4
+ module PDexPayerServer
5
+ class DeviceValidationTest < Inferno::Test
6
+ include USCoreTestKit::ValidationTest
7
+
8
+ id :pdex_device_validation
9
+ title 'Device resources returned during previous tests conform to the PDex Device'
10
+ description %(
11
+ This test verifies resources returned from the first search conform to
12
+ the [PDex Device](http://hl7.org/fhir/us/davinci-pdex/StructureDefinition/pdex-device).
13
+ Systems must demonstrate at least one valid example in order to pass this test.
14
+
15
+ It verifies the presence of mandatory elements and that elements with
16
+ required bindings contain appropriate values. CodeableConcept element
17
+ bindings will fail if none of their codings have a code/system belonging
18
+ to the bound ValueSet. Quantity, Coding, and code element bindings will
19
+ fail if their code/system are not found in the valueset.
20
+ )
21
+ output :dar_code_found, :dar_extension_found
22
+
23
+ def resource_type
24
+ 'Device'
25
+ end
26
+
27
+ def scratch_resources
28
+ scratch[:device_resources] ||= {}
29
+ end
30
+
31
+ run do
32
+ perform_validation_test(scratch_resources[:all] || [],
33
+ 'http://hl7.org/fhir/us/davinci-pdex/StructureDefinition/pdex-device',
34
+ '2.0.0',
35
+ skip_if_empty: true)
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,154 @@
1
+ ---
2
+ :name: pdex_device
3
+ :class_name: PdexDeviceSequence
4
+ :version: v2.0.0
5
+ :reformatted_version: v200
6
+ :resource: Device
7
+ :profile_url: http://hl7.org/fhir/us/davinci-pdex/StructureDefinition/pdex-device
8
+ :profile_name: PDex Device
9
+ :profile_version: 2.0.0
10
+ :title: PDex Device
11
+ :short_description: Verify support for the server capabilities required by the PDex
12
+ Device.
13
+ :is_delayed: false
14
+ :interactions:
15
+ - :code: search-type
16
+ :expectation: SHALL
17
+ - :code: read
18
+ :expectation: SHALL
19
+ - :code: vread
20
+ :expectation: SHOULD
21
+ - :code: history-instance
22
+ :expectation: SHOULD
23
+ - :code: history-type
24
+ :expectation: MAY
25
+ :operations: []
26
+ :searches:
27
+ - :names:
28
+ - patient
29
+ :expectation: SHALL
30
+ :names_not_must_support_or_mandatory: []
31
+ :must_support_or_mandatory: true
32
+ - :expectation: SHOULD
33
+ :names:
34
+ - patient
35
+ - type
36
+ :names_not_must_support_or_mandatory: []
37
+ :must_support_or_mandatory: true
38
+ - :expectation: SHOULD
39
+ :names:
40
+ - patient
41
+ - status
42
+ :names_not_must_support_or_mandatory: []
43
+ :must_support_or_mandatory: true
44
+ :search_definitions:
45
+ :patient:
46
+ :paths:
47
+ - patient
48
+ :full_paths:
49
+ - Device.patient
50
+ :comparators: {}
51
+ :values: []
52
+ :type: Reference
53
+ :contains_multiple: false
54
+ :multiple_or: MAY
55
+ :type:
56
+ :paths:
57
+ - type
58
+ :full_paths:
59
+ - Device.type
60
+ :comparators: {}
61
+ :values: []
62
+ :type: CodeableConcept
63
+ :contains_multiple: false
64
+ :multiple_or: MAY
65
+ :status:
66
+ :paths:
67
+ - status
68
+ :full_paths:
69
+ - Device.status
70
+ :comparators: {}
71
+ :values: []
72
+ :type: CodeableConcept
73
+ :contains_multiple: false
74
+ :multiple_or: MAY
75
+ :include_params: []
76
+ :revincludes:
77
+ - Provenance:target
78
+ :required_concepts: []
79
+ :must_supports:
80
+ :extensions: []
81
+ :slices: []
82
+ :elements:
83
+ - :path: udiCarrier
84
+ - :path: udiCarrier.deviceIdentifier
85
+ - :path: udiCarrier.carrierAIDC
86
+ - :path: udiCarrier.carrierHRF
87
+ - :path: status
88
+ - :path: distinctIdentifier
89
+ - :path: expirationDate
90
+ - :path: lotNumber
91
+ - :path: serialNumber
92
+ - :path: type
93
+ - :path: patient
94
+ :types:
95
+ - Reference
96
+ :target_profiles:
97
+ - http://hl7.org/fhir/us/core/StructureDefinition/us-core-patient
98
+ - :path: url
99
+ :mandatory_elements:
100
+ - Device.udiCarrier.deviceIdentifier
101
+ - Device.deviceName.name
102
+ - Device.deviceName.type
103
+ - Device.type
104
+ - Device.specialization.systemType
105
+ - Device.version.value
106
+ - Device.property.type
107
+ - Device.patient
108
+ :bindings:
109
+ - :type: code
110
+ :strength: required
111
+ :system: http://hl7.org/fhir/ValueSet/udi-entry-type
112
+ :path: udiCarrier.entryType
113
+ - :type: code
114
+ :strength: required
115
+ :system: http://hl7.org/fhir/ValueSet/device-status
116
+ :path: status
117
+ - :type: code
118
+ :strength: required
119
+ :system: http://hl7.org/fhir/ValueSet/device-nametype
120
+ :path: deviceName.type
121
+ :references:
122
+ - :path: Device.definition
123
+ :profiles:
124
+ - http://hl7.org/fhir/StructureDefinition/DeviceDefinition
125
+ - :path: Device.patient
126
+ :profiles:
127
+ - http://hl7.org/fhir/us/core/StructureDefinition/us-core-patient
128
+ - :path: Device.owner
129
+ :profiles:
130
+ - http://hl7.org/fhir/StructureDefinition/Organization
131
+ - :path: Device.location
132
+ :profiles:
133
+ - http://hl7.org/fhir/StructureDefinition/Location
134
+ - :path: Device.parent
135
+ :profiles:
136
+ - http://hl7.org/fhir/StructureDefinition/Device
137
+ :tests:
138
+ - :id: pdex_device_patient_search
139
+ :file_name: device_patient_search_test.rb
140
+ - :id: pdex_device_patient_type_search
141
+ :file_name: device_patient_type_search_test.rb
142
+ - :id: pdex_device_read
143
+ :file_name: device_read_test.rb
144
+ - :id: pdex_device_provenance_revinclude_search
145
+ :file_name: device_provenance_revinclude_search_test.rb
146
+ - :id: pdex_device_validation
147
+ :file_name: device_validation_test.rb
148
+ - :id: pdex_device_must_support
149
+ :file_name: device_must_support_test.rb
150
+ - :id: pdex_device_ref_resolution
151
+ :file_name: device_reference_resolution_test.rb
152
+ :id: pdex_device
153
+ :file_name: device_group.rb
154
+ :delayed_references: []