diff options
Diffstat (limited to 'test/test.rs')
-rw-r--r-- | test/test.rs | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/test/test.rs b/test/test.rs index 0a3d3b74..c8b8717f 100644 --- a/test/test.rs +++ b/test/test.rs @@ -9,6 +9,8 @@ extern crate nix; extern crate lazy_static; extern crate libc; extern crate rand; +#[cfg(target_os = "freebsd")] +extern crate sysctl; extern crate tempfile; #[cfg(any(target_os = "android", target_os = "linux"))] @@ -27,14 +29,31 @@ macro_rules! require_capability { } } +#[cfg(target_os = "freebsd")] +macro_rules! skip_if_jailed { + ($name:expr) => { + use ::sysctl::CtlValue; + + if let CtlValue::Int(1) = ::sysctl::value("security.jail.jailed") + .unwrap() + { + use ::std::io::Write; + let stderr = ::std::io::stderr(); + let mut handle = stderr.lock(); + writeln!(handle, "{} cannot run in a jail. Skipping test.", $name) + .unwrap(); + return; + } + } +} + macro_rules! skip_if_not_root { ($name:expr) => { use nix::unistd::Uid; - use std; - use std::io::Write; if !Uid::current().is_root() { - let stderr = std::io::stderr(); + use ::std::io::Write; + let stderr = ::std::io::stderr(); let mut handle = stderr.lock(); writeln!(handle, "{} requires root privileges. Skipping test.", $name).unwrap(); return; |