mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
Merge #5368
5368: Compress match checking tests r=matklad a=matklad
bors r+
🤖
Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
commit
735baad6ce
4 changed files with 543 additions and 1299 deletions
|
@ -244,3 +244,28 @@ impl AstDiagnostic for MismatchedArgCount {
|
||||||
ast::CallExpr::cast(node).unwrap()
|
ast::CallExpr::cast(node).unwrap()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
fn check_diagnostics(ra_fixture: &str) {
|
||||||
|
use ra_db::{fixture::WithFixture, FileId};
|
||||||
|
use ra_syntax::TextRange;
|
||||||
|
use rustc_hash::FxHashMap;
|
||||||
|
|
||||||
|
use crate::test_db::TestDB;
|
||||||
|
|
||||||
|
let db = TestDB::with_files(ra_fixture);
|
||||||
|
let annotations = db.extract_annotations();
|
||||||
|
|
||||||
|
let mut actual: FxHashMap<FileId, Vec<(TextRange, String)>> = FxHashMap::default();
|
||||||
|
db.diag(|d| {
|
||||||
|
// FXIME: macros...
|
||||||
|
let file_id = d.source().file_id.original_file(&db);
|
||||||
|
let range = d.syntax_node(&db).text_range();
|
||||||
|
// FIXME: support multi-line messages in annotations
|
||||||
|
let message = d.message().lines().next().unwrap().to_owned();
|
||||||
|
actual.entry(file_id).or_default().push((range, message));
|
||||||
|
});
|
||||||
|
actual.values_mut().for_each(|diags| diags.sort_by_key(|it| it.0.start()));
|
||||||
|
|
||||||
|
assert_eq!(annotations, actual);
|
||||||
|
}
|
||||||
|
|
|
@ -376,146 +376,117 @@ pub fn record_pattern_missing_fields(
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use expect::{expect, Expect};
|
use crate::diagnostics::check_diagnostics;
|
||||||
use ra_db::fixture::WithFixture;
|
|
||||||
|
|
||||||
use crate::{diagnostics::MismatchedArgCount, test_db::TestDB};
|
|
||||||
|
|
||||||
fn check_diagnostic(ra_fixture: &str, expect: Expect) {
|
|
||||||
let msg = TestDB::with_single_file(ra_fixture).0.diagnostic::<MismatchedArgCount>().0;
|
|
||||||
expect.assert_eq(&msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn check_no_diagnostic(ra_fixture: &str) {
|
|
||||||
let (s, diagnostic_count) =
|
|
||||||
TestDB::with_single_file(ra_fixture).0.diagnostic::<MismatchedArgCount>();
|
|
||||||
|
|
||||||
assert_eq!(0, diagnostic_count, "expected no diagnostic, found one: {}", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn simple_free_fn_zero() {
|
fn simple_free_fn_zero() {
|
||||||
check_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
fn zero() {}
|
fn zero() {}
|
||||||
fn f() { zero(1); }
|
fn f() { zero(1); }
|
||||||
",
|
//^^^^^^^ Expected 0 arguments, found 1
|
||||||
expect![["\"zero(1)\": Expected 0 arguments, found 1\n"]],
|
"#,
|
||||||
);
|
);
|
||||||
|
|
||||||
check_no_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
fn zero() {}
|
fn zero() {}
|
||||||
fn f() { zero(); }
|
fn f() { zero(); }
|
||||||
",
|
"#,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn simple_free_fn_one() {
|
fn simple_free_fn_one() {
|
||||||
check_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
fn one(arg: u8) {}
|
fn one(arg: u8) {}
|
||||||
fn f() { one(); }
|
fn f() { one(); }
|
||||||
",
|
//^^^^^ Expected 1 argument, found 0
|
||||||
expect![["\"one()\": Expected 1 argument, found 0\n"]],
|
"#,
|
||||||
);
|
);
|
||||||
|
|
||||||
check_no_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
fn one(arg: u8) {}
|
fn one(arg: u8) {}
|
||||||
fn f() { one(1); }
|
fn f() { one(1); }
|
||||||
",
|
"#,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn method_as_fn() {
|
fn method_as_fn() {
|
||||||
check_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
struct S;
|
struct S;
|
||||||
impl S {
|
impl S { fn method(&self) {} }
|
||||||
fn method(&self) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn f() {
|
fn f() {
|
||||||
S::method();
|
S::method();
|
||||||
}
|
} //^^^^^^^^^^^ Expected 1 argument, found 0
|
||||||
",
|
"#,
|
||||||
expect![["\"S::method()\": Expected 1 argument, found 0\n"]],
|
|
||||||
);
|
);
|
||||||
|
|
||||||
check_no_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
struct S;
|
struct S;
|
||||||
impl S {
|
impl S { fn method(&self) {} }
|
||||||
fn method(&self) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn f() {
|
fn f() {
|
||||||
S::method(&S);
|
S::method(&S);
|
||||||
S.method();
|
S.method();
|
||||||
}
|
}
|
||||||
",
|
"#,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn method_with_arg() {
|
fn method_with_arg() {
|
||||||
check_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
struct S;
|
struct S;
|
||||||
impl S {
|
impl S { fn method(&self, arg: u8) {} }
|
||||||
fn method(&self, arg: u8) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn f() {
|
fn f() {
|
||||||
S.method();
|
S.method();
|
||||||
}
|
} //^^^^^^^^^^ Expected 1 argument, found 0
|
||||||
",
|
"#,
|
||||||
expect![["\"S.method()\": Expected 1 argument, found 0\n"]],
|
|
||||||
);
|
);
|
||||||
|
|
||||||
check_no_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
struct S;
|
struct S;
|
||||||
impl S {
|
impl S { fn method(&self, arg: u8) {} }
|
||||||
fn method(&self, arg: u8) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn f() {
|
fn f() {
|
||||||
S::method(&S, 0);
|
S::method(&S, 0);
|
||||||
S.method(1);
|
S.method(1);
|
||||||
}
|
}
|
||||||
",
|
"#,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn tuple_struct() {
|
fn tuple_struct() {
|
||||||
check_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
struct Tup(u8, u16);
|
struct Tup(u8, u16);
|
||||||
fn f() {
|
fn f() {
|
||||||
Tup(0);
|
Tup(0);
|
||||||
}
|
} //^^^^^^ Expected 2 arguments, found 1
|
||||||
",
|
"#,
|
||||||
expect![["\"Tup(0)\": Expected 2 arguments, found 1\n"]],
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn enum_variant() {
|
fn enum_variant() {
|
||||||
check_diagnostic(
|
check_diagnostics(
|
||||||
r"
|
r#"
|
||||||
enum En {
|
enum En { Variant(u8, u16), }
|
||||||
Variant(u8, u16),
|
fn f() {
|
||||||
}
|
En::Variant(0);
|
||||||
fn f() {
|
} //^^^^^^^^^^^^^^ Expected 2 arguments, found 1
|
||||||
En::Variant(0);
|
"#,
|
||||||
}
|
|
||||||
",
|
|
||||||
expect![["\"En::Variant(0)\": Expected 2 arguments, found 1\n"]],
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -82,7 +82,7 @@ impl FileLoader for TestDB {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TestDB {
|
impl TestDB {
|
||||||
pub fn module_for_file(&self, file_id: FileId) -> ModuleId {
|
pub(crate) fn module_for_file(&self, file_id: FileId) -> ModuleId {
|
||||||
for &krate in self.relevant_crates(file_id).iter() {
|
for &krate in self.relevant_crates(file_id).iter() {
|
||||||
let crate_def_map = self.crate_def_map(krate);
|
let crate_def_map = self.crate_def_map(krate);
|
||||||
for (local_id, data) in crate_def_map.modules.iter() {
|
for (local_id, data) in crate_def_map.modules.iter() {
|
||||||
|
@ -94,7 +94,7 @@ impl TestDB {
|
||||||
panic!("Can't find module for file")
|
panic!("Can't find module for file")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn diag<F: FnMut(&dyn Diagnostic)>(&self, mut cb: F) {
|
pub(crate) fn diag<F: FnMut(&dyn Diagnostic)>(&self, mut cb: F) {
|
||||||
let crate_graph = self.crate_graph();
|
let crate_graph = self.crate_graph();
|
||||||
for krate in crate_graph.iter() {
|
for krate in crate_graph.iter() {
|
||||||
let crate_def_map = self.crate_def_map(krate);
|
let crate_def_map = self.crate_def_map(krate);
|
||||||
|
@ -124,7 +124,7 @@ impl TestDB {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn diagnostics(&self) -> (String, u32) {
|
pub(crate) fn diagnostics(&self) -> (String, u32) {
|
||||||
let mut buf = String::new();
|
let mut buf = String::new();
|
||||||
let mut count = 0;
|
let mut count = 0;
|
||||||
self.diag(|d| {
|
self.diag(|d| {
|
||||||
|
@ -134,22 +134,7 @@ impl TestDB {
|
||||||
(buf, count)
|
(buf, count)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Like `diagnostics`, but filtered for a single diagnostic.
|
pub(crate) fn extract_annotations(&self) -> FxHashMap<FileId, Vec<(TextRange, String)>> {
|
||||||
pub fn diagnostic<D: Diagnostic>(&self) -> (String, u32) {
|
|
||||||
let mut buf = String::new();
|
|
||||||
let mut count = 0;
|
|
||||||
self.diag(|d| {
|
|
||||||
// We want to filter diagnostics by the particular one we are testing for, to
|
|
||||||
// avoid surprising results in tests.
|
|
||||||
if d.downcast_ref::<D>().is_some() {
|
|
||||||
format_to!(buf, "{:?}: {}\n", d.syntax_node(self).text(), d.message());
|
|
||||||
count += 1;
|
|
||||||
};
|
|
||||||
});
|
|
||||||
(buf, count)
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn extract_annotations(&self) -> FxHashMap<FileId, Vec<(TextRange, String)>> {
|
|
||||||
let mut files = Vec::new();
|
let mut files = Vec::new();
|
||||||
let crate_graph = self.crate_graph();
|
let crate_graph = self.crate_graph();
|
||||||
for krate in crate_graph.iter() {
|
for krate in crate_graph.iter() {
|
||||||
|
|
Loading…
Reference in a new issue