Improve tests

This commit is contained in:
Adolfo Ochagavía 2018-10-13 21:33:15 +02:00
parent c5069eeef5
commit 2bc9e9f327
2 changed files with 63 additions and 30 deletions

View file

@ -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);
} }

View file

@ -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 {