1
//! Helper functionality for writing tests within the `tor-rpc-connect` crate.
2

            
3
#[cfg(unix)]
4
use std::os::unix::fs::PermissionsExt;
5

            
6
use std::path::PathBuf;
7

            
8
use fs_mistrust::Mistrust;
9
use tempfile::TempDir;
10

            
11
/// Create a temporary secure directory.
12
///
13
/// Return a [`tempfile::TempDir`] object (which should be retained but ignored),
14
/// a path to a secure directory within that `TempDir`,
15
/// and a [`Mistrust`] that accepts that secure directory.
16
///
17
/// # Panics
18
///
19
/// Panics if any operation fails.  This function is for testing only.
20
#[allow(clippy::unwrap_used)]
21
6
pub(crate) fn tempdir() -> (TempDir, PathBuf, Mistrust) {
22
6
    let mut bld = tempfile::Builder::new();
23
6
    #[cfg(unix)]
24
6
    bld.permissions(PermissionsExt::from_mode(0o700));
25
6
    let tempdir = bld.tempdir().unwrap();
26
6
    let subdir = tempdir.as_ref().join("d");
27
6

            
28
6
    let mistrust = fs_mistrust::Mistrust::builder()
29
6
        .ignore_prefix(tempdir.as_ref().canonicalize().unwrap())
30
6
        .build()
31
6
        .unwrap();
32
6

            
33
6
    mistrust.make_directory(&subdir).unwrap();
34
6
    (tempdir, subdir, mistrust)
35
6
}