mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-10-01 12:20:39 +00:00
This change adds a few tests around directory-related functions.
This commit is contained in:
parent
d246964bdf
commit
9153067d66
@ -27,6 +27,7 @@ tokio-io = { version = "0.1.6", path = "../tokio-io" }
|
|||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
rand = "0.5"
|
rand = "0.5"
|
||||||
tempfile = "3"
|
tempfile = "3"
|
||||||
|
tempdir = "0.3"
|
||||||
tokio-io = { version = "0.1.6", path = "../tokio-io" }
|
tokio-io = { version = "0.1.6", path = "../tokio-io" }
|
||||||
tokio-codec = { version = "0.1.0", path = "../tokio-codec" }
|
tokio-codec = { version = "0.1.0", path = "../tokio-codec" }
|
||||||
tokio = { version = "0.1.7", path = ".." }
|
tokio = { version = "0.1.7", path = ".." }
|
||||||
|
83
tokio-fs/tests/dir.rs
Normal file
83
tokio-fs/tests/dir.rs
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
extern crate futures;
|
||||||
|
extern crate tempdir;
|
||||||
|
extern crate tokio_fs;
|
||||||
|
extern crate tokio_threadpool;
|
||||||
|
|
||||||
|
use futures::sync::oneshot;
|
||||||
|
use futures::{Future, Stream};
|
||||||
|
use std::fs;
|
||||||
|
use std::sync::{Arc, Mutex};
|
||||||
|
use tempdir::TempDir;
|
||||||
|
use tokio_fs::*;
|
||||||
|
use tokio_threadpool::Builder;
|
||||||
|
|
||||||
|
fn run_in_pool<F>(f: F)
|
||||||
|
where
|
||||||
|
F: Future<Item = (), Error = std::io::Error> + Send + 'static,
|
||||||
|
{
|
||||||
|
let pool = Builder::new().pool_size(1).build();
|
||||||
|
let (tx, rx) = oneshot::channel::<()>();
|
||||||
|
pool.spawn(f.then(|_| tx.send(())));
|
||||||
|
rx.wait().unwrap()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn create() {
|
||||||
|
let base_dir = TempDir::new("base").unwrap();
|
||||||
|
let new_dir = base_dir.path().join("foo");
|
||||||
|
|
||||||
|
run_in_pool({ create_dir(new_dir.clone()) });
|
||||||
|
|
||||||
|
assert!(new_dir.is_dir());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn create_all() {
|
||||||
|
let base_dir = TempDir::new("base").unwrap();
|
||||||
|
let new_dir = base_dir.path().join("foo").join("bar");
|
||||||
|
|
||||||
|
run_in_pool({ create_dir_all(new_dir.clone()) });
|
||||||
|
|
||||||
|
assert!(new_dir.is_dir());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn remove() {
|
||||||
|
let base_dir = TempDir::new("base").unwrap();
|
||||||
|
let new_dir = base_dir.path().join("foo");
|
||||||
|
|
||||||
|
fs::create_dir(new_dir.clone()).unwrap();
|
||||||
|
|
||||||
|
run_in_pool({ remove_dir(new_dir.clone()) });
|
||||||
|
|
||||||
|
assert!(!new_dir.exists());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn read() {
|
||||||
|
let base_dir = TempDir::new("base").unwrap();
|
||||||
|
|
||||||
|
let p = base_dir.path();
|
||||||
|
fs::create_dir(p.join("aa")).unwrap();
|
||||||
|
fs::create_dir(p.join("bb")).unwrap();
|
||||||
|
fs::create_dir(p.join("cc")).unwrap();
|
||||||
|
|
||||||
|
let files = Arc::new(Mutex::new(Vec::new()));
|
||||||
|
|
||||||
|
let f = files.clone();
|
||||||
|
let p = p.to_path_buf();
|
||||||
|
run_in_pool({
|
||||||
|
read_dir(p).flatten_stream().for_each(move |e| {
|
||||||
|
let s = e.file_name().to_str().unwrap().to_string();
|
||||||
|
f.lock().unwrap().push(s);
|
||||||
|
Ok(())
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
let mut files = files.lock().unwrap();
|
||||||
|
files.sort(); // because the order is not guaranteed
|
||||||
|
assert_eq!(
|
||||||
|
*files,
|
||||||
|
vec!["aa".to_string(), "bb".to_string(), "cc".to_string()]
|
||||||
|
);
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user