reverie/tests/suppression.rs
Jason White cc40e95c91 Remove unnecessary Serialize/Deserialize impls for tools
Summary: Now that `Tool` doesn't require `Serialize` and `Deserialize`, we can remove these unnecessary derives. Hopefully this will have a slight improvement to compile-times.

Reviewed By: wkhughes

Differential Revision: D40958697

fbshipit-source-id: 88aa1f4ee2b953ba287d749c88d200c2887ccd46
2022-11-03 12:53:11 -07:00

58 lines
1.5 KiB
Rust

/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree.
*/
//! Tests that syscall suppression works. That is, when we intercept a syscall,
//! we should not run the real syscall.
use reverie::syscalls::Syscall;
use reverie::Error;
use reverie::Guest;
use reverie::Tool;
#[derive(Debug, Default, Clone)]
struct TestTool;
#[reverie::tool]
impl Tool for TestTool {
async fn handle_syscall_event<T: Guest<Self>>(
&self,
guest: &mut T,
syscall: Syscall,
) -> Result<i64, Error> {
match syscall {
Syscall::Tgkill(_) => {
// Suppress this syscall. This thread shall not be killed.
Ok(0)
}
_ => guest.tail_inject(syscall).await,
}
}
}
#[cfg(all(not(sanitized), test))]
mod tests {
use reverie_ptrace::testing::check_fn;
use syscalls::syscall;
use syscalls::Sysno;
use super::*;
#[test]
fn suppress_tgkill() {
check_fn::<TestTool, _>(|| {
let pid = unsafe { syscall!(Sysno::getpid) }.unwrap();
let tid = unsafe { syscall!(Sysno::gettid) }.unwrap();
// This shouldn't work.
for _ in 0..100 {
let ret = unsafe { syscall!(Sysno::tgkill, pid, tid, libc::SIGTERM) };
assert_eq!(ret, Ok(0));
}
});
}
}