From b08f2be60aceb0c260fb232b9e8b950f0c871cb9 Mon Sep 17 00:00:00 2001 From: Ronny Chevalier Date: Sat, 16 Aug 2014 14:19:10 +0200 Subject: [PATCH] tests: add test-condition-util --- .gitignore | 1 + Makefile.am | 11 +++- src/test/test-condition-util.c | 107 +++++++++++++++++++++++++++++++++ 3 files changed, 118 insertions(+), 1 deletion(-) create mode 100644 src/test/test-condition-util.c diff --git a/.gitignore b/.gitignore index 6f905247f..a3d8c4ea9 100644 --- a/.gitignore +++ b/.gitignore @@ -153,6 +153,7 @@ /test-cgroup-util /test-compress /test-compress-benchmark +/test-condition-util /test-conf-files /test-coredump-vacuum /test-daemon diff --git a/Makefile.am b/Makefile.am index b9deaa653..3ef9c2431 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1321,7 +1321,8 @@ tests += \ test-conf-files \ test-capability \ test-async \ - test-ratelimit + test-ratelimit \ + test-condition-util EXTRA_DIST += \ test/a.service \ @@ -1460,6 +1461,14 @@ test_async_SOURCES = \ test_async_LDADD = \ libsystemd-shared.la +test_condition_util_SOURCES = \ + src/test/test-condition-util.c + +test_condition_util_LDADD = \ + libsystemd-shared.la \ + libsystemd-internal.la + + test_fdset_SOURCES = \ src/test/test-fdset.c diff --git a/src/test/test-condition-util.c b/src/test/test-condition-util.c new file mode 100644 index 000000000..4ee5600ff --- /dev/null +++ b/src/test/test-condition-util.c @@ -0,0 +1,107 @@ +/*** + This file is part of systemd + + Copyright 2014 Ronny Chevalier + + systemd is free software; you can redistribute it and/or modify it + under the terms of the GNU Lesser General Public License as published by + the Free Software Foundation; either version 2.1 of the License, or + (at your option) any later version. + + systemd is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public License + along with systemd; If not, see . +***/ + +#include "condition-util.h" +#include "macro.h" +#include "util.h" +#include "log.h" +#include "architecture.h" +#include "systemd/sd-id128.h" + +static void test_condition_test_ac_power(void) { + Condition *condition; + + condition = condition_new(CONDITION_AC_POWER, "true", false, false); + assert_se(condition_test_ac_power(condition) == on_ac_power()); + condition_free(condition); + + condition = condition_new(CONDITION_AC_POWER, "false", false, false); + assert_se(condition_test_ac_power(condition) != on_ac_power()); + condition_free(condition); + + condition = condition_new(CONDITION_AC_POWER, "false", false, true); + assert_se(condition_test_ac_power(condition) == on_ac_power()); + condition_free(condition); +} + +static void test_condition_test_host(void) { + Condition *condition; + sd_id128_t id; + int r; + char sid[SD_ID128_STRING_MAX]; + char *hostname; + + r = sd_id128_get_machine(&id); + assert_se(r >= 0); + assert_se(sd_id128_to_string(id, sid)); + + condition = condition_new(CONDITION_HOST, sid, false, false); + assert_se(condition_test_host(condition)); + condition_free(condition); + + condition = condition_new(CONDITION_HOST, "garbage value jjjjjjjjjjjjjj", false, false); + assert_se(!condition_test_host(condition)); + condition_free(condition); + + condition = condition_new(CONDITION_HOST, sid, false, true); + assert_se(!condition_test_host(condition)); + condition_free(condition); + + hostname = gethostname_malloc(); + assert_se(hostname); + + condition = condition_new(CONDITION_HOST, hostname, false, false); + assert_se(condition_test_host(condition)); + condition_free(condition); +} + +static void test_condition_test_architecture(void) { + Condition *condition; + Architecture a; + const char *sa; + + a = uname_architecture(); + assert_se(a >= 0); + + sa = architecture_to_string(a); + assert_se(sa); + + condition = condition_new(CONDITION_ARCHITECTURE, sa, false, false); + assert_se(condition_test_architecture(condition)); + condition_free(condition); + + condition = condition_new(CONDITION_ARCHITECTURE, "garbage value", false, false); + assert_se(!condition_test_architecture(condition)); + condition_free(condition); + + condition = condition_new(CONDITION_ARCHITECTURE, sa, false, true); + assert_se(!condition_test_architecture(condition)); + condition_free(condition); +} + +int main(int argc, char *argv[]) { + log_parse_environment(); + log_open(); + + test_condition_test_ac_power(); + test_condition_test_host(); + test_condition_test_architecture(); + + return 0; +} -- 2.30.2