2023-02-19 03:48:50 -06:00
|
|
|
#![allow(unused)]
|
|
|
|
|
|
|
|
use std::path::{Path, PathBuf};
|
|
|
|
use std::{env, fs, thread};
|
2024-07-28 17:13:50 -05:00
|
|
|
|
2023-09-08 22:57:15 -05:00
|
|
|
use rand::RngCore;
|
2023-02-19 03:48:50 -06:00
|
|
|
|
|
|
|
/// Copied from `std::test_helpers::test_rng`, since these tests rely on the
|
|
|
|
/// seed not being the same for every RNG invocation too.
|
|
|
|
#[track_caller]
|
|
|
|
pub(crate) fn test_rng() -> rand_xorshift::XorShiftRng {
|
|
|
|
use core::hash::{BuildHasher, Hash, Hasher};
|
2023-09-08 22:57:15 -05:00
|
|
|
let mut hasher = std::hash::RandomState::new().build_hasher();
|
2023-02-19 03:48:50 -06:00
|
|
|
core::panic::Location::caller().hash(&mut hasher);
|
|
|
|
let hc64 = hasher.finish();
|
|
|
|
let seed_vec = hc64.to_le_bytes().into_iter().chain(0u8..8).collect::<Vec<u8>>();
|
|
|
|
let seed: [u8; 16] = seed_vec.as_slice().try_into().unwrap();
|
|
|
|
rand::SeedableRng::from_seed(seed)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Copied from std::sys_common::io
|
2023-05-08 16:51:07 -05:00
|
|
|
pub(crate) struct TempDir(PathBuf);
|
2023-02-19 03:48:50 -06:00
|
|
|
|
|
|
|
impl TempDir {
|
2023-05-08 16:51:07 -05:00
|
|
|
pub(crate) fn join(&self, path: &str) -> PathBuf {
|
2023-02-19 03:48:50 -06:00
|
|
|
let TempDir(ref p) = *self;
|
|
|
|
p.join(path)
|
|
|
|
}
|
|
|
|
|
2023-05-08 16:51:07 -05:00
|
|
|
pub(crate) fn path(&self) -> &Path {
|
2023-02-19 03:48:50 -06: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;
|
|
|
|
let result = fs::remove_dir_all(p);
|
|
|
|
// Avoid panicking while panicking as this causes the process to
|
|
|
|
// immediately abort, without displaying test results.
|
|
|
|
if !thread::panicking() {
|
|
|
|
result.unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[track_caller] // for `test_rng`
|
2023-05-08 16:51:07 -05:00
|
|
|
pub(crate) fn tmpdir() -> TempDir {
|
2023-02-19 03:48:50 -06:00
|
|
|
let p = env::temp_dir();
|
|
|
|
let mut r = test_rng();
|
|
|
|
let ret = p.join(&format!("rust-{}", r.next_u32()));
|
|
|
|
fs::create_dir(&ret).unwrap();
|
|
|
|
TempDir(ret)
|
|
|
|
}
|