|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From 45f1b67a70a749ca14a7df256a177de74a3e73f6 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From: Daniel Mack <daniel@zonque.org>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Date: Fri, 26 Sep 2014 17:50:24 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Subject: [PATCH] test-bus-policy: load policy files from TEST_DIR
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
'make distcheck' calls test-bus-policy outside of the source tree, so it
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
must consider the TEST_DIR variable to access its files.
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/bus-proxyd/test-bus-policy.c | 25 +++++++++++++++++++++----
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
1 file changed, 21 insertions(+), 4 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/bus-proxyd/test-bus-policy.c b/src/bus-proxyd/test-bus-policy.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 37e66274f0..900e4d2b06 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/bus-proxyd/test-bus-policy.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/bus-proxyd/test-bus-policy.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -44,6 +44,23 @@
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#include <bus-proxyd/bus-policy.h>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+static int test_policy_load(Policy *p, const char *name)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+{
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ char *path;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ int r = 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ path = strjoin(TEST_DIR, "/bus-policy/", name, NULL);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (access(path, R_OK) == 0)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ policy_load(p, STRV_MAKE(path));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ else
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ r = -ENOENT;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ free(path);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return r;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Policy p = {};
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -52,7 +69,7 @@ int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Hashmap *names_hash;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
/* Ownership tests */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(policy_load(&p, STRV_MAKE("test/bus-policy/ownerships.conf")) == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert_se(test_policy_load(&p, "ownerships.conf") == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
ucred.uid = 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert_se(policy_check_own(&p, &ucred, "org.test.test1") == true);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -77,7 +94,7 @@ int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
policy_free(&p);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
/* Signaltest */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(policy_load(&p, STRV_MAKE("test/bus-policy/signals.conf")) == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert_se(test_policy_load(&p, "signals.conf") == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
names_strv = STRV_MAKE("bli.bla.blubb");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
ucred.uid = 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -89,7 +106,7 @@ int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
policy_free(&p);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
/* Method calls */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(policy_load(&p, STRV_MAKE("test/bus-policy/methods.conf")) == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert_se(test_policy_load(&p, "methods.conf") == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
names_strv = STRV_MAKE("org.test.test1");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
policy_dump(&p);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -108,7 +125,7 @@ int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
policy_free(&p);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
/* User and groups */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(policy_load(&p, STRV_MAKE("test/bus-policy/hello.conf")) == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert_se(test_policy_load(&p, "hello.conf") == 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
policy_dump(&p);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
ucred.uid = 0;
|