diff options
author | Alice Frosi <afrosi@redhat.com> | 2023-02-23 09:48:59 +0100 |
---|---|---|
committer | Alice Frosi <afrosi@redhat.com> | 2023-02-23 16:15:33 +0100 |
commit | 5523c957d3a261bb29ec6da382a15538e42ae737 (patch) | |
tree | a69e90ba144ed1dbf550fe8ea79c11a7712e9e49 /tests | |
parent | 5049d01c8d5e77eac9c91367bfc10d1673785c5f (diff) | |
download | seitan-5523c957d3a261bb29ec6da382a15538e42ae737.tar seitan-5523c957d3a261bb29ec6da382a15538e42ae737.tar.gz seitan-5523c957d3a261bb29ec6da382a15538e42ae737.tar.bz2 seitan-5523c957d3a261bb29ec6da382a15538e42ae737.tar.lz seitan-5523c957d3a261bb29ec6da382a15538e42ae737.tar.xz seitan-5523c957d3a261bb29ec6da382a15538e42ae737.tar.zst seitan-5523c957d3a261bb29ec6da382a15538e42ae737.zip |
tests: generalize the syscall of the target
Refactor the tests to pass the filtered syscall and setting the argument
into the shared struct.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/unit/test_operations.c | 31 |
1 files changed, 19 insertions, 12 deletions
diff --git a/tests/unit/test_operations.c b/tests/unit/test_operations.c index 9dd78eb..750ad04 100644 --- a/tests/unit/test_operations.c +++ b/tests/unit/test_operations.c @@ -27,18 +27,19 @@ struct args_target { int err; bool check_fd; int fd; + int nr; + void *args[6]; }; struct seccomp_notif req; int notifyfd; struct args_target *at; int pipefd[2]; -int nr = __NR_getpid; pid_t pid; uint16_t tmp_data[TMP_DATA_SIZE]; -static int install_notification_filter() +static int install_notification_filter(int nr) { int fd; /* filter a single syscall for the tests */ @@ -76,11 +77,12 @@ static int create_test_fd() static int target() { int buf = 0; - if (install_notification_filter() < 0) { + if (install_notification_filter(at->nr) < 0) { return -1; } - at->ret = getpid(); + at->ret = syscall(at->nr, at->args[0], at->args[1], at->args[2], + at->args[3], at->args[4], at->args[5], at->args[5]); at->err = errno; if (at->check_fd) read(pipefd[0], &buf, 1); @@ -167,20 +169,17 @@ static void check_target_fd(int pid, int fd) close(pipefd[1]); } -void setup(bool check_fd) +void setup() { int ret; signal(SIGCHLD, target_exit); ck_assert_int_ne(pipe(pipefd), -1); - at = mmap(NULL, sizeof(struct args_target), PROT_READ | PROT_WRITE, - MAP_SHARED | MAP_ANONYMOUS, -1, 0); - at->check_fd = check_fd; pid = do_clone(target, NULL); ck_assert_int_ge(pid, 0); /* Use write pipe to sync the target for checking the existance of the fd */ - if (!check_fd) + if (!at->check_fd) ck_assert_int_ne(close(pipefd[1]), -1); notifyfd = get_fd_notifier(pid); @@ -188,7 +187,7 @@ void setup(bool check_fd) memset(&req, 0, sizeof(req)); ret = ioctl(notifyfd, SECCOMP_IOCTL_NOTIF_RECV, &req); ck_assert_msg(ret == 0, strerror(errno)); - ck_assert_msg((req.data).nr == nr, "filter syscall nr: %d", + ck_assert_msg((req.data).nr == at->nr, "filter syscall nr: %d", (req.data).nr); } @@ -200,11 +199,19 @@ void teardown() void setup_without_fd() { - setup(false); + at = mmap(NULL, sizeof(struct args_target), PROT_READ | PROT_WRITE, + MAP_SHARED | MAP_ANONYMOUS, -1, 0); + at->check_fd = false; + at->nr = __NR_getpid; + setup(); } void setup_fd() { - setup(true); + at = mmap(NULL, sizeof(struct args_target), PROT_READ | PROT_WRITE, + MAP_SHARED | MAP_ANONYMOUS, -1, 0); + at->check_fd = true; + at->nr = __NR_getpid; + setup(); } START_TEST(test_act_continue) |