mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 05:38:46 +00:00
Improve tests
This commit is contained in:
parent
c5069eeef5
commit
2bc9e9f327
2 changed files with 63 additions and 30 deletions
|
@ -120,54 +120,65 @@ fn contiguous_range_for_comment<'a>(
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
use test_utils::extract_ranges;
|
||||||
|
|
||||||
|
fn do_check(text: &str, fold_kinds: &[FoldKind]) {
|
||||||
|
let (ranges, text) = extract_ranges(text);
|
||||||
|
let file = File::parse(&text);
|
||||||
|
let folds = folding_ranges(&file);
|
||||||
|
|
||||||
|
assert_eq!(folds.len(), ranges.len());
|
||||||
|
for ((fold, range), fold_kind) in folds.into_iter().zip(ranges.into_iter()).zip(fold_kinds.into_iter()) {
|
||||||
|
assert_eq!(fold.range.start(), range.start());
|
||||||
|
assert_eq!(fold.range.end(), range.end());
|
||||||
|
assert_eq!(&fold.kind, fold_kind);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_fold_comments() {
|
fn test_fold_comments() {
|
||||||
let text = r#"
|
let text = r#"
|
||||||
// Hello
|
<|>// Hello
|
||||||
// this is a multiline
|
// this is a multiline
|
||||||
// comment
|
// comment
|
||||||
//
|
//<|>
|
||||||
|
|
||||||
// But this is not
|
// But this is not
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
// We should
|
<|>// We should
|
||||||
// also
|
// also
|
||||||
// fold
|
// fold
|
||||||
// this one.
|
// this one.<|>
|
||||||
|
<|>//! But this one is different
|
||||||
|
//! because it has another flavor<|>
|
||||||
|
<|>/* As does this
|
||||||
|
multiline comment */<|>
|
||||||
}"#;
|
}"#;
|
||||||
|
|
||||||
let file = File::parse(&text);
|
let fold_kinds = &[
|
||||||
let folds = folding_ranges(&file);
|
FoldKind::Comment,
|
||||||
assert_eq!(folds.len(), 2);
|
FoldKind::Comment,
|
||||||
assert_eq!(folds[0].range.start(), 1.into());
|
FoldKind::Comment,
|
||||||
assert_eq!(folds[0].range.end(), 46.into());
|
FoldKind::Comment,
|
||||||
assert_eq!(folds[0].kind, FoldKind::Comment);
|
];
|
||||||
|
do_check(text, fold_kinds);
|
||||||
assert_eq!(folds[1].range.start(), 84.into());
|
|
||||||
assert_eq!(folds[1].range.end(), 137.into());
|
|
||||||
assert_eq!(folds[1].kind, FoldKind::Comment);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_fold_imports() {
|
fn test_fold_imports() {
|
||||||
let text = r#"
|
let text = r#"
|
||||||
use std::{
|
<|>use std::{
|
||||||
str,
|
str,
|
||||||
vec,
|
vec,
|
||||||
io as iop
|
io as iop
|
||||||
};
|
};<|>
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
}"#;
|
}"#;
|
||||||
|
|
||||||
let file = File::parse(&text);
|
let folds = &[FoldKind::Imports];
|
||||||
let folds = folding_ranges(&file);
|
do_check(text, folds);
|
||||||
assert_eq!(folds.len(), 1);
|
|
||||||
assert_eq!(folds[0].range.start(), 1.into());
|
|
||||||
assert_eq!(folds[0].range.end(), 46.into());
|
|
||||||
assert_eq!(folds[0].kind, FoldKind::Imports);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -38,22 +38,44 @@ pub fn assert_eq_dbg(expected: &str, actual: &impl fmt::Debug) {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn extract_offset(text: &str) -> (TextUnit, String) {
|
pub fn extract_offset(text: &str) -> (TextUnit, String) {
|
||||||
let cursor = "<|>";
|
match try_extract_offset(text) {
|
||||||
let cursor_pos = match text.find(cursor) {
|
|
||||||
None => panic!("text should contain cursor marker"),
|
None => panic!("text should contain cursor marker"),
|
||||||
Some(pos) => pos,
|
Some(result) => result,
|
||||||
};
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn try_extract_offset(text: &str) -> Option<(TextUnit, String)> {
|
||||||
|
let cursor = "<|>";
|
||||||
|
let cursor_pos = text.find(cursor)?;
|
||||||
let mut new_text = String::with_capacity(text.len() - cursor.len());
|
let mut new_text = String::with_capacity(text.len() - cursor.len());
|
||||||
new_text.push_str(&text[..cursor_pos]);
|
new_text.push_str(&text[..cursor_pos]);
|
||||||
new_text.push_str(&text[cursor_pos + cursor.len()..]);
|
new_text.push_str(&text[cursor_pos + cursor.len()..]);
|
||||||
let cursor_pos = TextUnit::from(cursor_pos as u32);
|
let cursor_pos = TextUnit::from(cursor_pos as u32);
|
||||||
(cursor_pos, new_text)
|
Some((cursor_pos, new_text))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn extract_range(text: &str) -> (TextRange, String) {
|
pub fn extract_range(text: &str) -> (TextRange, String) {
|
||||||
let (start, text) = extract_offset(text);
|
match try_extract_range(text) {
|
||||||
let (end, text) = extract_offset(&text);
|
None => panic!("text should contain cursor marker"),
|
||||||
(TextRange::from_to(start, end), text)
|
Some(result) => result,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn try_extract_range(text: &str) -> Option<(TextRange, String)> {
|
||||||
|
let (start, text) = try_extract_offset(text)?;
|
||||||
|
let (end, text) = try_extract_offset(&text)?;
|
||||||
|
Some((TextRange::from_to(start, end), text))
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn extract_ranges(text: &str) -> (Vec<TextRange>, String) {
|
||||||
|
let mut ranges = Vec::new();
|
||||||
|
let mut text = String::from(text);
|
||||||
|
while let Some((range, new_text)) = try_extract_range(&text) {
|
||||||
|
text = new_text;
|
||||||
|
ranges.push(range);
|
||||||
|
}
|
||||||
|
|
||||||
|
(ranges, text)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_cursor(text: &str, offset: TextUnit) -> String {
|
pub fn add_cursor(text: &str, offset: TextUnit) -> String {
|
||||||
|
|
Loading…
Reference in a new issue