2016-09-30 21:01:53 +00:00
|
|
|
pub const DEFAULT_BUF_SIZE: usize = 8 * 1024;
|
|
|
|
|
2016-09-22 01:30:30 +00:00
|
|
|
#[cfg(test)]
|
|
|
|
#[allow(dead_code)] // not used on emscripten
|
2016-03-17 03:50:45 +00:00
|
|
|
pub mod test {
|
2019-02-10 19:23:21 +00:00
|
|
|
use crate::env;
|
|
|
|
use crate::fs;
|
2019-11-27 18:29:00 +00:00
|
|
|
use crate::path::{Path, PathBuf};
|
2019-02-10 19:23:21 +00:00
|
|
|
use rand::RngCore;
|
2016-03-17 03:50:45 +00:00
|
|
|
|
|
|
|
pub struct TempDir(PathBuf);
|
|
|
|
|
|
|
|
impl TempDir {
|
|
|
|
pub fn join(&self, path: &str) -> PathBuf {
|
|
|
|
let TempDir(ref p) = *self;
|
|
|
|
p.join(path)
|
|
|
|
}
|
|
|
|
|
2019-06-25 17:43:18 +00:00
|
|
|
pub fn path(&self) -> &Path {
|
2016-03-17 03:50:45 +00:00
|
|
|
let TempDir(ref p) = *self;
|
|
|
|
p
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Drop for TempDir {
|
|
|
|
fn drop(&mut self) {
|
|
|
|
// Gee, seeing how we're testing the fs module I sure hope that we
|
|
|
|
// at least implement this correctly!
|
|
|
|
let TempDir(ref p) = *self;
|
|
|
|
fs::remove_dir_all(p).unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn tmpdir() -> TempDir {
|
|
|
|
let p = env::temp_dir();
|
|
|
|
let mut r = rand::thread_rng();
|
|
|
|
let ret = p.join(&format!("rust-{}", r.next_u32()));
|
|
|
|
fs::create_dir(&ret).unwrap();
|
|
|
|
TempDir(ret)
|
|
|
|
}
|
|
|
|
}
|