tabox 1.3.6

A sandbox to execute a program in an isolated environment and measure its resource usage
Documentation
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
// SPDX-License-Identifier: MPL-2.0

use super::util::*;
use crate::configuration::SandboxConfiguration;
use crate::result::ExitStatus;
use crate::syscall_filter::{SyscallFilter, SyscallFilterAction};

#[test]
fn test_seccomp_filter() {
    let program = r#"
       #include <unistd.h>
       int main() { getpid(); return 0; }
    "#;

    let mut filter = SyscallFilter::default();
    filter
        .default_action(SyscallFilterAction::Allow)
        .add_rule("getpid", SyscallFilterAction::Kill);

    let mut config = SandboxConfiguration::default();
    config.syscall_filter(filter);

    let result = exec(program, &mut config, "");

    assert_eq!(result.result.status, ExitStatus::Signal(31));
}

#[test]
fn test_fork_block() {
    let program = r#"
       #include <unistd.h>
       int main() { fork(); return 0; }
    "#;

    let mut config = SandboxConfiguration::default();

    config.syscall_filter(SyscallFilter::build(false, false));

    let result = exec(program, &mut config, "");

    assert_eq!(result.result.status, ExitStatus::Signal(31));
}

#[test]
fn test_chmod_block() {
    let program = r#"
       #include <sys/stat.h>
       int main() { chmod("file", 777); return 0; }
    "#;

    let mut config = SandboxConfiguration::default();

    config.syscall_filter(SyscallFilter::build(false, false));

    let result = exec(program, &mut config, "");

    assert_eq!(result.result.status, ExitStatus::Signal(31));
}

#[test]
fn test_no_write_root() {
    let program = r#"
       #include <stdio.h>
       int main() { return fopen("/file", "w") == 0; }
    "#;

    let mut config = SandboxConfiguration::default();

    let result = exec(program, &mut config, "");

    assert_eq!(result.result.status, ExitStatus::ExitCode(1));
}

#[test]
fn test_write_tmp() {
    let program = r#"
       #include <stdio.h>
       int main() { return fopen("/tmp/file", "w") != 0; }
    "#;

    let mut config = SandboxConfiguration::default();
    config.mount_tmpfs(true);

    let result = exec(program, &mut config, "");

    assert_eq!(result.result.status, ExitStatus::ExitCode(1));
}