mirror of
https://github.com/rust-lang/rust.git
synced 2025-02-08 04:56:58 +00:00
Merge #1468
1468: Use inline snapshots in complete_path r=matklad a=funkill Relates to #1127 Co-authored-by: funkill2 <funkill2@gmail.com>
This commit is contained in:
commit
dd698fc3f7
@ -74,10 +74,11 @@ pub(super) fn complete_path(acc: &mut Completions, ctx: &CompletionContext) {
|
||||
mod tests {
|
||||
use test_utils::covers;
|
||||
|
||||
use crate::completion::{CompletionKind, check_completion, do_completion};
|
||||
use crate::completion::{CompletionKind, do_completion, CompletionItem};
|
||||
use insta::assert_debug_snapshot_matches;
|
||||
|
||||
fn check_reference_completion(code: &str, expected_completions: &str) {
|
||||
check_completion(code, expected_completions, CompletionKind::Reference);
|
||||
fn do_reference_completion(code: &str) -> Vec<CompletionItem> {
|
||||
do_completion(code, CompletionKind::Reference)
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -115,8 +116,8 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn completes_mod_with_docs() {
|
||||
check_reference_completion(
|
||||
"mod_with_docs",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
r"
|
||||
use self::my<|>;
|
||||
|
||||
@ -125,56 +126,113 @@ mod tests {
|
||||
mod my {
|
||||
struct Bar;
|
||||
}
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "my",
|
||||
source_range: [27; 29),
|
||||
delete: [27; 29),
|
||||
insert: "my",
|
||||
kind: Module,
|
||||
documentation: Documentation(
|
||||
"Some simple\ndocs describing `mod my`.",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_use_item_starting_with_self() {
|
||||
check_reference_completion(
|
||||
"use_item_starting_with_self",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
r"
|
||||
use self::m::<|>;
|
||||
|
||||
mod m {
|
||||
struct Bar;
|
||||
}
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "Bar",
|
||||
source_range: [30; 30),
|
||||
delete: [30; 30),
|
||||
insert: "Bar",
|
||||
kind: Struct,
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_use_item_starting_with_crate() {
|
||||
check_reference_completion(
|
||||
"use_item_starting_with_crate",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
mod foo;
|
||||
struct Spam;
|
||||
//- /foo.rs
|
||||
use crate::Sp<|>
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "Spam",
|
||||
source_range: [11; 13),
|
||||
delete: [11; 13),
|
||||
insert: "Spam",
|
||||
kind: Struct,
|
||||
},
|
||||
CompletionItem {
|
||||
label: "foo",
|
||||
source_range: [11; 13),
|
||||
delete: [11; 13),
|
||||
insert: "foo",
|
||||
kind: Module,
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_nested_use_tree() {
|
||||
check_reference_completion(
|
||||
"nested_use_tree",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
mod foo;
|
||||
struct Spam;
|
||||
//- /foo.rs
|
||||
use crate::{Sp<|>};
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "Spam",
|
||||
source_range: [12; 14),
|
||||
delete: [12; 14),
|
||||
insert: "Spam",
|
||||
kind: Struct,
|
||||
},
|
||||
CompletionItem {
|
||||
label: "foo",
|
||||
source_range: [12; 14),
|
||||
delete: [12; 14),
|
||||
insert: "foo",
|
||||
kind: Module,
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_deeply_nested_use_tree() {
|
||||
check_reference_completion(
|
||||
"deeply_nested_use_tree",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
mod foo;
|
||||
@ -185,14 +243,24 @@ mod tests {
|
||||
}
|
||||
//- /foo.rs
|
||||
use crate::{bar::{baz::Sp<|>}};
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "Spam",
|
||||
source_range: [23; 25),
|
||||
delete: [23; 25),
|
||||
insert: "Spam",
|
||||
kind: Struct,
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_enum_variant() {
|
||||
check_reference_completion(
|
||||
"enum_variant",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
/// An enum
|
||||
@ -203,14 +271,39 @@ mod tests {
|
||||
Bar(i32)
|
||||
}
|
||||
fn foo() { let _ = E::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "Bar",
|
||||
source_range: [116; 116),
|
||||
delete: [116; 116),
|
||||
insert: "Bar",
|
||||
kind: EnumVariant,
|
||||
detail: "(i32)",
|
||||
documentation: Documentation(
|
||||
"Bar Variant with i32",
|
||||
),
|
||||
},
|
||||
CompletionItem {
|
||||
label: "Foo",
|
||||
source_range: [116; 116),
|
||||
delete: [116; 116),
|
||||
insert: "Foo",
|
||||
kind: EnumVariant,
|
||||
detail: "()",
|
||||
documentation: Documentation(
|
||||
"Foo Variant",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_enum_variant_with_details() {
|
||||
check_reference_completion(
|
||||
"enum_variant_with_details",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
struct S { field: u32 }
|
||||
@ -224,14 +317,50 @@ mod tests {
|
||||
S(S),
|
||||
}
|
||||
fn foo() { let _ = E::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "Bar",
|
||||
source_range: [180; 180),
|
||||
delete: [180; 180),
|
||||
insert: "Bar",
|
||||
kind: EnumVariant,
|
||||
detail: "(i32, u32)",
|
||||
documentation: Documentation(
|
||||
"Bar Variant with i32 and u32",
|
||||
),
|
||||
},
|
||||
CompletionItem {
|
||||
label: "Foo",
|
||||
source_range: [180; 180),
|
||||
delete: [180; 180),
|
||||
insert: "Foo",
|
||||
kind: EnumVariant,
|
||||
detail: "()",
|
||||
documentation: Documentation(
|
||||
"Foo Variant (empty)",
|
||||
),
|
||||
},
|
||||
CompletionItem {
|
||||
label: "S",
|
||||
source_range: [180; 180),
|
||||
delete: [180; 180),
|
||||
insert: "S",
|
||||
kind: EnumVariant,
|
||||
detail: "(S)",
|
||||
documentation: Documentation(
|
||||
"",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_struct_associated_method() {
|
||||
check_reference_completion(
|
||||
"struct_associated_method",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
/// A Struct
|
||||
@ -243,14 +372,28 @@ mod tests {
|
||||
}
|
||||
|
||||
fn foo() { let _ = S::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "m",
|
||||
source_range: [100; 100),
|
||||
delete: [100; 100),
|
||||
insert: "m()$0",
|
||||
kind: Function,
|
||||
detail: "fn m()",
|
||||
documentation: Documentation(
|
||||
"An associated method",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_struct_associated_const() {
|
||||
check_reference_completion(
|
||||
"struct_associated_const",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
/// A Struct
|
||||
@ -262,14 +405,28 @@ mod tests {
|
||||
}
|
||||
|
||||
fn foo() { let _ = S::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "C",
|
||||
source_range: [107; 107),
|
||||
delete: [107; 107),
|
||||
insert: "C",
|
||||
kind: Const,
|
||||
detail: "const C: i32 = 42;",
|
||||
documentation: Documentation(
|
||||
"An associated const",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_struct_associated_type() {
|
||||
check_reference_completion(
|
||||
"struct_associated_type",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
/// A Struct
|
||||
@ -281,14 +438,28 @@ mod tests {
|
||||
}
|
||||
|
||||
fn foo() { let _ = S::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "T",
|
||||
source_range: [101; 101),
|
||||
delete: [101; 101),
|
||||
insert: "T",
|
||||
kind: TypeAlias,
|
||||
detail: "type T = i32;",
|
||||
documentation: Documentation(
|
||||
"An associated type",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_enum_associated_method() {
|
||||
check_reference_completion(
|
||||
"enum_associated_method",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
/// An enum
|
||||
@ -300,14 +471,28 @@ mod tests {
|
||||
}
|
||||
|
||||
fn foo() { let _ = S::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "m",
|
||||
source_range: [100; 100),
|
||||
delete: [100; 100),
|
||||
insert: "m()$0",
|
||||
kind: Function,
|
||||
detail: "fn m()",
|
||||
documentation: Documentation(
|
||||
"An associated method",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_union_associated_method() {
|
||||
check_reference_completion(
|
||||
"union_associated_method",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /lib.rs
|
||||
/// A union
|
||||
@ -319,14 +504,28 @@ mod tests {
|
||||
}
|
||||
|
||||
fn foo() { let _ = U::<|> }
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "m",
|
||||
source_range: [101; 101),
|
||||
delete: [101; 101),
|
||||
insert: "m()$0",
|
||||
kind: Function,
|
||||
detail: "fn m()",
|
||||
documentation: Documentation(
|
||||
"An associated method",
|
||||
),
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn completes_use_paths_across_crates() {
|
||||
check_reference_completion(
|
||||
"completes_use_paths_across_crates",
|
||||
assert_debug_snapshot_matches!(
|
||||
do_reference_completion(
|
||||
"
|
||||
//- /main.rs
|
||||
use foo::<|>;
|
||||
@ -335,7 +534,17 @@ mod tests {
|
||||
pub mod bar {
|
||||
pub struct S;
|
||||
}
|
||||
",
|
||||
"
|
||||
),
|
||||
@r###"[
|
||||
CompletionItem {
|
||||
label: "bar",
|
||||
source_range: [9; 9),
|
||||
delete: [9; 9),
|
||||
insert: "bar",
|
||||
kind: Module,
|
||||
},
|
||||
]"###
|
||||
);
|
||||
}
|
||||
}
|
||||
|
@ -1,15 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.108690807Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "bar",
|
||||
source_range: [9; 9),
|
||||
delete: [9; 9),
|
||||
insert: "bar",
|
||||
kind: Module,
|
||||
},
|
||||
]
|
@ -1,15 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.085633034Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "Spam",
|
||||
source_range: [23; 25),
|
||||
delete: [23; 25),
|
||||
insert: "Spam",
|
||||
kind: Struct,
|
||||
},
|
||||
]
|
@ -1,19 +0,0 @@
|
||||
---
|
||||
created: "2019-06-29T10:30:34.110468474Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "m",
|
||||
source_range: [100; 100),
|
||||
delete: [100; 100),
|
||||
insert: "m()$0",
|
||||
kind: Function,
|
||||
detail: "fn m()",
|
||||
documentation: Documentation(
|
||||
"An associated method",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,30 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.090178265Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "Bar",
|
||||
source_range: [116; 116),
|
||||
delete: [116; 116),
|
||||
insert: "Bar",
|
||||
kind: EnumVariant,
|
||||
detail: "(i32)",
|
||||
documentation: Documentation(
|
||||
"Bar Variant with i32",
|
||||
),
|
||||
},
|
||||
CompletionItem {
|
||||
label: "Foo",
|
||||
source_range: [116; 116),
|
||||
delete: [116; 116),
|
||||
insert: "Foo",
|
||||
kind: EnumVariant,
|
||||
detail: "()",
|
||||
documentation: Documentation(
|
||||
"Foo Variant",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,41 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.091325331Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "Bar",
|
||||
source_range: [180; 180),
|
||||
delete: [180; 180),
|
||||
insert: "Bar",
|
||||
kind: EnumVariant,
|
||||
detail: "(i32, u32)",
|
||||
documentation: Documentation(
|
||||
"Bar Variant with i32 and u32",
|
||||
),
|
||||
},
|
||||
CompletionItem {
|
||||
label: "Foo",
|
||||
source_range: [180; 180),
|
||||
delete: [180; 180),
|
||||
insert: "Foo",
|
||||
kind: EnumVariant,
|
||||
detail: "()",
|
||||
documentation: Documentation(
|
||||
"Foo Variant (empty)",
|
||||
),
|
||||
},
|
||||
CompletionItem {
|
||||
label: "S",
|
||||
source_range: [180; 180),
|
||||
delete: [180; 180),
|
||||
insert: "S",
|
||||
kind: EnumVariant,
|
||||
detail: "(S)",
|
||||
documentation: Documentation(
|
||||
"",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,18 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.093689514Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "my",
|
||||
source_range: [23; 25),
|
||||
delete: [23; 25),
|
||||
insert: "my",
|
||||
kind: Module,
|
||||
documentation: Documentation(
|
||||
"Some simple\ndocs describing `mod my`.",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,22 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.099358768Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "Spam",
|
||||
source_range: [12; 14),
|
||||
delete: [12; 14),
|
||||
insert: "Spam",
|
||||
kind: Struct,
|
||||
},
|
||||
CompletionItem {
|
||||
label: "foo",
|
||||
source_range: [12; 14),
|
||||
delete: [12; 14),
|
||||
insert: "foo",
|
||||
kind: Module,
|
||||
},
|
||||
]
|
@ -1,19 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.101474826Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "C",
|
||||
source_range: [107; 107),
|
||||
delete: [107; 107),
|
||||
insert: "C",
|
||||
kind: Const,
|
||||
detail: "const C: i32 = 42;",
|
||||
documentation: Documentation(
|
||||
"An associated const",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,19 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.102351365Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "m",
|
||||
source_range: [100; 100),
|
||||
delete: [100; 100),
|
||||
insert: "m()$0",
|
||||
kind: Function,
|
||||
detail: "fn m()",
|
||||
documentation: Documentation(
|
||||
"An associated method",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,19 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.105188762Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "T",
|
||||
source_range: [101; 101),
|
||||
delete: [101; 101),
|
||||
insert: "T",
|
||||
kind: TypeAlias,
|
||||
detail: "type T = i32;",
|
||||
documentation: Documentation(
|
||||
"An associated type",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,19 +0,0 @@
|
||||
---
|
||||
created: "2019-06-29T10:37:44.968500164Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "m",
|
||||
source_range: [101; 101),
|
||||
delete: [101; 101),
|
||||
insert: "m()$0",
|
||||
kind: Function,
|
||||
detail: "fn m()",
|
||||
documentation: Documentation(
|
||||
"An associated method",
|
||||
),
|
||||
},
|
||||
]
|
@ -1,22 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.105336210Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "Spam",
|
||||
source_range: [11; 13),
|
||||
delete: [11; 13),
|
||||
insert: "Spam",
|
||||
kind: Struct,
|
||||
},
|
||||
CompletionItem {
|
||||
label: "foo",
|
||||
source_range: [11; 13),
|
||||
delete: [11; 13),
|
||||
insert: "foo",
|
||||
kind: Module,
|
||||
},
|
||||
]
|
@ -1,15 +0,0 @@
|
||||
---
|
||||
created: "2019-05-23T22:23:35.106923266Z"
|
||||
creator: insta@0.8.1
|
||||
source: crates/ra_ide_api/src/completion/completion_item.rs
|
||||
expression: kind_completions
|
||||
---
|
||||
[
|
||||
CompletionItem {
|
||||
label: "Bar",
|
||||
source_range: [26; 26),
|
||||
delete: [26; 26),
|
||||
insert: "Bar",
|
||||
kind: Struct,
|
||||
},
|
||||
]
|
Loading…
Reference in New Issue
Block a user