cognee 0.3.3__py3-none-any.whl → 0.3.4__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. cognee/api/v1/cloud/routers/get_checks_router.py +1 -1
  2. cognee/api/v1/cognify/cognify.py +44 -7
  3. cognee/api/v1/cognify/routers/get_cognify_router.py +2 -1
  4. cognee/api/v1/prune/prune.py +2 -2
  5. cognee/api/v1/search/search.py +1 -1
  6. cognee/api/v1/sync/sync.py +16 -5
  7. cognee/base_config.py +19 -1
  8. cognee/eval_framework/corpus_builder/task_getters/get_default_tasks_by_indices.py +2 -2
  9. cognee/infrastructure/databases/graph/kuzu/remote_kuzu_adapter.py +4 -1
  10. cognee/infrastructure/databases/relational/ModelBase.py +2 -1
  11. cognee/infrastructure/databases/vector/chromadb/ChromaDBAdapter.py +2 -6
  12. cognee/infrastructure/databases/vector/embeddings/OllamaEmbeddingEngine.py +6 -5
  13. cognee/infrastructure/files/storage/LocalFileStorage.py +50 -0
  14. cognee/infrastructure/files/storage/S3FileStorage.py +56 -9
  15. cognee/infrastructure/files/storage/StorageManager.py +18 -0
  16. cognee/infrastructure/files/utils/get_file_metadata.py +6 -1
  17. cognee/infrastructure/llm/structured_output_framework/litellm_instructor/llm/anthropic/adapter.py +4 -2
  18. cognee/modules/cloud/operations/check_api_key.py +4 -1
  19. cognee/modules/data/deletion/prune_system.py +5 -1
  20. cognee/modules/data/methods/create_authorized_dataset.py +9 -0
  21. cognee/modules/data/methods/get_authorized_dataset.py +1 -1
  22. cognee/modules/data/methods/get_authorized_dataset_by_name.py +11 -0
  23. cognee/modules/graph/utils/expand_with_nodes_and_edges.py +22 -8
  24. cognee/modules/graph/utils/retrieve_existing_edges.py +0 -2
  25. cognee/modules/notebooks/methods/create_notebook.py +34 -0
  26. cognee/modules/notebooks/methods/get_notebooks.py +27 -1
  27. cognee/modules/notebooks/models/Notebook.py +206 -1
  28. cognee/modules/observability/get_observe.py +14 -0
  29. cognee/modules/observability/observers.py +1 -0
  30. cognee/modules/ontology/base_ontology_resolver.py +42 -0
  31. cognee/modules/ontology/get_default_ontology_resolver.py +41 -0
  32. cognee/modules/ontology/matching_strategies.py +53 -0
  33. cognee/modules/ontology/models.py +20 -0
  34. cognee/modules/ontology/ontology_config.py +24 -0
  35. cognee/modules/ontology/ontology_env_config.py +45 -0
  36. cognee/modules/ontology/rdf_xml/{OntologyResolver.py → RDFLibOntologyResolver.py} +20 -28
  37. cognee/modules/pipelines/layers/resolve_authorized_user_dataset.py +13 -0
  38. cognee/modules/pipelines/layers/resolve_authorized_user_datasets.py +1 -1
  39. cognee/modules/pipelines/models/PipelineRunInfo.py +7 -2
  40. cognee/modules/retrieval/temporal_retriever.py +2 -2
  41. cognee/modules/search/methods/get_search_type_tools.py +7 -0
  42. cognee/modules/search/methods/search.py +12 -13
  43. cognee/modules/search/utils/prepare_search_result.py +28 -6
  44. cognee/modules/search/utils/transform_context_to_graph.py +1 -1
  45. cognee/modules/search/utils/transform_insights_to_graph.py +28 -0
  46. cognee/modules/users/methods/create_user.py +4 -24
  47. cognee/modules/users/permissions/methods/authorized_give_permission_on_datasets.py +12 -0
  48. cognee/modules/users/permissions/methods/check_permission_on_dataset.py +11 -0
  49. cognee/modules/users/permissions/methods/get_all_user_permission_datasets.py +19 -2
  50. cognee/modules/users/permissions/methods/get_document_ids_for_user.py +10 -0
  51. cognee/modules/users/permissions/methods/get_principal.py +9 -0
  52. cognee/modules/users/permissions/methods/get_principal_datasets.py +11 -0
  53. cognee/modules/users/permissions/methods/get_role.py +10 -0
  54. cognee/modules/users/permissions/methods/get_specific_user_permission_datasets.py +3 -3
  55. cognee/modules/users/permissions/methods/get_tenant.py +9 -0
  56. cognee/modules/users/permissions/methods/give_default_permission_to_role.py +9 -0
  57. cognee/modules/users/permissions/methods/give_default_permission_to_tenant.py +9 -0
  58. cognee/modules/users/permissions/methods/give_default_permission_to_user.py +9 -0
  59. cognee/modules/users/permissions/methods/give_permission_on_dataset.py +10 -0
  60. cognee/modules/users/roles/methods/add_user_to_role.py +11 -0
  61. cognee/modules/users/roles/methods/create_role.py +10 -0
  62. cognee/modules/users/tenants/methods/add_user_to_tenant.py +12 -0
  63. cognee/modules/users/tenants/methods/create_tenant.py +10 -0
  64. cognee/root_dir.py +5 -0
  65. cognee/shared/cache.py +346 -0
  66. cognee/shared/utils.py +12 -0
  67. cognee/tasks/graph/extract_graph_from_data.py +53 -10
  68. cognee/tasks/graph/extract_graph_from_data_v2.py +16 -4
  69. cognee/tasks/ingestion/save_data_item_to_storage.py +1 -0
  70. cognee/tasks/temporal_graph/models.py +11 -6
  71. cognee/tests/cli_tests/cli_unit_tests/test_cli_main.py +5 -5
  72. cognee/tests/test_cognee_server_start.py +4 -4
  73. cognee/tests/test_temporal_graph.py +6 -34
  74. cognee/tests/unit/modules/ontology/test_ontology_adapter.py +330 -13
  75. cognee/tests/unit/modules/users/test_tutorial_notebook_creation.py +399 -0
  76. {cognee-0.3.3.dist-info → cognee-0.3.4.dist-info}/METADATA +11 -8
  77. {cognee-0.3.3.dist-info → cognee-0.3.4.dist-info}/RECORD +81 -73
  78. cognee/modules/notebooks/methods/create_tutorial_notebook.py +0 -92
  79. {cognee-0.3.3.dist-info → cognee-0.3.4.dist-info}/WHEEL +0 -0
  80. {cognee-0.3.3.dist-info → cognee-0.3.4.dist-info}/entry_points.txt +0 -0
  81. {cognee-0.3.3.dist-info → cognee-0.3.4.dist-info}/licenses/LICENSE +0 -0
  82. {cognee-0.3.3.dist-info → cognee-0.3.4.dist-info}/licenses/NOTICE.md +0 -0
@@ -48,7 +48,7 @@ class TestCogneeServerStart(unittest.TestCase):
48
48
  """Test that the server is running and can accept connections."""
49
49
  # Test health endpoint
50
50
  health_response = requests.get("http://localhost:8000/health", timeout=15)
51
- self.assertIn(health_response.status_code, [200, 503])
51
+ self.assertIn(health_response.status_code, [200])
52
52
 
53
53
  # Test root endpoint
54
54
  root_response = requests.get("http://localhost:8000/", timeout=15)
@@ -88,7 +88,7 @@ class TestCogneeServerStart(unittest.TestCase):
88
88
  payload = {"datasets": [dataset_name]}
89
89
 
90
90
  add_response = requests.post(url, headers=headers, data=form_data, files=file, timeout=50)
91
- if add_response.status_code not in [200, 201, 409]:
91
+ if add_response.status_code not in [200, 201]:
92
92
  add_response.raise_for_status()
93
93
 
94
94
  # Cognify request
@@ -99,7 +99,7 @@ class TestCogneeServerStart(unittest.TestCase):
99
99
  }
100
100
 
101
101
  cognify_response = requests.post(url, headers=headers, json=payload, timeout=150)
102
- if cognify_response.status_code not in [200, 201, 409]:
102
+ if cognify_response.status_code not in [200, 201]:
103
103
  cognify_response.raise_for_status()
104
104
 
105
105
  # TODO: Add test to verify cognify pipeline is complete before testing search
@@ -115,7 +115,7 @@ class TestCogneeServerStart(unittest.TestCase):
115
115
  payload = {"searchType": "GRAPH_COMPLETION", "query": "What's in the document?"}
116
116
 
117
117
  search_response = requests.post(url, headers=headers, json=payload, timeout=50)
118
- if search_response.status_code not in [200, 201, 409]:
118
+ if search_response.status_code not in [200, 201]:
119
119
  search_response.raise_for_status()
120
120
 
121
121
 
@@ -97,7 +97,7 @@ async def main():
97
97
  f"Expected exactly one DocumentChunk, but found {type_counts.get('DocumentChunk', 0)}"
98
98
  )
99
99
 
100
- assert type_counts.get("Entity", 0) >= 20, (
100
+ assert type_counts.get("Entity", 0) >= 10, (
101
101
  f"Expected multiple entities (assert is set to 20), but found {type_counts.get('Entity', 0)}"
102
102
  )
103
103
 
@@ -105,52 +105,24 @@ async def main():
105
105
  f"Expected multiple entity types, but found {type_counts.get('EntityType', 0)}"
106
106
  )
107
107
 
108
- assert type_counts.get("Event", 0) >= 20, (
108
+ assert type_counts.get("Event", 0) >= 10, (
109
109
  f"Expected multiple events (assert is set to 20), but found {type_counts.get('Event', 0)}"
110
110
  )
111
111
 
112
- assert type_counts.get("Timestamp", 0) >= 20, (
113
- f"Expected multiple timestamps (assert is set to 20), but found {type_counts.get('Timestamp', 0)}"
112
+ assert type_counts.get("Timestamp", 0) >= 10, (
113
+ f"Expected multiple timestamps (assert is set to 10), but found {type_counts.get('Timestamp', 0)}"
114
114
  )
115
115
 
116
- assert type_counts.get("Interval", 0) >= 2, (
117
- f"Expected multiple intervals, but found {type_counts.get('Interval', 0)}"
118
- )
119
-
120
- assert edge_type_counts.get("contains", 0) >= 20, (
116
+ assert edge_type_counts.get("contains", 0) >= 10, (
121
117
  f"Expected multiple 'contains' edge, but found {edge_type_counts.get('contains', 0)}"
122
118
  )
123
119
 
124
- assert edge_type_counts.get("is_a", 0) >= 20, (
120
+ assert edge_type_counts.get("is_a", 0) >= 10, (
125
121
  f"Expected multiple 'is_a' edge, but found {edge_type_counts.get('is_a', 0)}"
126
122
  )
127
123
 
128
- assert edge_type_counts.get("during", 0) == type_counts.get("Interval", 0), (
129
- "Expected the same amount of during and interval objects in the graph"
130
- )
131
-
132
- assert edge_type_counts.get("during", 0) == type_counts.get("Interval", 0), (
133
- "Expected the same amount of during and interval objects in the graph"
134
- )
135
-
136
- assert edge_type_counts.get("time_from", 0) == type_counts.get("Interval", 0), (
137
- "Expected the same amount of time_from and interval objects in the graph"
138
- )
139
-
140
- assert edge_type_counts.get("time_to", 0) == type_counts.get("Interval", 0), (
141
- "Expected the same amount of time_to and interval objects in the graph"
142
- )
143
-
144
124
  retriever = TemporalRetriever()
145
125
 
146
- result_before = await retriever.extract_time_from_query("What happened before 1890?")
147
-
148
- assert result_before[0] is None
149
-
150
- result_after = await retriever.extract_time_from_query("What happened after 1891?")
151
-
152
- assert result_after[1] is None
153
-
154
126
  result_between = await retriever.extract_time_from_query("What happened between 1890 and 1900?")
155
127
 
156
128
  assert result_between[1]
@@ -1,12 +1,14 @@
1
1
  import pytest
2
2
  from rdflib import Graph, Namespace, RDF, OWL, RDFS
3
- from cognee.modules.ontology.rdf_xml.OntologyResolver import OntologyResolver, AttachedOntologyNode
3
+ from cognee.modules.ontology.rdf_xml.RDFLibOntologyResolver import RDFLibOntologyResolver
4
+ from cognee.modules.ontology.models import AttachedOntologyNode
5
+ from cognee.modules.ontology.get_default_ontology_resolver import get_default_ontology_resolver
4
6
 
5
7
 
6
8
  def test_ontology_adapter_initialization_success():
7
- """Test successful initialization of OntologyAdapter."""
9
+ """Test successful initialization of RDFLibOntologyResolver from get_default_ontology_resolver."""
8
10
 
9
- adapter = OntologyResolver()
11
+ adapter = get_default_ontology_resolver()
10
12
  adapter.build_lookup()
11
13
 
12
14
  assert isinstance(adapter.lookup, dict)
@@ -14,7 +16,7 @@ def test_ontology_adapter_initialization_success():
14
16
 
15
17
  def test_ontology_adapter_initialization_file_not_found():
16
18
  """Test OntologyAdapter initialization with nonexistent file."""
17
- adapter = OntologyResolver(ontology_file="nonexistent.owl")
19
+ adapter = RDFLibOntologyResolver(ontology_file="nonexistent.owl")
18
20
  assert adapter.graph is None
19
21
 
20
22
 
@@ -27,7 +29,7 @@ def test_build_lookup():
27
29
 
28
30
  g.add((ns.Audi, RDF.type, ns.Car))
29
31
 
30
- resolver = OntologyResolver()
32
+ resolver = RDFLibOntologyResolver()
31
33
  resolver.graph = g
32
34
  resolver.build_lookup()
33
35
 
@@ -50,7 +52,7 @@ def test_find_closest_match_exact():
50
52
  g.add((ns.Car, RDF.type, OWL.Class))
51
53
  g.add((ns.Audi, RDF.type, ns.Car))
52
54
 
53
- resolver = OntologyResolver()
55
+ resolver = RDFLibOntologyResolver()
54
56
  resolver.graph = g
55
57
  resolver.build_lookup()
56
58
 
@@ -71,7 +73,7 @@ def test_find_closest_match_fuzzy():
71
73
  g.add((ns.Audi, RDF.type, ns.Car))
72
74
  g.add((ns.BMW, RDF.type, ns.Car))
73
75
 
74
- resolver = OntologyResolver()
76
+ resolver = RDFLibOntologyResolver()
75
77
  resolver.graph = g
76
78
  resolver.build_lookup()
77
79
 
@@ -92,7 +94,7 @@ def test_find_closest_match_no_match():
92
94
  g.add((ns.Audi, RDF.type, ns.Car))
93
95
  g.add((ns.BMW, RDF.type, ns.Car))
94
96
 
95
- resolver = OntologyResolver()
97
+ resolver = RDFLibOntologyResolver()
96
98
  resolver.graph = g
97
99
  resolver.build_lookup()
98
100
 
@@ -102,10 +104,10 @@ def test_find_closest_match_no_match():
102
104
 
103
105
 
104
106
  def test_get_subgraph_no_match_rdflib():
105
- """Test get_subgraph returns empty results for a non-existent node."""
107
+ """Test get_subgraph returns empty results for a non-existent node using RDFLibOntologyResolver."""
106
108
  g = Graph()
107
109
 
108
- resolver = OntologyResolver()
110
+ resolver = get_default_ontology_resolver()
109
111
  resolver.graph = g
110
112
  resolver.build_lookup()
111
113
 
@@ -138,7 +140,7 @@ def test_get_subgraph_success_rdflib():
138
140
  g.add((ns.VW, owns, ns.Audi))
139
141
  g.add((ns.VW, owns, ns.Porsche))
140
142
 
141
- resolver = OntologyResolver()
143
+ resolver = RDFLibOntologyResolver()
142
144
  resolver.graph = g
143
145
  resolver.build_lookup()
144
146
 
@@ -160,10 +162,10 @@ def test_get_subgraph_success_rdflib():
160
162
 
161
163
 
162
164
  def test_refresh_lookup_rdflib():
163
- """Test that refresh_lookup rebuilds the lookup dict into a new object."""
165
+ """Test that refresh_lookup rebuilds the lookup dict into a new object using RDFLibOntologyResolver."""
164
166
  g = Graph()
165
167
 
166
- resolver = OntologyResolver()
168
+ resolver = get_default_ontology_resolver()
167
169
  resolver.graph = g
168
170
  resolver.build_lookup()
169
171
 
@@ -172,3 +174,318 @@ def test_refresh_lookup_rdflib():
172
174
  resolver.refresh_lookup()
173
175
 
174
176
  assert resolver.lookup is not original_lookup
177
+
178
+
179
+ def test_fuzzy_matching_strategy_exact_match():
180
+ """Test FuzzyMatchingStrategy finds exact matches."""
181
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
182
+
183
+ strategy = FuzzyMatchingStrategy()
184
+ candidates = ["audi", "bmw", "mercedes"]
185
+
186
+ result = strategy.find_match("audi", candidates)
187
+ assert result == "audi"
188
+
189
+
190
+ def test_fuzzy_matching_strategy_fuzzy_match():
191
+ """Test FuzzyMatchingStrategy finds fuzzy matches."""
192
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
193
+
194
+ strategy = FuzzyMatchingStrategy(cutoff=0.6)
195
+ candidates = ["audi", "bmw", "mercedes"]
196
+
197
+ result = strategy.find_match("audii", candidates)
198
+ assert result == "audi"
199
+
200
+
201
+ def test_fuzzy_matching_strategy_no_match():
202
+ """Test FuzzyMatchingStrategy returns None when no match meets cutoff."""
203
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
204
+
205
+ strategy = FuzzyMatchingStrategy(cutoff=0.9)
206
+ candidates = ["audi", "bmw", "mercedes"]
207
+
208
+ result = strategy.find_match("completely_different", candidates)
209
+ assert result is None
210
+
211
+
212
+ def test_fuzzy_matching_strategy_empty_candidates():
213
+ """Test FuzzyMatchingStrategy handles empty candidates list."""
214
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
215
+
216
+ strategy = FuzzyMatchingStrategy()
217
+
218
+ result = strategy.find_match("audi", [])
219
+ assert result is None
220
+
221
+
222
+ def test_base_ontology_resolver_initialization():
223
+ """Test BaseOntologyResolver initialization with default matching strategy."""
224
+ from cognee.modules.ontology.base_ontology_resolver import BaseOntologyResolver
225
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
226
+
227
+ class TestOntologyResolver(BaseOntologyResolver):
228
+ def build_lookup(self):
229
+ pass
230
+
231
+ def refresh_lookup(self):
232
+ pass
233
+
234
+ def find_closest_match(self, name, category):
235
+ return None
236
+
237
+ def get_subgraph(self, node_name, node_type="individuals", directed=True):
238
+ return [], [], None
239
+
240
+ resolver = TestOntologyResolver()
241
+ assert isinstance(resolver.matching_strategy, FuzzyMatchingStrategy)
242
+
243
+
244
+ def test_base_ontology_resolver_custom_matching_strategy():
245
+ """Test BaseOntologyResolver initialization with custom matching strategy."""
246
+ from cognee.modules.ontology.base_ontology_resolver import BaseOntologyResolver
247
+ from cognee.modules.ontology.matching_strategies import MatchingStrategy
248
+
249
+ class CustomMatchingStrategy(MatchingStrategy):
250
+ def find_match(self, name, candidates):
251
+ return "custom_match"
252
+
253
+ class TestOntologyResolver(BaseOntologyResolver):
254
+ def build_lookup(self):
255
+ pass
256
+
257
+ def refresh_lookup(self):
258
+ pass
259
+
260
+ def find_closest_match(self, name, category):
261
+ return None
262
+
263
+ def get_subgraph(self, node_name, node_type="individuals", directed=True):
264
+ return [], [], None
265
+
266
+ custom_strategy = CustomMatchingStrategy()
267
+ resolver = TestOntologyResolver(matching_strategy=custom_strategy)
268
+ assert resolver.matching_strategy == custom_strategy
269
+
270
+
271
+ def test_ontology_config_structure():
272
+ """Test TypedDict structure for ontology configuration."""
273
+ from cognee.modules.ontology.ontology_config import Config
274
+ from cognee.modules.ontology.rdf_xml.RDFLibOntologyResolver import RDFLibOntologyResolver
275
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
276
+
277
+ matching_strategy = FuzzyMatchingStrategy()
278
+ resolver = RDFLibOntologyResolver(matching_strategy=matching_strategy)
279
+
280
+ config: Config = {"ontology_config": {"ontology_resolver": resolver}}
281
+
282
+ assert config["ontology_config"]["ontology_resolver"] == resolver
283
+
284
+
285
+ def test_get_ontology_resolver_default():
286
+ """Test get_default_ontology_resolver returns a properly configured RDFLibOntologyResolver with FuzzyMatchingStrategy."""
287
+ from cognee.modules.ontology.rdf_xml.RDFLibOntologyResolver import RDFLibOntologyResolver
288
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
289
+
290
+ resolver = get_default_ontology_resolver()
291
+
292
+ assert isinstance(resolver, RDFLibOntologyResolver)
293
+ assert isinstance(resolver.matching_strategy, FuzzyMatchingStrategy)
294
+
295
+
296
+ def test_get_default_ontology_resolver():
297
+ """Test get_default_ontology_resolver returns a properly configured RDFLibOntologyResolver with FuzzyMatchingStrategy."""
298
+ from cognee.modules.ontology.rdf_xml.RDFLibOntologyResolver import RDFLibOntologyResolver
299
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
300
+
301
+ resolver = get_default_ontology_resolver()
302
+
303
+ assert isinstance(resolver, RDFLibOntologyResolver)
304
+ assert isinstance(resolver.matching_strategy, FuzzyMatchingStrategy)
305
+
306
+
307
+ def test_rdflib_ontology_resolver_uses_matching_strategy():
308
+ """Test that RDFLibOntologyResolver uses the provided matching strategy."""
309
+ from cognee.modules.ontology.matching_strategies import MatchingStrategy
310
+
311
+ class TestMatchingStrategy(MatchingStrategy):
312
+ def find_match(self, name, candidates):
313
+ return "test_match" if candidates else None
314
+
315
+ ns = Namespace("http://example.org/test#")
316
+ g = Graph()
317
+ g.add((ns.Car, RDF.type, OWL.Class))
318
+ g.add((ns.Audi, RDF.type, ns.Car))
319
+
320
+ resolver = RDFLibOntologyResolver(matching_strategy=TestMatchingStrategy())
321
+ resolver.graph = g
322
+ resolver.build_lookup()
323
+
324
+ result = resolver.find_closest_match("Audi", "individuals")
325
+ assert result == "test_match"
326
+
327
+
328
+ def test_rdflib_ontology_resolver_default_matching_strategy():
329
+ """Test that RDFLibOntologyResolver uses FuzzyMatchingStrategy by default."""
330
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
331
+
332
+ resolver = RDFLibOntologyResolver()
333
+ assert isinstance(resolver.matching_strategy, FuzzyMatchingStrategy)
334
+
335
+
336
+ def test_get_ontology_resolver_from_env_success():
337
+ """Test get_ontology_resolver_from_env returns correct resolver with valid parameters."""
338
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
339
+ from cognee.modules.ontology.rdf_xml.RDFLibOntologyResolver import RDFLibOntologyResolver
340
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
341
+
342
+ resolver = get_ontology_resolver_from_env(
343
+ ontology_resolver="rdflib", matching_strategy="fuzzy", ontology_file_path="/test/path.owl"
344
+ )
345
+
346
+ assert isinstance(resolver, RDFLibOntologyResolver)
347
+ assert isinstance(resolver.matching_strategy, FuzzyMatchingStrategy)
348
+ assert resolver.ontology_file == "/test/path.owl"
349
+
350
+
351
+ def test_get_ontology_resolver_from_env_unsupported_resolver():
352
+ """Test get_ontology_resolver_from_env raises EnvironmentError for unsupported resolver."""
353
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
354
+
355
+ with pytest.raises(EnvironmentError) as exc_info:
356
+ get_ontology_resolver_from_env(
357
+ ontology_resolver="unsupported",
358
+ matching_strategy="fuzzy",
359
+ ontology_file_path="/test/path.owl",
360
+ )
361
+
362
+ assert "Unsupported ontology resolver: unsupported" in str(exc_info.value)
363
+ assert "Supported resolvers are: RdfLib with FuzzyMatchingStrategy" in str(exc_info.value)
364
+
365
+
366
+ def test_get_ontology_resolver_from_env_unsupported_strategy():
367
+ """Test get_ontology_resolver_from_env raises EnvironmentError for unsupported strategy."""
368
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
369
+
370
+ with pytest.raises(EnvironmentError) as exc_info:
371
+ get_ontology_resolver_from_env(
372
+ ontology_resolver="rdflib",
373
+ matching_strategy="unsupported",
374
+ ontology_file_path="/test/path.owl",
375
+ )
376
+
377
+ assert "Unsupported ontology resolver: rdflib" in str(exc_info.value)
378
+
379
+
380
+ def test_get_ontology_resolver_from_env_empty_file_path():
381
+ """Test get_ontology_resolver_from_env raises EnvironmentError for empty file path."""
382
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
383
+
384
+ with pytest.raises(EnvironmentError) as exc_info:
385
+ get_ontology_resolver_from_env(
386
+ ontology_resolver="rdflib", matching_strategy="fuzzy", ontology_file_path=""
387
+ )
388
+
389
+ assert "Unsupported ontology resolver: rdflib" in str(exc_info.value)
390
+
391
+
392
+ def test_get_ontology_resolver_from_env_none_file_path():
393
+ """Test get_ontology_resolver_from_env raises EnvironmentError for None file path."""
394
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
395
+
396
+ with pytest.raises(EnvironmentError) as exc_info:
397
+ get_ontology_resolver_from_env(
398
+ ontology_resolver="rdflib", matching_strategy="fuzzy", ontology_file_path=None
399
+ )
400
+
401
+ assert "Unsupported ontology resolver: rdflib" in str(exc_info.value)
402
+
403
+
404
+ def test_get_ontology_resolver_from_env_empty_resolver():
405
+ """Test get_ontology_resolver_from_env raises EnvironmentError for empty resolver."""
406
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
407
+
408
+ with pytest.raises(EnvironmentError) as exc_info:
409
+ get_ontology_resolver_from_env(
410
+ ontology_resolver="", matching_strategy="fuzzy", ontology_file_path="/test/path.owl"
411
+ )
412
+
413
+ assert "Unsupported ontology resolver:" in str(exc_info.value)
414
+
415
+
416
+ def test_get_ontology_resolver_from_env_empty_strategy():
417
+ """Test get_ontology_resolver_from_env raises EnvironmentError for empty strategy."""
418
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
419
+
420
+ with pytest.raises(EnvironmentError) as exc_info:
421
+ get_ontology_resolver_from_env(
422
+ ontology_resolver="rdflib", matching_strategy="", ontology_file_path="/test/path.owl"
423
+ )
424
+
425
+ assert "Unsupported ontology resolver: rdflib" in str(exc_info.value)
426
+
427
+
428
+ def test_get_ontology_resolver_from_env_default_parameters():
429
+ """Test get_ontology_resolver_from_env with default empty parameters raises EnvironmentError."""
430
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
431
+
432
+ with pytest.raises(EnvironmentError) as exc_info:
433
+ get_ontology_resolver_from_env()
434
+
435
+ assert "Unsupported ontology resolver:" in str(exc_info.value)
436
+
437
+
438
+ def test_get_ontology_resolver_from_env_case_sensitivity():
439
+ """Test get_ontology_resolver_from_env is case sensitive."""
440
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
441
+
442
+ with pytest.raises(EnvironmentError):
443
+ get_ontology_resolver_from_env(
444
+ ontology_resolver="RDFLIB",
445
+ matching_strategy="fuzzy",
446
+ ontology_file_path="/test/path.owl",
447
+ )
448
+
449
+ with pytest.raises(EnvironmentError):
450
+ get_ontology_resolver_from_env(
451
+ ontology_resolver="RdfLib",
452
+ matching_strategy="fuzzy",
453
+ ontology_file_path="/test/path.owl",
454
+ )
455
+
456
+
457
+ def test_get_ontology_resolver_from_env_with_actual_file():
458
+ """Test get_ontology_resolver_from_env works with actual file path."""
459
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
460
+ from cognee.modules.ontology.rdf_xml.RDFLibOntologyResolver import RDFLibOntologyResolver
461
+ from cognee.modules.ontology.matching_strategies import FuzzyMatchingStrategy
462
+
463
+ resolver = get_ontology_resolver_from_env(
464
+ ontology_resolver="rdflib",
465
+ matching_strategy="fuzzy",
466
+ ontology_file_path="/path/to/ontology.owl",
467
+ )
468
+
469
+ assert isinstance(resolver, RDFLibOntologyResolver)
470
+ assert isinstance(resolver.matching_strategy, FuzzyMatchingStrategy)
471
+ assert resolver.ontology_file == "/path/to/ontology.owl"
472
+
473
+
474
+ def test_get_ontology_resolver_from_env_resolver_functionality():
475
+ """Test that resolver created from env function works correctly."""
476
+ from cognee.modules.ontology.get_default_ontology_resolver import get_ontology_resolver_from_env
477
+
478
+ resolver = get_ontology_resolver_from_env(
479
+ ontology_resolver="rdflib", matching_strategy="fuzzy", ontology_file_path="/test/path.owl"
480
+ )
481
+
482
+ resolver.build_lookup()
483
+ assert isinstance(resolver.lookup, dict)
484
+
485
+ result = resolver.find_closest_match("test", "individuals")
486
+ assert result is None # Should return None for non-existent entity
487
+
488
+ nodes, relationships, start_node = resolver.get_subgraph("test", "individuals")
489
+ assert nodes == []
490
+ assert relationships == []
491
+ assert start_node is None