From 37295083fe888994654a587a4cbd84f13e261f2d Mon Sep 17 00:00:00 2001 From: Nico Matentzoglu Date: Tue, 5 Dec 2023 13:00:22 +0200 Subject: [PATCH] What to do when having a uri-prefix clash? (#473) Note: If you remove either one of the two prefixes, it works --------- Co-authored-by: Harshad Hegde Co-authored-by: Harshad --- tests/test_utils.py | 39 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) diff --git a/tests/test_utils.py b/tests/test_utils.py index fb943115..e8e518e9 100644 --- a/tests/test_utils.py +++ b/tests/test_utils.py @@ -5,7 +5,7 @@ import numpy as np import pandas as pd import yaml -from curies import Converter, Record +from curies import Converter, Record, chain from sssom_schema import Mapping as SSSOM_Mapping from sssom.constants import ( @@ -430,3 +430,40 @@ def test_get_dict_from_mapping(self): else: self.assertEqual(value, result_with_mapping_object[key]) self.assertEqual(value, result_with_dict[key]) + + def test_curiechain_with_conflicts(self): + """Test curie map with CURIE/URI clashes.""" + PREFIXMAP_BOTH = { + "SCTID": "http://identifiers.org/snomedct/", + "SCTID__2": "http://snomed.info/id/", + } + PREFIXMAP_FIRST = { + "SCTID": "http://identifiers.org/snomedct/", + } + PREFIXMAP_SECOND = { + "SCTID__2": "http://snomed.info/id/", + } + + EPM = [ + { + "prefix": "SCTID", + "prefix_synonyms": ["snomed"], + "uri_prefix": "http://snomed.info/id/", + }, + ] + + converter = chain( + [Converter.from_prefix_map(PREFIXMAP_FIRST), Converter.from_extended_prefix_map(EPM)] + ) + self.assertIn("SCTID", converter.prefix_map) + converter = chain( + [Converter.from_prefix_map(PREFIXMAP_SECOND), Converter.from_extended_prefix_map(EPM)] + ) + self.assertIn("SCTID", converter.prefix_map) + # Fails here: + with self.assertRaises(ValueError): + chain( + [Converter.from_prefix_map(PREFIXMAP_BOTH), Converter.from_extended_prefix_map(EPM)] + ) + + # self.assertIn("SCTID", converter.prefix_map)