Module: DaVinciUSDrugFormularyTestKit::ValidationTest
- Included in:
- DaVinciUSDrugFormularyV201::BasicValidationTest, DaVinciUSDrugFormularyV201::FormularyValidationTest, DaVinciUSDrugFormularyV201::LocationValidationTest, DaVinciUSDrugFormularyV201::MedicationKnowledgeValidationTest, DaVinciUSDrugFormularyV201::PayerInsurancePlanValidationTest
- Defined in:
- lib/davinci_us_drug_formulary_test_kit/validation_test.rb
Constant Summary collapse
- DAR_CODE_SYSTEM_URL =
'http://terminology.hl7.org/CodeSystem/data-absent-reason'.freeze
- DAR_EXTENSION_URL =
'http://hl7.org/fhir/StructureDefinition/data-absent-reason'.freeze
Instance Method Summary collapse
- #check_for_dar(resource) ⇒ Object
- #check_for_dar_code(coding) ⇒ Object
- #check_for_dar_extension(resource) ⇒ Object
- #perform_validation_test(resources, profile_url, profile_version, skip_if_empty: true) ⇒ Object
Instance Method Details
#check_for_dar(resource) ⇒ Object
28 29 30 31 32 33 34 35 36 37 38 39 40 |
# File 'lib/davinci_us_drug_formulary_test_kit/validation_test.rb', line 28 def check_for_dar(resource) unless scratch[:dar_code_found] resource.each_element do |element, , _path| next unless element.is_a?(FHIR::Coding) check_for_dar_code(element) end end return if scratch[:dar_extension_found] check_for_dar_extension(resource) end |
#check_for_dar_code(coding) ⇒ Object
42 43 44 45 46 47 |
# File 'lib/davinci_us_drug_formulary_test_kit/validation_test.rb', line 42 def check_for_dar_code(coding) return unless coding.code == 'unknown' && coding.system == DAR_CODE_SYSTEM_URL scratch[:dar_code_found] = true output dar_code_found: 'true' end |
#check_for_dar_extension(resource) ⇒ Object
49 50 51 52 53 54 |
# File 'lib/davinci_us_drug_formulary_test_kit/validation_test.rb', line 49 def check_for_dar_extension(resource) return unless resource.source_contents&.include? DAR_EXTENSION_URL scratch[:dar_extension_found] = true output dar_extension_found: 'true' end |
#perform_validation_test(resources, profile_url, profile_version, skip_if_empty: true) ⇒ Object
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
# File 'lib/davinci_us_drug_formulary_test_kit/validation_test.rb', line 6 def perform_validation_test(resources, profile_url, profile_version, skip_if_empty: true) skip_if skip_if_empty && resources.blank?, "No #{resource_type} resources conforming to the #{profile_url} profile were returned" omit_if resources.blank?, "No #{resource_type} resources provided so the #{profile_url} profile does not apply" profile_with_version = "#{profile_url}|#{profile_version}" resources.each do |resource| resource_is_valid?(resource:, profile_url: profile_with_version) check_for_dar(resource) end errors_found = .any? { || [:type] == 'error' } assert !errors_found, "Resource does not conform to the profile #{profile_with_version}" end |