From b3f06009baedb2bfb35decbe9880b525cf4264ed Mon Sep 17 00:00:00 2001 From: David Seddon Date: Fri, 10 Jan 2025 16:10:03 +0000 Subject: [PATCH] WIP Make integration test use new API TODO: This fails to get the correct deps, why? --- rust/tests/large.rs | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/rust/tests/large.rs b/rust/tests/large.rs index 0fff1d65..b9c9d9da 100644 --- a/rust/tests/large.rs +++ b/rust/tests/large.rs @@ -1,7 +1,6 @@ -use _rustgrimp::importgraph::ImportGraph; -use _rustgrimp::layers::{find_illegal_dependencies, Level}; +use _rustgrimp::graph::{Graph, Level, Module}; use serde_json::{Map, Value}; -use std::collections::{HashMap, HashSet}; +use std::collections::HashSet; use std::fs; #[test] @@ -9,15 +8,25 @@ fn test_large_graph_deep_layers() { let data = fs::read_to_string("tests/large_graph.json").expect("Unable to read file"); let value: Value = serde_json::from_str(&data).unwrap(); let items: &Map = value.as_object().unwrap(); - let mut importeds_by_importer: HashMap<&str, HashSet<&str>> = HashMap::new(); + let mut graph = Graph::default(); for (importer, importeds_value) in items.iter() { - let mut importeds = HashSet::new(); for imported in importeds_value.as_array().unwrap() { - importeds.insert(imported.as_str().unwrap()); + graph.add_import( + &Module { + name: importer.to_string(), + }, + &Module { + name: imported.to_string(), + }, + ); } - importeds_by_importer.insert(importer, importeds); } - let graph = ImportGraph::new(importeds_by_importer); + // TODO: for some reason this isn't populated in large_graph.json. Possibly there are other + // things missing too, which may be why find_illegal_dependencies_for_layers doesn't currently + // return any illegal dependencies. + graph.add_module(Module { + name: "mypackage".to_string(), + }); let deep_layers = vec![ "mypackage.plugins.5634303718.1007553798.8198145119.application.3242334296.1991886645", @@ -39,7 +48,9 @@ fn test_large_graph_deep_layers() { .collect(); let containers = HashSet::new(); - let deps = find_illegal_dependencies(&graph, &levels, &containers); + let deps = graph + .find_illegal_dependencies_for_layers(levels, containers) + .unwrap(); assert_eq!(deps.len(), 8); }