check_p_g_o_u("", -ENOENT, 0);
}
-static void check_p_g_m_n(const char *path, int code, const char *result) {
- _cleanup_free_ char *m = NULL;
-
- assert_se(cg_path_get_machine_name(path, &m) == code);
- assert_se(streq_ptr(m, result));
-}
-
-static void test_path_get_machine_name(void) {
- check_p_g_m_n("/user.slice/machine-foobar.scope", 0, "foobar");
- check_p_g_m_n("/machine-foobar.scope", 0, "foobar");
- check_p_g_m_n("/user.slice/user-kuux.slice/machine-foobar.scope", 0, "foobar");
- check_p_g_m_n("/user.slice/user-kuux.slice/machine-foobar.scope/asjhdkj", 0, "foobar");
- check_p_g_m_n("", -ENOENT, NULL);
-}
-
static void test_get_paths(void) {
_cleanup_free_ char *a = NULL;
cg_pid_get_machine_name(pid, &machine);
cg_pid_get_slice(pid, &slice);
- printf("%lu\t%s\t%s\t%lu\t%s\t%s\t%s\t%s\t%s\n",
- (unsigned long) pid,
+ printf(PID_FMT"\t%s\t%s\t"UID_FMT"\t%s\t%s\t%s\t%s\t%s\n",
+ pid,
path,
path_shifted,
- (unsigned long) uid,
+ uid,
session,
unit,
user_unit,
test_slice_to_path_one("a-b-c-d-e.slice", "a.slice/a-b.slice/a-b-c.slice/a-b-c-d.slice/a-b-c-d-e.slice", 0);
}
+static void test_shift_path_one(const char *raw, const char *root, const char *shifted) {
+ const char *s = NULL;
+
+ assert_se(cg_shift_path(raw, root, &s) >= 0);
+ assert_se(streq(s, shifted));
+}
+
+static void test_shift_path(void) {
+
+ test_shift_path_one("/foobar/waldo", "/", "/foobar/waldo");
+ test_shift_path_one("/foobar/waldo", "", "/foobar/waldo");
+ test_shift_path_one("/foobar/waldo", "/foobar", "/waldo");
+ test_shift_path_one("/foobar/waldo", "/fuckfuck", "/foobar/waldo");
+}
+
int main(void) {
test_path_decode_unit();
test_path_get_unit();
test_path_get_user_unit();
test_path_get_session();
test_path_get_owner_uid();
- test_path_get_machine_name();
TEST_REQ_RUNNING_SYSTEMD(test_get_paths());
test_proc();
TEST_REQ_RUNNING_SYSTEMD(test_escape());
test_controller_is_valid();
test_slice_to_path();
+ test_shift_path();
return 0;
}