struct pakfire_jail* jail = NULL;
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Destroy it
ASSERT_NULL(pakfire_jail_unref(jail));
};
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Check if we receive the correct exit code
- ASSERT(pakfire_jail_exec(jail, argv, NULL, NULL, NULL) == 123);
+ ASSERT(pakfire_jail_exec(jail, argv, NULL, NULL, NULL, 0) == 123);
// Success
r = EXIT_SUCCESS;
};
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Check if we receive the correct exit code
- ASSERT(pakfire_jail_exec(jail, argv, NULL, NULL, NULL) == 139);
+ ASSERT(pakfire_jail_exec(jail, argv, NULL, NULL, NULL, 0) == 139);
// Success
r = EXIT_SUCCESS;
struct pakfire_jail* jail = NULL;
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Check if the default variables are set
ASSERT(pakfire_jail_get_env(jail, "LANG"));
struct pakfire_jail* jail = NULL;
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Try to execute something
- ASSERT_SUCCESS(pakfire_jail_exec(jail, cmd_hello_world, NULL, NULL, NULL));
+ ASSERT_SUCCESS(pakfire_jail_exec(jail, cmd_hello_world, NULL, NULL, NULL, 0));
// Destroy it
ASSERT_NULL(pakfire_jail_unref(jail));
ASSERT_SUCCESS(pakfire_cgroup_open(&cgroup, t->pakfire, "pakfire-test", 0));
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Connect jail to the cgroup
ASSERT_SUCCESS(pakfire_jail_set_cgroup(jail, cgroup));
// Run command
- ASSERT(pakfire_jail_exec(jail, cmd_hello_world, NULL, NULL, NULL) == 0);
+ ASSERT(pakfire_jail_exec(jail, cmd_hello_world, NULL, NULL, NULL, 0) == 0);
r = EXIT_SUCCESS;
};
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Set invalid nice levels
ASSERT_ERRNO(pakfire_jail_nice(jail, 100), EINVAL);
// Check if the nice level has been set
ASSERT_SUCCESS(pakfire_jail_exec(jail, argv,
- NULL, pakfire_jail_capture_stdout, &output));
+ NULL, pakfire_jail_capture_stdout, &output, 0));
ASSERT_STRING_EQUALS(output, "5\n");
// Success
ASSERT_SUCCESS(pakfire_cgroup_open(&cgroup, t->pakfire, "pakfire-test", 0));
// Create jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Connect jail to the cgroup
ASSERT_SUCCESS(pakfire_jail_set_cgroup(jail, cgroup));
ASSERT_SUCCESS(pakfire_cgroup_set_memory_limit(cgroup, 100 * 1024 * 1024));
// Try to exhaust all memory
- ASSERT_FAILURE(pakfire_jail_exec(jail, cmd_exhaust_memory, NULL, NULL, NULL));
+ ASSERT_FAILURE(pakfire_jail_exec(jail, cmd_exhaust_memory, NULL, NULL, NULL, 0));
// A fork bomb should also exhaust all memory
- ASSERT_FAILURE(pakfire_jail_exec(jail, cmd_fork_bomb, NULL, NULL, NULL));
+ ASSERT_FAILURE(pakfire_jail_exec(jail, cmd_fork_bomb, NULL, NULL, NULL, 0));
// Success
r = EXIT_SUCCESS;
ASSERT_SUCCESS(pakfire_cgroup_open(&cgroup, t->pakfire, "pakfire-test", 0));
// Create jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Connect jail to the cgroup
ASSERT_SUCCESS(pakfire_jail_set_cgroup(jail, cgroup));
ASSERT_SUCCESS(pakfire_cgroup_set_pid_limit(cgroup, 100));
// Try to fork as many processes as possible
- ASSERT_FAILURE(pakfire_jail_exec(jail, cmd_fork_bomb, NULL, NULL, NULL));
+ ASSERT_FAILURE(pakfire_jail_exec(jail, cmd_fork_bomb, NULL, NULL, NULL, 0));
// Success
r = EXIT_SUCCESS;
};
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Bind-mount nonsense
ASSERT_ERRNO(pakfire_jail_bind(jail, NULL, target, 0), EINVAL);
ASSERT_SUCCESS(pakfire_jail_bind(jail, source, target, MS_RDONLY));
// Check if the mount actually works
- ASSERT_SUCCESS(pakfire_jail_exec(jail, argv, NULL, NULL, NULL));
+ ASSERT_SUCCESS(pakfire_jail_exec(jail, argv, NULL, NULL, NULL, 0));
// Success
r = EXIT_SUCCESS;
};
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Check if the mount actually works
- ASSERT_SUCCESS(pakfire_jail_exec(jail, argv, callback_stdin, NULL, &lines));
+ ASSERT_SUCCESS(pakfire_jail_exec(jail, argv, callback_stdin, NULL, &lines, 0));
// Success
r = EXIT_SUCCESS;
};
// Perform the command
- return pakfire_jail_exec(jail, argv, NULL, NULL, NULL);
+ return pakfire_jail_exec(jail, argv, NULL, NULL, NULL, 0);
}
static int test_send_signal(const struct test* t) {
int r = EXIT_FAILURE;
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Sending SIGTERM to ourselves
ASSERT(test_send_one_signal(t, jail, "15") == 0);
};
// Create a new jail
- ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire, 0));
+ ASSERT_SUCCESS(pakfire_jail_create(&jail, t->pakfire));
// Set a timeout of one second
ASSERT_SUCCESS(pakfire_jail_set_timeout(jail, 1));
// Check if we receive the correct exit code
- ASSERT(pakfire_jail_exec(jail, argv, NULL, NULL, NULL) == 139);
+ ASSERT(pakfire_jail_exec(jail, argv, NULL, NULL, NULL, 0) == 139);
// Success
r = EXIT_SUCCESS;