Module: DaVinciPASTestKit::ValidationTest

Included in:
PasBundleValidation
Defined in:
lib/davinci_pas_test_kit/validation_test.rb

Constant Summary collapse

DAR_CODE_SYSTEM_URL =
'http://terminology.hl7.org/CodeSystem/data-absent-reason'
DAR_EXTENSION_URL =
'http://hl7.org/fhir/StructureDefinition/data-absent-reason'

Instance Method Summary collapse

Instance Method Details

#check_for_dar(resource) ⇒ Object



29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/davinci_pas_test_kit/validation_test.rb', line 29

def check_for_dar(resource)
  unless scratch[:dar_code_found]
    resource.each_element do |element, _meta, _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



43
44
45
46
47
48
# File 'lib/davinci_pas_test_kit/validation_test.rb', line 43

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



50
51
52
53
54
55
# File 'lib/davinci_pas_test_kit/validation_test.rb', line 50

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



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# File 'lib/davinci_pas_test_kit/validation_test.rb', line 8

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 = messages.any? { |message| message[:type] == 'error' }

  assert !errors_found, "Resource does not conform to the profile #{profile_with_version}"
end