Skip to content

Commit

Permalink
test(integration_test): port 'runtime-tools/validation/linux_seccomp' (
Browse files Browse the repository at this point in the history
…#2531)

* test(integration_test): port 'runtime-tools/validation/linux_seccomp'

Signed-off-by: Xiaoyang Liu <[email protected]>

* test(integration_test): address code review suggestions

Co-authored-by: Yashodhan <[email protected]>
Signed-off-by: Xiaoyang Liu <[email protected]>

* test(integration_test): format the code

Signed-off-by: Xiaoyang Liu <[email protected]>

---------

Signed-off-by: Xiaoyang Liu <[email protected]>
Co-authored-by: Yashodhan <[email protected]>
  • Loading branch information
Xiaoyang Liu and YJDoc2 authored Nov 17, 2023
1 parent 3c7cc26 commit 18f3dd7
Show file tree
Hide file tree
Showing 5 changed files with 71 additions and 0 deletions.
3 changes: 3 additions & 0 deletions tests/integration_test/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ use crate::tests::linux_ns_itype::get_ns_itype_tests;
use crate::tests::mounts_recursive::get_mounts_recursive_test;
use crate::tests::pidfile::get_pidfile_test;
use crate::tests::readonly_paths::get_ro_paths_test;
use crate::tests::seccomp::get_seccomp_test;
use crate::tests::seccomp_notify::get_seccomp_notify_test;
use crate::tests::sysctl::get_sysctl_test;
use crate::tests::tlb::get_tlb_test;
Expand Down Expand Up @@ -95,6 +96,7 @@ fn main() -> Result<()> {
let cgroup_v1_memory = cgroups::memory::get_test_group();
let cgroup_v1_network = cgroups::network::get_test_group();
let cgroup_v1_blkio = cgroups::blkio::get_test_group();
let seccomp = get_seccomp_test();
let seccomp_notify = get_seccomp_notify_test();
let ro_paths = get_ro_paths_test();
let hostname = get_hostname_test();
Expand All @@ -114,6 +116,7 @@ fn main() -> Result<()> {
tm.add_test_group(Box::new(cgroup_v1_memory));
tm.add_test_group(Box::new(cgroup_v1_network));
tm.add_test_group(Box::new(cgroup_v1_blkio));
tm.add_test_group(Box::new(seccomp));
tm.add_test_group(Box::new(seccomp_notify));
tm.add_test_group(Box::new(ro_paths));
tm.add_test_group(Box::new(hostname));
Expand Down
1 change: 1 addition & 0 deletions tests/integration_test/src/tests/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ pub mod linux_ns_itype;
pub mod mounts_recursive;
pub mod pidfile;
pub mod readonly_paths;
pub mod seccomp;
pub mod seccomp_notify;
pub mod sysctl;
pub mod tlb;
48 changes: 48 additions & 0 deletions tests/integration_test/src/tests/seccomp/mod.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
use oci_spec::runtime::{
LinuxBuilder, LinuxSeccomp, LinuxSeccompAction, LinuxSeccompBuilder, LinuxSyscallBuilder,
ProcessBuilder, Spec, SpecBuilder,
};
use test_framework::{Test, TestGroup, TestResult};

use crate::utils::test_inside_container;

fn create_spec(seccomp: LinuxSeccomp) -> Spec {
SpecBuilder::default()
.linux(
LinuxBuilder::default()
.seccomp(seccomp)
.build()
.expect("error in building linux config"),
)
.process(
ProcessBuilder::default()
.args(vec!["runtimetest".to_string(), "seccomp".to_string()])
.build()
.expect("error in creating process config"),
)
.build()
.unwrap()
}

fn seccomp_test() -> TestResult {
let spec = create_spec(
LinuxSeccompBuilder::default()
.default_action(LinuxSeccompAction::ScmpActAllow)
.syscalls(vec![LinuxSyscallBuilder::default()
.names(vec![String::from("getcwd")])
.action(LinuxSeccompAction::ScmpActErrno)
.build()
.unwrap()])
.build()
.unwrap(),
);
test_inside_container(spec, &|_| Ok(()))
}

pub fn get_seccomp_test() -> TestGroup {
let mut test_group = TestGroup::new("seccomp");
let seccomp_test = Test::new("seccomp_test", Box::new(seccomp_test));
test_group.add(vec![Box::new(seccomp_test)]);

test_group
}
1 change: 1 addition & 0 deletions tests/runtimetest/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ fn main() {
"readonly_paths" => tests::validate_readonly_paths(&spec),
"set_host_name" => tests::validate_hostname(&spec),
"mounts_recursive" => tests::validate_mounts_recursive(&spec),
"seccomp" => tests::validate_seccomp(&spec),
"sysctl" => tests::validate_sysctl(&spec),
_ => eprintln!("error due to unexpected execute test name: {execute_test}"),
}
Expand Down
18 changes: 18 additions & 0 deletions tests/runtimetest/src/tests.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
use crate::utils::{self, test_read_access, test_write_access};
use anyhow::{bail, Result};
use nix::errno::Errno;
use nix::unistd::getcwd;
use oci_spec::runtime::Spec;
use std::fs::{self, read_dir};
use std::path::Path;
Expand Down Expand Up @@ -268,6 +269,23 @@ pub fn validate_mounts_recursive(spec: &Spec) {
}
}

pub fn validate_seccomp(spec: &Spec) {
let linux = spec.linux().as_ref().unwrap();
if linux.seccomp().is_some() {
if let Err(errno) = getcwd() {
if errno != Errno::EPERM {
eprintln!(
"'getcwd()' failed with unexpected error code '{errno}', expected 'EPERM'"
);
}
} else {
eprintln!(
"'getcwd()' syscall succeeded. It was expected to fail due to seccomp policies."
);
}
}
}

pub fn validate_sysctl(spec: &Spec) {
let linux = spec.linux().as_ref().unwrap();
if let Some(expected_linux_sysctl) = linux.sysctl() {
Expand Down

0 comments on commit 18f3dd7

Please sign in to comment.