From 099524d7b0df690e3361ffc3fe3c6aed0558b4fc Mon Sep 17 00:00:00 2001
From: Lennart Poettering <lennart@poettering.net>
Date: Fri, 21 Feb 2014 02:06:04 +0100
Subject: core: add new ConditionArchitecture() that checks the architecture
 returned by uname()'s machine field.

---
 src/test/test-architecture.c | 52 ++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 52 insertions(+)
 create mode 100644 src/test/test-architecture.c

(limited to 'src/test')

diff --git a/src/test/test-architecture.c b/src/test/test-architecture.c
new file mode 100644
index 0000000000..b586c0da5d
--- /dev/null
+++ b/src/test/test-architecture.c
@@ -0,0 +1,52 @@
+/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
+
+/***
+  This file is part of systemd.
+
+  Copyright 2014 Kay Sievers
+
+  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 <http://www.gnu.org/licenses/>.
+***/
+
+#include "virt.h"
+#include "architecture.h"
+#include "util.h"
+#include "log.h"
+
+int main(int argc, char *argv[]) {
+        Architecture a;
+        Virtualization v;
+        const char *id = NULL;
+
+        v = detect_virtualization(&id);
+        if (v == -EPERM || v == -EACCES)
+                return EXIT_TEST_SKIP;
+
+        assert_se(v >= 0);
+
+        log_info("virtualization=%s id=%s",
+                 v == VIRTUALIZATION_CONTAINER ? "container" : v == VIRTUALIZATION_VM ? "vm" : "n/a",
+                 strna(id));
+
+        a = uname_architecture();
+        assert_se(a >= 0);
+
+        log_info("uname architecture=%s", architecture_to_string(a));
+
+        a = native_architecture();
+        assert_se(a >= 0);
+
+        log_info("native architecture=%s", architecture_to_string(a));
+        return 0;
+}
-- 
cgit v1.2.3-54-g00ecf