mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 05:38:46 +00:00
Remove insta for ra_hir_def
This commit is contained in:
parent
798f43da50
commit
19e78020bd
4 changed files with 168 additions and 164 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -1111,7 +1111,6 @@ dependencies = [
|
||||||
"expect",
|
"expect",
|
||||||
"fst",
|
"fst",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"insta",
|
|
||||||
"itertools",
|
"itertools",
|
||||||
"log",
|
"log",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
|
|
|
@ -33,5 +33,4 @@ ra_cfg = { path = "../ra_cfg" }
|
||||||
tt = { path = "../ra_tt", package = "ra_tt" }
|
tt = { path = "../ra_tt", package = "ra_tt" }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
insta = "0.16.0"
|
|
||||||
expect = { path = "../expect" }
|
expect = { path = "../expect" }
|
||||||
|
|
|
@ -327,32 +327,14 @@ pub fn search_dependencies<'a>(
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use expect::{expect, Expect};
|
||||||
|
use ra_db::{fixture::WithFixture, SourceDatabase, Upcast};
|
||||||
|
|
||||||
use crate::{test_db::TestDB, AssocContainerId, Lookup};
|
use crate::{test_db::TestDB, AssocContainerId, Lookup};
|
||||||
use insta::assert_snapshot;
|
|
||||||
use itertools::Itertools;
|
|
||||||
use ra_db::fixture::WithFixture;
|
|
||||||
use ra_db::{SourceDatabase, Upcast};
|
|
||||||
|
|
||||||
fn import_map(ra_fixture: &str) -> String {
|
use super::*;
|
||||||
let db = TestDB::with_files(ra_fixture);
|
|
||||||
let crate_graph = db.crate_graph();
|
|
||||||
|
|
||||||
let s = crate_graph
|
fn check_search(ra_fixture: &str, krate_name: &str, query: Query, expect: Expect) {
|
||||||
.iter()
|
|
||||||
.filter_map(|krate| {
|
|
||||||
let cdata = &crate_graph[krate];
|
|
||||||
let name = cdata.display_name.as_ref()?;
|
|
||||||
|
|
||||||
let map = db.import_map(krate);
|
|
||||||
|
|
||||||
Some(format!("{}:\n{:?}", name, map))
|
|
||||||
})
|
|
||||||
.join("\n");
|
|
||||||
s
|
|
||||||
}
|
|
||||||
|
|
||||||
fn search_dependencies_of(ra_fixture: &str, krate_name: &str, query: Query) -> String {
|
|
||||||
let db = TestDB::with_files(ra_fixture);
|
let db = TestDB::with_files(ra_fixture);
|
||||||
let crate_graph = db.crate_graph();
|
let crate_graph = db.crate_graph();
|
||||||
let krate = crate_graph
|
let krate = crate_graph
|
||||||
|
@ -363,7 +345,7 @@ mod tests {
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
search_dependencies(db.upcast(), krate, query)
|
let actual = search_dependencies(db.upcast(), krate, query)
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.filter_map(|item| {
|
.filter_map(|item| {
|
||||||
let mark = match item {
|
let mark = match item {
|
||||||
|
@ -376,14 +358,15 @@ mod tests {
|
||||||
let map = db.import_map(krate);
|
let map = db.import_map(krate);
|
||||||
let path = map.path_of(item).unwrap();
|
let path = map.path_of(item).unwrap();
|
||||||
format!(
|
format!(
|
||||||
"{}::{} ({})",
|
"{}::{} ({})\n",
|
||||||
crate_graph[krate].display_name.as_ref().unwrap(),
|
crate_graph[krate].display_name.as_ref().unwrap(),
|
||||||
path,
|
path,
|
||||||
mark
|
mark
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.join("\n")
|
.collect::<String>();
|
||||||
|
expect.assert_eq(&actual)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn assoc_to_trait(db: &dyn DefDatabase, item: ItemInNs) -> ItemInNs {
|
fn assoc_to_trait(db: &dyn DefDatabase, item: ItemInNs) -> ItemInNs {
|
||||||
|
@ -409,9 +392,28 @@ mod tests {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn check(ra_fixture: &str, expect: Expect) {
|
||||||
|
let db = TestDB::with_files(ra_fixture);
|
||||||
|
let crate_graph = db.crate_graph();
|
||||||
|
|
||||||
|
let actual = crate_graph
|
||||||
|
.iter()
|
||||||
|
.filter_map(|krate| {
|
||||||
|
let cdata = &crate_graph[krate];
|
||||||
|
let name = cdata.display_name.as_ref()?;
|
||||||
|
|
||||||
|
let map = db.import_map(krate);
|
||||||
|
|
||||||
|
Some(format!("{}:\n{:?}\n", name, map))
|
||||||
|
})
|
||||||
|
.collect::<String>();
|
||||||
|
|
||||||
|
expect.assert_eq(&actual)
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn smoke() {
|
fn smoke() {
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /main.rs crate:main deps:lib
|
//- /main.rs crate:main deps:lib
|
||||||
|
|
||||||
|
@ -436,24 +438,23 @@ mod tests {
|
||||||
pub struct Pub2; // t + v
|
pub struct Pub2; // t + v
|
||||||
struct Priv;
|
struct Priv;
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
main:
|
||||||
|
- publ1 (t)
|
||||||
|
- real_pu2 (t)
|
||||||
|
- real_pub (t)
|
||||||
|
- real_pub::Pub (t)
|
||||||
|
lib:
|
||||||
|
- Pub (t)
|
||||||
|
- Pub2 (t)
|
||||||
|
- Pub2 (v)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
main:
|
|
||||||
- publ1 (t)
|
|
||||||
- real_pu2 (t)
|
|
||||||
- real_pub (t)
|
|
||||||
- real_pub::Pub (t)
|
|
||||||
lib:
|
|
||||||
- Pub (t)
|
|
||||||
- Pub2 (t)
|
|
||||||
- Pub2 (v)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn prefers_shortest_path() {
|
fn prefers_shortest_path() {
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /main.rs crate:main
|
//- /main.rs crate:main
|
||||||
|
|
||||||
|
@ -465,21 +466,20 @@ mod tests {
|
||||||
pub use super::sub::subsub::Def;
|
pub use super::sub::subsub::Def;
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
main:
|
||||||
|
- sub (t)
|
||||||
|
- sub::Def (t)
|
||||||
|
- sub::subsub (t)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
main:
|
|
||||||
- sub (t)
|
|
||||||
- sub::Def (t)
|
|
||||||
- sub::subsub (t)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn type_reexport_cross_crate() {
|
fn type_reexport_cross_crate() {
|
||||||
// Reexports need to be visible from a crate, even if the original crate exports the item
|
// Reexports need to be visible from a crate, even if the original crate exports the item
|
||||||
// at a shorter path.
|
// at a shorter path.
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /main.rs crate:main deps:lib
|
//- /main.rs crate:main deps:lib
|
||||||
pub mod m {
|
pub mod m {
|
||||||
|
@ -488,22 +488,21 @@ mod tests {
|
||||||
//- /lib.rs crate:lib
|
//- /lib.rs crate:lib
|
||||||
pub struct S;
|
pub struct S;
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
main:
|
||||||
|
- m (t)
|
||||||
|
- m::S (t)
|
||||||
|
- m::S (v)
|
||||||
|
lib:
|
||||||
|
- S (t)
|
||||||
|
- S (v)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
main:
|
|
||||||
- m (t)
|
|
||||||
- m::S (t)
|
|
||||||
- m::S (v)
|
|
||||||
lib:
|
|
||||||
- S (t)
|
|
||||||
- S (v)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn macro_reexport() {
|
fn macro_reexport() {
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /main.rs crate:main deps:lib
|
//- /main.rs crate:main deps:lib
|
||||||
pub mod m {
|
pub mod m {
|
||||||
|
@ -515,21 +514,20 @@ mod tests {
|
||||||
() => {};
|
() => {};
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
main:
|
||||||
|
- m (t)
|
||||||
|
- m::pub_macro (m)
|
||||||
|
lib:
|
||||||
|
- pub_macro (m)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
main:
|
|
||||||
- m (t)
|
|
||||||
- m::pub_macro (m)
|
|
||||||
lib:
|
|
||||||
- pub_macro (m)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn module_reexport() {
|
fn module_reexport() {
|
||||||
// Reexporting modules from a dependency adds all contents to the import map.
|
// Reexporting modules from a dependency adds all contents to the import map.
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /main.rs crate:main deps:lib
|
//- /main.rs crate:main deps:lib
|
||||||
pub use lib::module as reexported_module;
|
pub use lib::module as reexported_module;
|
||||||
|
@ -538,24 +536,23 @@ mod tests {
|
||||||
pub struct S;
|
pub struct S;
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
main:
|
||||||
|
- reexported_module (t)
|
||||||
|
- reexported_module::S (t)
|
||||||
|
- reexported_module::S (v)
|
||||||
|
lib:
|
||||||
|
- module (t)
|
||||||
|
- module::S (t)
|
||||||
|
- module::S (v)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
main:
|
|
||||||
- reexported_module (t)
|
|
||||||
- reexported_module::S (t)
|
|
||||||
- reexported_module::S (v)
|
|
||||||
lib:
|
|
||||||
- module (t)
|
|
||||||
- module::S (t)
|
|
||||||
- module::S (v)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn cyclic_module_reexport() {
|
fn cyclic_module_reexport() {
|
||||||
// A cyclic reexport does not hang.
|
// A cyclic reexport does not hang.
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /lib.rs crate:lib
|
//- /lib.rs crate:lib
|
||||||
pub mod module {
|
pub mod module {
|
||||||
|
@ -567,36 +564,35 @@ mod tests {
|
||||||
pub use super::module;
|
pub use super::module;
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
lib:
|
||||||
|
- module (t)
|
||||||
|
- module::S (t)
|
||||||
|
- module::S (v)
|
||||||
|
- sub (t)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
lib:
|
|
||||||
- module (t)
|
|
||||||
- module::S (t)
|
|
||||||
- module::S (v)
|
|
||||||
- sub (t)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn private_macro() {
|
fn private_macro() {
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /lib.rs crate:lib
|
//- /lib.rs crate:lib
|
||||||
macro_rules! private_macro {
|
macro_rules! private_macro {
|
||||||
() => {};
|
() => {};
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
);
|
expect![[r#"
|
||||||
|
lib:
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
"#]],
|
||||||
lib:
|
);
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn namespacing() {
|
fn namespacing() {
|
||||||
let map = import_map(
|
check(
|
||||||
r"
|
r"
|
||||||
//- /lib.rs crate:lib
|
//- /lib.rs crate:lib
|
||||||
pub struct Thing; // t + v
|
pub struct Thing; // t + v
|
||||||
|
@ -605,16 +601,15 @@ mod tests {
|
||||||
() => {};
|
() => {};
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
lib:
|
||||||
|
- Thing (m)
|
||||||
|
- Thing (t)
|
||||||
|
- Thing (v)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
check(
|
||||||
lib:
|
|
||||||
- Thing (m)
|
|
||||||
- Thing (t)
|
|
||||||
- Thing (v)
|
|
||||||
"###);
|
|
||||||
|
|
||||||
let map = import_map(
|
|
||||||
r"
|
r"
|
||||||
//- /lib.rs crate:lib
|
//- /lib.rs crate:lib
|
||||||
pub mod Thing {} // t
|
pub mod Thing {} // t
|
||||||
|
@ -623,13 +618,12 @@ mod tests {
|
||||||
() => {};
|
() => {};
|
||||||
}
|
}
|
||||||
",
|
",
|
||||||
|
expect![[r#"
|
||||||
|
lib:
|
||||||
|
- Thing (m)
|
||||||
|
- Thing (t)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
|
|
||||||
assert_snapshot!(map, @r###"
|
|
||||||
lib:
|
|
||||||
- Thing (m)
|
|
||||||
- Thing (t)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -658,25 +652,33 @@ mod tests {
|
||||||
}
|
}
|
||||||
"#;
|
"#;
|
||||||
|
|
||||||
let res = search_dependencies_of(ra_fixture, "main", Query::new("fmt"));
|
check_search(
|
||||||
assert_snapshot!(res, @r###"
|
ra_fixture,
|
||||||
dep::fmt (t)
|
"main",
|
||||||
dep::Fmt (t)
|
Query::new("fmt"),
|
||||||
dep::Fmt (v)
|
expect![[r#"
|
||||||
dep::Fmt (m)
|
dep::fmt (t)
|
||||||
dep::fmt::Display (t)
|
dep::Fmt (t)
|
||||||
dep::format (v)
|
dep::Fmt (v)
|
||||||
dep::fmt::Display (t)
|
dep::Fmt (m)
|
||||||
"###);
|
dep::fmt::Display (t)
|
||||||
|
dep::format (v)
|
||||||
|
dep::fmt::Display (t)
|
||||||
|
"#]],
|
||||||
|
);
|
||||||
|
|
||||||
let res = search_dependencies_of(ra_fixture, "main", Query::new("fmt").anchor_end());
|
check_search(
|
||||||
assert_snapshot!(res, @r###"
|
ra_fixture,
|
||||||
dep::fmt (t)
|
"main",
|
||||||
dep::Fmt (t)
|
Query::new("fmt").anchor_end(),
|
||||||
dep::Fmt (v)
|
expect![[r#"
|
||||||
dep::Fmt (m)
|
dep::fmt (t)
|
||||||
dep::fmt::Display (t)
|
dep::Fmt (t)
|
||||||
"###);
|
dep::Fmt (v)
|
||||||
|
dep::Fmt (m)
|
||||||
|
dep::fmt::Display (t)
|
||||||
|
"#]],
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -689,26 +691,32 @@ mod tests {
|
||||||
pub struct FMT;
|
pub struct FMT;
|
||||||
"#;
|
"#;
|
||||||
|
|
||||||
let res = search_dependencies_of(ra_fixture, "main", Query::new("FMT"));
|
check_search(
|
||||||
|
ra_fixture,
|
||||||
|
"main",
|
||||||
|
Query::new("FMT"),
|
||||||
|
expect![[r#"
|
||||||
|
dep::fmt (t)
|
||||||
|
dep::fmt (v)
|
||||||
|
dep::FMT (t)
|
||||||
|
dep::FMT (v)
|
||||||
|
"#]],
|
||||||
|
);
|
||||||
|
|
||||||
assert_snapshot!(res, @r###"
|
check_search(
|
||||||
dep::fmt (t)
|
ra_fixture,
|
||||||
dep::fmt (v)
|
"main",
|
||||||
dep::FMT (t)
|
Query::new("FMT").case_sensitive(),
|
||||||
dep::FMT (v)
|
expect![[r#"
|
||||||
"###);
|
dep::FMT (t)
|
||||||
|
dep::FMT (v)
|
||||||
let res = search_dependencies_of(ra_fixture, "main", Query::new("FMT").case_sensitive());
|
"#]],
|
||||||
|
);
|
||||||
assert_snapshot!(res, @r###"
|
|
||||||
dep::FMT (t)
|
|
||||||
dep::FMT (v)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn search_limit() {
|
fn search_limit() {
|
||||||
let res = search_dependencies_of(
|
check_search(
|
||||||
r#"
|
r#"
|
||||||
//- /main.rs crate:main deps:dep
|
//- /main.rs crate:main deps:dep
|
||||||
//- /dep.rs crate:dep
|
//- /dep.rs crate:dep
|
||||||
|
@ -728,10 +736,10 @@ mod tests {
|
||||||
"#,
|
"#,
|
||||||
"main",
|
"main",
|
||||||
Query::new("").limit(2),
|
Query::new("").limit(2),
|
||||||
|
expect![[r#"
|
||||||
|
dep::fmt (t)
|
||||||
|
dep::Fmt (t)
|
||||||
|
"#]],
|
||||||
);
|
);
|
||||||
assert_snapshot!(res, @r###"
|
|
||||||
dep::fmt (t)
|
|
||||||
dep::Fmt (t)
|
|
||||||
"###);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -686,27 +686,25 @@ fn unresolved_module_diagnostics() {
|
||||||
|
|
||||||
let crate_def_map = db.crate_def_map(krate);
|
let crate_def_map = db.crate_def_map(krate);
|
||||||
|
|
||||||
insta::assert_debug_snapshot!(
|
expect![[r#"
|
||||||
crate_def_map.diagnostics,
|
[
|
||||||
@r###"
|
UnresolvedModule {
|
||||||
[
|
module: Idx::<ModuleData>(0),
|
||||||
UnresolvedModule {
|
declaration: InFile {
|
||||||
module: Idx::<ModuleData>(0),
|
file_id: HirFileId(
|
||||||
declaration: InFile {
|
|
||||||
file_id: HirFileId(
|
|
||||||
FileId(
|
|
||||||
FileId(
|
FileId(
|
||||||
0,
|
FileId(
|
||||||
|
0,
|
||||||
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
value: FileAstId::<ra_syntax::ast::generated::nodes::Module>(1),
|
||||||
value: FileAstId::<ra_syntax::ast::generated::nodes::Module>(1),
|
},
|
||||||
|
candidate: "bar.rs",
|
||||||
},
|
},
|
||||||
candidate: "bar.rs",
|
]
|
||||||
},
|
"#]]
|
||||||
]
|
.assert_debug_eq(&crate_def_map.diagnostics);
|
||||||
"###
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
Loading…
Reference in a new issue