require_relative 'observation_pregnancyintent/observation_pregnancyintent_patient_code_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_patient_category_date_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_patient_code_date_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_patient_category_status_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_patient_category_lastupdated_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_patient_category_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_read_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_provenance_revinclude_search_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_validation_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_must_support_test' require_relative 'observation_pregnancyintent/observation_pregnancyintent_reference_resolution_test' module USCoreTestKit module USCoreV700 class ObservationPregnancyintentGroup < Inferno::TestGroup title 'Observation Pregnancy Intent Tests' short_description 'Verify support for the server capabilities required by the US Core Observation Pregnancy Intent Profile.' description %( # Background The US Core Observation Pregnancy Intent sequence verifies that the system under test is able to provide correct responses for Observation queries. These queries must contain resources conforming to the US Core Observation Pregnancy Intent Profile as specified in the US Core v7.0.0 Implementation Guide. # Testing Methodology ## Searching This test sequence will first perform each required search associated with this resource. This sequence will perform searches with the following parameters: * patient + code * patient + category + date * patient + category ### Search Parameters The first search uses the selected patient(s) from the prior launch sequence. Any subsequent searches will look for its parameter values from the results of the first search. For example, the `identifier` search in the patient sequence is performed by looking for an existing `Patient.identifier` from any of the resources returned in the `_id` search. If a value cannot be found this way, the search is skipped. ### Search Validation Inferno will retrieve up to the first 20 bundle pages of the reply for Observation resources and save them for subsequent tests. Each of these resources is then checked to see if it matches the searched parameters in accordance with [FHIR search guidelines](https://www.hl7.org/fhir/search.html). The test will fail, for example, if a Patient search for `gender=male` returns a `female` patient. ## Must Support Each profile contains elements marked as "must support". This test sequence expects to see each of these elements at least once. If at least one cannot be found, the test will fail. The test will look through the Observation resources found in the first test for these elements. ## Profile Validation Each resource returned from the first search is expected to conform to the [US Core Observation Pregnancy Intent Profile](http://hl7.org/fhir/us/core/StructureDefinition/us-core-observation-pregnancyintent). Each element is checked against teminology binding and cardinality requirements. Elements with a required binding are validated against their bound ValueSet. If the code/system in the element is not part of the ValueSet, then the test will fail. ## Reference Validation At least one instance of each external reference in elements marked as "must support" within the resources provided by the system must resolve. The test will attempt to read each reference found and will fail if no read succeeds. ) id :us_core_v700_observation_pregnancyintent run_as_group def self.metadata @metadata ||= Generator::GroupMetadata.new(YAML.load_file(File.join(__dir__, 'observation_pregnancyintent', 'metadata.yml'), aliases: true)) end test from: :us_core_v700_observation_pregnancyintent_patient_code_search_test test from: :us_core_v700_observation_pregnancyintent_patient_category_date_search_test test from: :us_core_v700_observation_pregnancyintent_patient_code_date_search_test test from: :us_core_v700_observation_pregnancyintent_patient_category_status_search_test test from: :us_core_v700_observation_pregnancyintent_patient_category__lastUpdated_search_test test from: :us_core_v700_observation_pregnancyintent_patient_category_search_test test from: :us_core_v700_observation_pregnancyintent_read_test test from: :us_core_v700_observation_pregnancyintent_provenance_revinclude_search_test test from: :us_core_v700_observation_pregnancyintent_validation_test test from: :us_core_v700_observation_pregnancyintent_must_support_test test from: :us_core_v700_observation_pregnancyintent_reference_resolution_test end end end