mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-09-30 13:51:31 +00:00
Merge #7610
7610: Cleanup test r=matklad a=matklad
bors r+
🤖
Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
commit
fca93cfed3
3 changed files with 234 additions and 217 deletions
|
@ -270,8 +270,9 @@ fn foo() {
|
|||
|
||||
#[test]
|
||||
fn test_join_lines_diverging_block() {
|
||||
let before = r"
|
||||
fn foo() {
|
||||
check_join_lines(
|
||||
r"
|
||||
fn foo() {
|
||||
loop {
|
||||
match x {
|
||||
92 => $0{
|
||||
|
@ -279,18 +280,18 @@ fn foo() {
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
";
|
||||
let after = r"
|
||||
fn foo() {
|
||||
}
|
||||
",
|
||||
r"
|
||||
fn foo() {
|
||||
loop {
|
||||
match x {
|
||||
92 => $0continue,
|
||||
}
|
||||
}
|
||||
}
|
||||
";
|
||||
check_join_lines(before, after);
|
||||
}
|
||||
",
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -100,19 +100,28 @@ fn syntax_tree_for_token(node: &SyntaxToken, text_range: TextRange) -> Option<St
|
|||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use test_utils::assert_eq_text;
|
||||
use expect_test::expect;
|
||||
|
||||
use crate::fixture;
|
||||
|
||||
fn check(ra_fixture: &str, expect: expect_test::Expect) {
|
||||
let (analysis, file_id) = fixture::file(ra_fixture);
|
||||
let syn = analysis.syntax_tree(file_id, None).unwrap();
|
||||
expect.assert_eq(&syn)
|
||||
}
|
||||
fn check_range(ra_fixture: &str, expect: expect_test::Expect) {
|
||||
let (analysis, frange) = fixture::range(ra_fixture);
|
||||
let syn = analysis.syntax_tree(frange.file_id, Some(frange.range)).unwrap();
|
||||
expect.assert_eq(&syn)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_syntax_tree_without_range() {
|
||||
// Basic syntax
|
||||
let (analysis, file_id) = fixture::file(r#"fn foo() {}"#);
|
||||
let syn = analysis.syntax_tree(file_id, None).unwrap();
|
||||
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
SOURCE_FILE@0..11
|
||||
check(
|
||||
r#"fn foo() {}"#,
|
||||
expect![[r#"
|
||||
SOURCE_FILE@0..11
|
||||
FN@0..11
|
||||
FN_KW@0..2 "fn"
|
||||
WHITESPACE@2..3 " "
|
||||
|
@ -125,26 +134,19 @@ SOURCE_FILE@0..11
|
|||
BLOCK_EXPR@9..11
|
||||
L_CURLY@9..10 "{"
|
||||
R_CURLY@10..11 "}"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
"#]],
|
||||
);
|
||||
|
||||
let (analysis, file_id) = fixture::file(
|
||||
check(
|
||||
r#"
|
||||
fn test() {
|
||||
assert!("
|
||||
fn foo() {
|
||||
}
|
||||
", "");
|
||||
}"#
|
||||
.trim(),
|
||||
);
|
||||
let syn = analysis.syntax_tree(file_id, None).unwrap();
|
||||
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
SOURCE_FILE@0..60
|
||||
}"#,
|
||||
expect![[r#"
|
||||
SOURCE_FILE@0..60
|
||||
FN@0..60
|
||||
FN_KW@0..2 "fn"
|
||||
WHITESPACE@2..3 " "
|
||||
|
@ -174,20 +176,16 @@ SOURCE_FILE@0..60
|
|||
SEMICOLON@57..58 ";"
|
||||
WHITESPACE@58..59 "\n"
|
||||
R_CURLY@59..60 "}"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
);
|
||||
"#]],
|
||||
)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_syntax_tree_with_range() {
|
||||
let (analysis, range) = fixture::range(r#"$0fn foo() {}$0"#.trim());
|
||||
let syn = analysis.syntax_tree(range.file_id, Some(range.range)).unwrap();
|
||||
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
FN@0..11
|
||||
check_range(
|
||||
r#"$0fn foo() {}$0"#,
|
||||
expect![[r#"
|
||||
FN@0..11
|
||||
FN_KW@0..2 "fn"
|
||||
WHITESPACE@2..3 " "
|
||||
NAME@3..6
|
||||
|
@ -199,25 +197,19 @@ FN@0..11
|
|||
BLOCK_EXPR@9..11
|
||||
L_CURLY@9..10 "{"
|
||||
R_CURLY@10..11 "}"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
"#]],
|
||||
);
|
||||
|
||||
let (analysis, range) = fixture::range(
|
||||
r#"fn test() {
|
||||
check_range(
|
||||
r#"
|
||||
fn test() {
|
||||
$0assert!("
|
||||
fn foo() {
|
||||
}
|
||||
", "");$0
|
||||
}"#
|
||||
.trim(),
|
||||
);
|
||||
let syn = analysis.syntax_tree(range.file_id, Some(range.range)).unwrap();
|
||||
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
EXPR_STMT@16..58
|
||||
}"#,
|
||||
expect![[r#"
|
||||
EXPR_STMT@16..58
|
||||
MACRO_CALL@16..57
|
||||
PATH@16..22
|
||||
PATH_SEGMENT@16..22
|
||||
|
@ -232,15 +224,13 @@ EXPR_STMT@16..58
|
|||
STRING@54..56 "\"\""
|
||||
R_PAREN@56..57 ")"
|
||||
SEMICOLON@57..58 ";"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
"#]],
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_syntax_tree_inside_string() {
|
||||
let (analysis, range) = fixture::range(
|
||||
check_range(
|
||||
r#"fn test() {
|
||||
assert!("
|
||||
$0fn foo() {
|
||||
|
@ -248,13 +238,9 @@ $0fn foo() {
|
|||
fn bar() {
|
||||
}
|
||||
", "");
|
||||
}"#
|
||||
.trim(),
|
||||
);
|
||||
let syn = analysis.syntax_tree(range.file_id, Some(range.range)).unwrap();
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
SOURCE_FILE@0..12
|
||||
}"#,
|
||||
expect![[r#"
|
||||
SOURCE_FILE@0..12
|
||||
FN@0..12
|
||||
FN_KW@0..2 "fn"
|
||||
WHITESPACE@2..3 " "
|
||||
|
@ -268,13 +254,11 @@ SOURCE_FILE@0..12
|
|||
L_CURLY@9..10 "{"
|
||||
WHITESPACE@10..11 "\n"
|
||||
R_CURLY@11..12 "}"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
"#]],
|
||||
);
|
||||
|
||||
// With a raw string
|
||||
let (analysis, range) = fixture::range(
|
||||
check_range(
|
||||
r###"fn test() {
|
||||
assert!(r#"
|
||||
$0fn foo() {
|
||||
|
@ -282,13 +266,9 @@ $0fn foo() {
|
|||
fn bar() {
|
||||
}
|
||||
"#, "");
|
||||
}"###
|
||||
.trim(),
|
||||
);
|
||||
let syn = analysis.syntax_tree(range.file_id, Some(range.range)).unwrap();
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
SOURCE_FILE@0..12
|
||||
}"###,
|
||||
expect![[r#"
|
||||
SOURCE_FILE@0..12
|
||||
FN@0..12
|
||||
FN_KW@0..2 "fn"
|
||||
WHITESPACE@2..3 " "
|
||||
|
@ -302,26 +282,20 @@ SOURCE_FILE@0..12
|
|||
L_CURLY@9..10 "{"
|
||||
WHITESPACE@10..11 "\n"
|
||||
R_CURLY@11..12 "}"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
"#]],
|
||||
);
|
||||
|
||||
// With a raw string
|
||||
let (analysis, range) = fixture::range(
|
||||
check_range(
|
||||
r###"fn test() {
|
||||
assert!(r$0#"
|
||||
fn foo() {
|
||||
}
|
||||
fn bar() {
|
||||
}"$0#, "");
|
||||
}"###
|
||||
.trim(),
|
||||
);
|
||||
let syn = analysis.syntax_tree(range.file_id, Some(range.range)).unwrap();
|
||||
assert_eq_text!(
|
||||
r#"
|
||||
SOURCE_FILE@0..25
|
||||
}"###,
|
||||
expect![[r#"
|
||||
SOURCE_FILE@0..25
|
||||
FN@0..12
|
||||
FN_KW@0..2 "fn"
|
||||
WHITESPACE@2..3 " "
|
||||
|
@ -349,9 +323,7 @@ SOURCE_FILE@0..25
|
|||
L_CURLY@22..23 "{"
|
||||
WHITESPACE@23..24 "\n"
|
||||
R_CURLY@24..25 "}"
|
||||
"#
|
||||
.trim(),
|
||||
syn.trim()
|
||||
"#]],
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -950,6 +950,50 @@
|
|||
{
|
||||
"id": "formatSpecifier",
|
||||
"description": "Style for {} placeholders in format strings"
|
||||
},
|
||||
{
|
||||
"id": "punctuation",
|
||||
"description": "generic punctuation"
|
||||
},
|
||||
{
|
||||
"id": "parenthesis",
|
||||
"description": "( or )",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "bracket",
|
||||
"description": "[ or ]",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "brace",
|
||||
"description": "{ or }",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "angle",
|
||||
"description": "< or >",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "comma",
|
||||
"description": ",",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "colon",
|
||||
"description": ":",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "semicolon",
|
||||
"description": ";",
|
||||
"superType": "punctuation"
|
||||
},
|
||||
{
|
||||
"id": "dot",
|
||||
"description": ".",
|
||||
"superType": "punctuation"
|
||||
}
|
||||
],
|
||||
"semanticTokenModifiers": [
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue