mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-29 06:23:25 +00:00
Move some tests
This commit is contained in:
parent
da5c63c8f9
commit
663e11c4b0
2 changed files with 64 additions and 63 deletions
|
@ -1,38 +1,4 @@
|
||||||
use super::*;
|
use super::LineIndex;
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_line_index() {
|
|
||||||
let text = "hello\nworld";
|
|
||||||
let table = [
|
|
||||||
(00, 0, 0),
|
|
||||||
(01, 0, 1),
|
|
||||||
(05, 0, 5),
|
|
||||||
(06, 1, 0),
|
|
||||||
(07, 1, 1),
|
|
||||||
(08, 1, 2),
|
|
||||||
(10, 1, 4),
|
|
||||||
(11, 1, 5),
|
|
||||||
(12, 1, 6),
|
|
||||||
];
|
|
||||||
|
|
||||||
let index = LineIndex::new(text);
|
|
||||||
for (offset, line, col) in table {
|
|
||||||
assert_eq!(index.line_col(offset.into()), LineCol { line, col });
|
|
||||||
}
|
|
||||||
|
|
||||||
let text = "\nhello\nworld";
|
|
||||||
let table = [(0, 0, 0), (1, 1, 0), (2, 1, 1), (6, 1, 5), (7, 2, 0)];
|
|
||||||
let index = LineIndex::new(text);
|
|
||||||
for (offset, line, col) in table {
|
|
||||||
assert_eq!(index.line_col(offset.into()), LineCol { line, col });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_char_len() {
|
|
||||||
assert_eq!('メ'.len_utf8(), 3);
|
|
||||||
assert_eq!('メ'.len_utf16(), 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_empty_index() {
|
fn test_empty_index() {
|
||||||
|
@ -43,31 +9,3 @@ const C: char = 'x';
|
||||||
);
|
);
|
||||||
assert_eq!(col_index.line_wide_chars.len(), 0);
|
assert_eq!(col_index.line_wide_chars.len(), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_splitlines() {
|
|
||||||
fn r(lo: u32, hi: u32) -> TextRange {
|
|
||||||
TextRange::new(lo.into(), hi.into())
|
|
||||||
}
|
|
||||||
|
|
||||||
let text = "a\nbb\nccc\n";
|
|
||||||
let line_index = LineIndex::new(text);
|
|
||||||
|
|
||||||
let actual = line_index.lines(r(0, 9)).collect::<Vec<_>>();
|
|
||||||
let expected = vec![r(0, 2), r(2, 5), r(5, 9)];
|
|
||||||
assert_eq!(actual, expected);
|
|
||||||
|
|
||||||
let text = "";
|
|
||||||
let line_index = LineIndex::new(text);
|
|
||||||
|
|
||||||
let actual = line_index.lines(r(0, 0)).collect::<Vec<_>>();
|
|
||||||
let expected = vec![];
|
|
||||||
assert_eq!(actual, expected);
|
|
||||||
|
|
||||||
let text = "\n";
|
|
||||||
let line_index = LineIndex::new(text);
|
|
||||||
|
|
||||||
let actual = line_index.lines(r(0, 1)).collect::<Vec<_>>();
|
|
||||||
let expected = vec![r(0, 1)];
|
|
||||||
assert_eq!(actual, expected)
|
|
||||||
}
|
|
||||||
|
|
63
lib/line-index/tests/it.rs
Normal file
63
lib/line-index/tests/it.rs
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
use line_index::{LineCol, LineIndex, TextRange};
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_line_index() {
|
||||||
|
let text = "hello\nworld";
|
||||||
|
let table = [
|
||||||
|
(00, 0, 0),
|
||||||
|
(01, 0, 1),
|
||||||
|
(05, 0, 5),
|
||||||
|
(06, 1, 0),
|
||||||
|
(07, 1, 1),
|
||||||
|
(08, 1, 2),
|
||||||
|
(10, 1, 4),
|
||||||
|
(11, 1, 5),
|
||||||
|
(12, 1, 6),
|
||||||
|
];
|
||||||
|
|
||||||
|
let index = LineIndex::new(text);
|
||||||
|
for (offset, line, col) in table {
|
||||||
|
assert_eq!(index.line_col(offset.into()), LineCol { line, col });
|
||||||
|
}
|
||||||
|
|
||||||
|
let text = "\nhello\nworld";
|
||||||
|
let table = [(0, 0, 0), (1, 1, 0), (2, 1, 1), (6, 1, 5), (7, 2, 0)];
|
||||||
|
let index = LineIndex::new(text);
|
||||||
|
for (offset, line, col) in table {
|
||||||
|
assert_eq!(index.line_col(offset.into()), LineCol { line, col });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_char_len() {
|
||||||
|
assert_eq!('メ'.len_utf8(), 3);
|
||||||
|
assert_eq!('メ'.len_utf16(), 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_splitlines() {
|
||||||
|
fn r(lo: u32, hi: u32) -> TextRange {
|
||||||
|
TextRange::new(lo.into(), hi.into())
|
||||||
|
}
|
||||||
|
|
||||||
|
let text = "a\nbb\nccc\n";
|
||||||
|
let line_index = LineIndex::new(text);
|
||||||
|
|
||||||
|
let actual = line_index.lines(r(0, 9)).collect::<Vec<_>>();
|
||||||
|
let expected = vec![r(0, 2), r(2, 5), r(5, 9)];
|
||||||
|
assert_eq!(actual, expected);
|
||||||
|
|
||||||
|
let text = "";
|
||||||
|
let line_index = LineIndex::new(text);
|
||||||
|
|
||||||
|
let actual = line_index.lines(r(0, 0)).collect::<Vec<_>>();
|
||||||
|
let expected = vec![];
|
||||||
|
assert_eq!(actual, expected);
|
||||||
|
|
||||||
|
let text = "\n";
|
||||||
|
let line_index = LineIndex::new(text);
|
||||||
|
|
||||||
|
let actual = line_index.lines(r(0, 1)).collect::<Vec<_>>();
|
||||||
|
let expected = vec![r(0, 1)];
|
||||||
|
assert_eq!(actual, expected)
|
||||||
|
}
|
Loading…
Reference in a new issue