require_relative '../test_helper' class CodesToJsonTest < Test::Unit::TestCase def setup end def test_parsing_from_xml codes_file_path = File.expand_path("../../fixtures/codes/codes.xml", __FILE__) # Parse the code systems that are mapped to the OIDs we support codes_json = HQMF2JS::Generator::CodesToJson.hash_to_js(HQMF2JS::Generator::CodesToJson.from_xml(codes_file_path)) @context = get_js_context("var dictionary = #{codes_json}") @context.eval("dictionary").entries.length.must_equal 19 @context.eval("dictionary['2.16.840.1.113883.3.464.1.42']").entries.first[0].must_equal "CPT" @context.eval("dictionary['2.16.840.1.113883.3.464.1.42']").entries.first[1].length.must_equal 19 end def test_codes_to_json value_sets = JSON.parse(File.read(File.join('test','fixtures','codes','codes.json'))).map {|vs| HealthDataStandards::SVS::ValueSet.new(vs)} oid_map = HQMF2JS::Generator::CodesToJson.from_value_sets(value_sets) oid_map.keys.sort.must_equal ["1.2.3.4.5","1.2.3.4.6"] oid_map["1.2.3.4.5"].keys.sort.must_equal ["ICD-9-CM","SNOMED-CT"] oid_map["1.2.3.4.5"]["ICD-9-CM"].sort.must_equal ["126", "127"] oid_map["1.2.3.4.5"]["SNOMED-CT"].sort.must_equal ["123", "124", "125"] oid_map["1.2.3.4.6"].keys.sort.must_equal ["CPT","SNOMED-CT"] oid_map["1.2.3.4.6"]["CPT"].sort.must_equal ["125C", "126D", "127E"] oid_map["1.2.3.4.6"]["SNOMED-CT"].sort.must_equal ["123A", "124B"] # def self.from_value_sets(value_sets) # # make sure we have a string keyed hash # value_sets = JSON.parse(value_sets.to_json) # translation = {} # value_sets.each do |value_set| # code_sets = {} # value_set["concepts"].each do |code_set| # code_sets[code_set["code_system_name"]] ||= [] # code_sets[code_set["code_system_name"]].concat(code_set["code"].to_a) # end # translation[value_set["oid"]] = code_sets # end # translation # end end end