mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 11:55:04 +00:00
Merge #5537
5537: Add one more test r=matklad a=matklad
bors r+
🤖
Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
commit
4e21fc3136
1 changed files with 48 additions and 19 deletions
|
@ -148,25 +148,54 @@ impl fst::Automaton for PrefixOf<'_> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[cfg(test)]
|
||||||
fn test_partitioning() {
|
mod tests {
|
||||||
let mut file_set = FileSetConfig::builder();
|
use super::*;
|
||||||
file_set.add_file_set(vec![VfsPath::new_virtual_path("/foo".into())]);
|
|
||||||
file_set.add_file_set(vec![VfsPath::new_virtual_path("/foo/bar/baz".into())]);
|
|
||||||
let file_set = file_set.build();
|
|
||||||
|
|
||||||
let mut vfs = Vfs::default();
|
#[test]
|
||||||
vfs.set_file_contents(VfsPath::new_virtual_path("/foo/src/lib.rs".into()), Some(Vec::new()));
|
fn path_prefix() {
|
||||||
vfs.set_file_contents(
|
let mut file_set = FileSetConfig::builder();
|
||||||
VfsPath::new_virtual_path("/foo/src/bar/baz/lib.rs".into()),
|
file_set.add_file_set(vec![VfsPath::new_virtual_path("/foo".into())]);
|
||||||
Some(Vec::new()),
|
file_set.add_file_set(vec![VfsPath::new_virtual_path("/foo/bar/baz".into())]);
|
||||||
);
|
let file_set = file_set.build();
|
||||||
vfs.set_file_contents(
|
|
||||||
VfsPath::new_virtual_path("/foo/bar/baz/lib.rs".into()),
|
|
||||||
Some(Vec::new()),
|
|
||||||
);
|
|
||||||
vfs.set_file_contents(VfsPath::new_virtual_path("/quux/lib.rs".into()), Some(Vec::new()));
|
|
||||||
|
|
||||||
let partition = file_set.partition(&vfs).into_iter().map(|it| it.len()).collect::<Vec<_>>();
|
let mut vfs = Vfs::default();
|
||||||
assert_eq!(partition, vec![2, 1, 1]);
|
vfs.set_file_contents(
|
||||||
|
VfsPath::new_virtual_path("/foo/src/lib.rs".into()),
|
||||||
|
Some(Vec::new()),
|
||||||
|
);
|
||||||
|
vfs.set_file_contents(
|
||||||
|
VfsPath::new_virtual_path("/foo/src/bar/baz/lib.rs".into()),
|
||||||
|
Some(Vec::new()),
|
||||||
|
);
|
||||||
|
vfs.set_file_contents(
|
||||||
|
VfsPath::new_virtual_path("/foo/bar/baz/lib.rs".into()),
|
||||||
|
Some(Vec::new()),
|
||||||
|
);
|
||||||
|
vfs.set_file_contents(VfsPath::new_virtual_path("/quux/lib.rs".into()), Some(Vec::new()));
|
||||||
|
|
||||||
|
let partition = file_set.partition(&vfs).into_iter().map(|it| it.len()).collect::<Vec<_>>();
|
||||||
|
assert_eq!(partition, vec![2, 1, 1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn name_prefix() {
|
||||||
|
let mut file_set = FileSetConfig::builder();
|
||||||
|
file_set.add_file_set(vec![VfsPath::new_virtual_path("/foo".into())]);
|
||||||
|
file_set.add_file_set(vec![VfsPath::new_virtual_path("/foo-things".into())]);
|
||||||
|
let file_set = file_set.build();
|
||||||
|
|
||||||
|
let mut vfs = Vfs::default();
|
||||||
|
vfs.set_file_contents(
|
||||||
|
VfsPath::new_virtual_path("/foo/src/lib.rs".into()),
|
||||||
|
Some(Vec::new()),
|
||||||
|
);
|
||||||
|
vfs.set_file_contents(
|
||||||
|
VfsPath::new_virtual_path("/foo-things/src/lib.rs".into()),
|
||||||
|
Some(Vec::new()),
|
||||||
|
);
|
||||||
|
|
||||||
|
let partition = file_set.partition(&vfs).into_iter().map(|it| it.len()).collect::<Vec<_>>();
|
||||||
|
assert_eq!(partition, vec![1, 1, 0]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue