Introduce completion test utils

This commit is contained in:
Aleksey Kladov
2020-03-11 10:46:43 +01:00
parent 9b0b59c5d2
commit dad8f1e064
16 changed files with 49 additions and 48 deletions

View File

@@ -0,0 +1,29 @@
//! Runs completion for testing purposes.
use crate::{
completion::{completion_item::CompletionKind, CompletionOptions},
mock_analysis::{analysis_and_position, single_file_with_position},
CompletionItem,
};
pub(crate) fn do_completion(code: &str, kind: CompletionKind) -> Vec<CompletionItem> {
do_completion_with_options(code, kind, &CompletionOptions::default())
}
pub(crate) fn do_completion_with_options(
code: &str,
kind: CompletionKind,
options: &CompletionOptions,
) -> Vec<CompletionItem> {
let (analysis, position) = if code.contains("//-") {
analysis_and_position(code)
} else {
single_file_with_position(code)
};
let completions = analysis.completions(position, options).unwrap().unwrap();
let completion_items: Vec<CompletionItem> = completions.into();
let mut kind_completions: Vec<CompletionItem> =
completion_items.into_iter().filter(|c| c.completion_kind == kind).collect();
kind_completions.sort_by_key(|c| c.label().to_owned());
kind_completions
}