mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-16 07:03:57 +00:00
Auto merge of #12174 - Veykril:completion-rev, r=Veykril
internal: Improve completion tests by checking that the offset is included in the source_range of items
This commit is contained in:
commit
57c5447f90
2 changed files with 12 additions and 2 deletions
|
@ -26,7 +26,7 @@ pub struct CompletionItem {
|
|||
/// It should be used primarily for UI, but we also use this to convert
|
||||
/// generic TextEdit into LSP's completion edit (see conv.rs).
|
||||
///
|
||||
/// `source_range` must contain the completion offset. `insert_text` should
|
||||
/// `source_range` must contain the completion offset. `text_edit` should
|
||||
/// start with what `source_range` points to, or VSCode will filter out the
|
||||
/// completion silently.
|
||||
source_range: TextRange,
|
||||
|
|
|
@ -214,7 +214,17 @@ pub(crate) fn check_pattern_is_applicable(code: &str, check: impl FnOnce(SyntaxE
|
|||
|
||||
pub(crate) fn get_all_items(config: CompletionConfig, code: &str) -> Vec<CompletionItem> {
|
||||
let (db, position) = position(code);
|
||||
crate::completions(&db, &config, position).map_or_else(Vec::default, Into::into)
|
||||
let res = crate::completions(&db, &config, position).map_or_else(Vec::default, Into::into);
|
||||
// validate
|
||||
res.iter().for_each(|it| {
|
||||
let sr = it.source_range();
|
||||
assert!(
|
||||
sr.contains_inclusive(position.offset),
|
||||
"source range {sr:?} does not contain the offset {:?} of the completion request: {it:?}",
|
||||
position.offset
|
||||
);
|
||||
});
|
||||
res
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
|
Loading…
Reference in a new issue