2013-07-18 09:54:21 +00:00
|
|
|
/*
|
2014-03-17 09:38:38 +00:00
|
|
|
* Copyright (C) 2013, 2014 Red Hat, Inc.
|
2013-07-18 09:54:21 +00:00
|
|
|
*
|
|
|
|
* This library 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.
|
|
|
|
*
|
|
|
|
* This library 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 this library. If not, see
|
|
|
|
* <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include "testutils.h"
|
|
|
|
|
2020-09-09 14:42:42 +00:00
|
|
|
#if defined(__linux__)
|
2013-09-17 17:11:25 +00:00
|
|
|
|
2019-07-12 16:55:13 +00:00
|
|
|
# include <fcntl.h>
|
2020-02-16 21:59:28 +00:00
|
|
|
# include <unistd.h>
|
2013-09-17 17:11:25 +00:00
|
|
|
|
2018-12-13 14:53:50 +00:00
|
|
|
# define LIBVIRT_VIRSYSTEMDPRIV_H_ALLOW
|
2016-06-24 15:41:09 +00:00
|
|
|
# include "virsystemdpriv.h"
|
|
|
|
|
2013-09-17 17:11:25 +00:00
|
|
|
# include "virsystemd.h"
|
2020-09-09 14:42:42 +00:00
|
|
|
# include "virgdbus.h"
|
2013-09-17 17:11:25 +00:00
|
|
|
# include "virlog.h"
|
2014-03-12 12:20:07 +00:00
|
|
|
# include "virmock.h"
|
2019-06-25 12:03:56 +00:00
|
|
|
# include "rpc/virnetsocket.h"
|
2020-03-20 17:14:22 +00:00
|
|
|
# include "domain_driver.h"
|
2013-09-17 17:11:25 +00:00
|
|
|
# define VIR_FROM_THIS VIR_FROM_NONE
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2014-02-28 12:16:17 +00:00
|
|
|
VIR_LOG_INIT("tests.systemdtest");
|
|
|
|
|
2020-09-09 14:42:42 +00:00
|
|
|
VIR_MOCK_WRAP_RET_ARGS(g_dbus_connection_call_sync,
|
|
|
|
GVariant *,
|
|
|
|
GDBusConnection *, connection,
|
|
|
|
const gchar *, bus_name,
|
|
|
|
const gchar *, object_path,
|
|
|
|
const gchar *, interface_name,
|
|
|
|
const gchar *, method_name,
|
|
|
|
GVariant *, parameters,
|
|
|
|
const GVariantType *, reply_type,
|
|
|
|
GDBusCallFlags, flags,
|
|
|
|
gint, timeout_msec,
|
|
|
|
GCancellable *, cancellable,
|
|
|
|
GError **, error)
|
2014-03-12 12:20:07 +00:00
|
|
|
{
|
2020-09-09 14:42:42 +00:00
|
|
|
GVariant *reply = NULL;
|
2020-10-27 13:15:03 +00:00
|
|
|
g_autoptr(GVariant) params = parameters;
|
2014-03-12 12:20:07 +00:00
|
|
|
|
2020-10-27 13:15:03 +00:00
|
|
|
if (params)
|
|
|
|
g_variant_ref_sink(params);
|
2014-03-12 12:20:07 +00:00
|
|
|
|
2020-09-09 14:42:42 +00:00
|
|
|
VIR_MOCK_REAL_INIT(g_dbus_connection_call_sync);
|
|
|
|
|
|
|
|
if (STREQ(bus_name, "org.freedesktop.machine1")) {
|
2014-03-12 12:20:07 +00:00
|
|
|
if (getenv("FAIL_BAD_SERVICE")) {
|
2020-09-09 14:42:42 +00:00
|
|
|
*error = g_dbus_error_new_for_dbus_error(
|
|
|
|
"org.freedesktop.systemd.badthing",
|
|
|
|
"Something went wrong creating the machine");
|
2014-03-12 12:20:07 +00:00
|
|
|
} else {
|
2020-09-09 14:42:42 +00:00
|
|
|
if (STREQ(method_name, "GetMachineByPID")) {
|
|
|
|
reply = g_variant_new("(o)",
|
|
|
|
"/org/freedesktop/machine1/machine/qemu_2ddemo");
|
|
|
|
} else if (STREQ(method_name, "Get")) {
|
2020-10-27 13:15:03 +00:00
|
|
|
const char *prop;
|
|
|
|
g_variant_get(params, "(@s&s)", NULL, &prop);
|
|
|
|
|
|
|
|
if (STREQ(prop, "Name")) {
|
|
|
|
reply = g_variant_new("(v)", g_variant_new_string("qemu-demo"));
|
|
|
|
} else if (STREQ(prop, "Unit")) {
|
|
|
|
reply = g_variant_new("(v)",
|
|
|
|
g_variant_new_string("machine-qemu-demo.scope"));
|
|
|
|
} else {
|
|
|
|
*error = g_dbus_error_new_for_dbus_error(
|
|
|
|
"org.freedesktop.systemd.badthing",
|
|
|
|
"Unknown machine property");
|
|
|
|
}
|
2020-09-09 14:42:42 +00:00
|
|
|
} else {
|
|
|
|
reply = g_variant_new("()");
|
2016-02-02 18:45:55 +00:00
|
|
|
}
|
2014-03-12 12:20:07 +00:00
|
|
|
}
|
2020-09-09 14:42:42 +00:00
|
|
|
} else if (STREQ(bus_name, "org.freedesktop.login1")) {
|
|
|
|
reply = g_variant_new("(s)", getenv("RESULT_SUPPORT"));
|
|
|
|
} else if (STREQ(bus_name, "org.freedesktop.DBus") &&
|
|
|
|
STREQ(method_name, "ListActivatableNames")) {
|
|
|
|
GVariantBuilder builder;
|
|
|
|
|
|
|
|
g_variant_builder_init(&builder, G_VARIANT_TYPE("as"));
|
|
|
|
|
|
|
|
g_variant_builder_add(&builder, "s", "org.foo.bar.wizz");
|
|
|
|
|
|
|
|
if (!getenv("FAIL_NO_SERVICE")) {
|
|
|
|
g_variant_builder_add(&builder, "s", "org.freedesktop.machine1");
|
|
|
|
g_variant_builder_add(&builder, "s", "org.freedesktop.login1");
|
|
|
|
}
|
|
|
|
|
|
|
|
reply = g_variant_new("(@as)", g_variant_builder_end(&builder));
|
|
|
|
} else if (STREQ(bus_name, "org.freedesktop.DBus") &&
|
|
|
|
STREQ(method_name, "ListNames")) {
|
|
|
|
GVariantBuilder builder;
|
|
|
|
|
|
|
|
g_variant_builder_init(&builder, G_VARIANT_TYPE("as"));
|
|
|
|
|
|
|
|
g_variant_builder_add(&builder, "s", "org.foo.bar.wizz");
|
|
|
|
|
|
|
|
if (!getenv("FAIL_NO_SERVICE") && !getenv("FAIL_NOT_REGISTERED")) {
|
|
|
|
g_variant_builder_add(&builder, "s", "org.freedesktop.systemd1");
|
|
|
|
g_variant_builder_add(&builder, "s", "org.freedesktop.login1");
|
|
|
|
}
|
|
|
|
|
|
|
|
reply = g_variant_new("(@as)", g_variant_builder_end(&builder));
|
2014-03-12 12:20:07 +00:00
|
|
|
} else {
|
2020-09-09 14:42:42 +00:00
|
|
|
reply = g_variant_new("()");
|
2014-03-12 12:20:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return reply;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testCreateContainer(const void *opaque G_GNUC_UNUSED)
|
2013-07-18 09:54:21 +00:00
|
|
|
{
|
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN] = {
|
|
|
|
1, 1, 1, 1,
|
|
|
|
2, 2, 2, 2,
|
|
|
|
3, 3, 3, 3,
|
|
|
|
4, 4, 4, 4
|
|
|
|
};
|
|
|
|
if (virSystemdCreateMachine("demo",
|
|
|
|
"lxc",
|
|
|
|
uuid,
|
|
|
|
"/proc/123/root",
|
|
|
|
123,
|
|
|
|
true,
|
2014-11-11 17:38:43 +00:00
|
|
|
0, NULL,
|
2019-05-22 23:12:14 +00:00
|
|
|
"highpriority.slice", 0) < 0) {
|
2013-07-18 09:54:21 +00:00
|
|
|
fprintf(stderr, "%s", "Failed to create LXC machine\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testTerminateContainer(const void *opaque G_GNUC_UNUSED)
|
2013-09-30 14:46:29 +00:00
|
|
|
{
|
2016-02-01 15:50:54 +00:00
|
|
|
if (virSystemdTerminateMachine("lxc-demo") < 0) {
|
2013-09-30 14:46:29 +00:00
|
|
|
fprintf(stderr, "%s", "Failed to terminate LXC machine\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testCreateMachine(const void *opaque G_GNUC_UNUSED)
|
2013-07-18 09:54:21 +00:00
|
|
|
{
|
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN] = {
|
|
|
|
1, 1, 1, 1,
|
|
|
|
2, 2, 2, 2,
|
|
|
|
3, 3, 3, 3,
|
|
|
|
4, 4, 4, 4
|
|
|
|
};
|
|
|
|
if (virSystemdCreateMachine("demo",
|
|
|
|
"qemu",
|
|
|
|
uuid,
|
|
|
|
NULL,
|
|
|
|
123,
|
|
|
|
false,
|
2014-11-11 17:38:43 +00:00
|
|
|
0, NULL,
|
2019-05-22 23:12:14 +00:00
|
|
|
NULL, 0) < 0) {
|
2013-07-18 09:54:21 +00:00
|
|
|
fprintf(stderr, "%s", "Failed to create KVM machine\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testTerminateMachine(const void *opaque G_GNUC_UNUSED)
|
2013-09-30 14:46:29 +00:00
|
|
|
{
|
2016-02-01 15:50:54 +00:00
|
|
|
if (virSystemdTerminateMachine("test-qemu-demo") < 0) {
|
2013-09-30 14:46:29 +00:00
|
|
|
fprintf(stderr, "%s", "Failed to terminate KVM machine\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testCreateNoSystemd(const void *opaque G_GNUC_UNUSED)
|
2013-07-18 09:54:21 +00:00
|
|
|
{
|
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN] = {
|
|
|
|
1, 1, 1, 1,
|
|
|
|
2, 2, 2, 2,
|
|
|
|
3, 3, 3, 3,
|
|
|
|
4, 4, 4, 4
|
|
|
|
};
|
2013-07-22 15:33:37 +00:00
|
|
|
int rv;
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("FAIL_NO_SERVICE", "1", TRUE);
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2013-07-22 15:33:37 +00:00
|
|
|
if ((rv = virSystemdCreateMachine("demo",
|
|
|
|
"qemu",
|
|
|
|
uuid,
|
|
|
|
NULL,
|
|
|
|
123,
|
|
|
|
false,
|
2014-11-11 17:38:43 +00:00
|
|
|
0, NULL,
|
2019-05-22 23:12:14 +00:00
|
|
|
NULL, 0)) == 0) {
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NO_SERVICE");
|
2013-07-18 09:54:21 +00:00
|
|
|
fprintf(stderr, "%s", "Unexpected create machine success\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NO_SERVICE");
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2013-07-22 15:33:37 +00:00
|
|
|
if (rv != -2) {
|
|
|
|
fprintf(stderr, "%s", "Unexpected create machine error\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testCreateSystemdNotRunning(const void *opaque G_GNUC_UNUSED)
|
2014-02-27 20:21:57 +00:00
|
|
|
{
|
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN] = {
|
|
|
|
1, 1, 1, 1,
|
|
|
|
2, 2, 2, 2,
|
|
|
|
3, 3, 3, 3,
|
|
|
|
4, 4, 4, 4
|
|
|
|
};
|
|
|
|
int rv;
|
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("FAIL_NOT_REGISTERED", "1", TRUE);
|
2014-02-27 20:21:57 +00:00
|
|
|
|
|
|
|
if ((rv = virSystemdCreateMachine("demo",
|
|
|
|
"qemu",
|
|
|
|
uuid,
|
|
|
|
NULL,
|
|
|
|
123,
|
|
|
|
false,
|
2014-11-11 17:38:43 +00:00
|
|
|
0, NULL,
|
2019-05-22 23:12:14 +00:00
|
|
|
NULL, 0)) == 0) {
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NOT_REGISTERED");
|
2014-02-27 20:21:57 +00:00
|
|
|
fprintf(stderr, "%s", "Unexpected create machine success\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NOT_REGISTERED");
|
2014-02-27 20:21:57 +00:00
|
|
|
|
|
|
|
if (rv != -2) {
|
|
|
|
fprintf(stderr, "%s", "Unexpected create machine error\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testCreateBadSystemd(const void *opaque G_GNUC_UNUSED)
|
2013-07-22 15:33:37 +00:00
|
|
|
{
|
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN] = {
|
|
|
|
1, 1, 1, 1,
|
|
|
|
2, 2, 2, 2,
|
|
|
|
3, 3, 3, 3,
|
|
|
|
4, 4, 4, 4
|
|
|
|
};
|
|
|
|
int rv;
|
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("FAIL_BAD_SERVICE", "1", TRUE);
|
2013-07-22 15:33:37 +00:00
|
|
|
|
|
|
|
if ((rv = virSystemdCreateMachine("demo",
|
|
|
|
"qemu",
|
|
|
|
uuid,
|
|
|
|
NULL,
|
|
|
|
123,
|
|
|
|
false,
|
2014-11-11 17:38:43 +00:00
|
|
|
0, NULL,
|
2019-05-22 23:12:14 +00:00
|
|
|
NULL, 0)) == 0) {
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_BAD_SERVICE");
|
2013-07-22 15:33:37 +00:00
|
|
|
fprintf(stderr, "%s", "Unexpected create machine success\n");
|
2013-07-18 09:54:21 +00:00
|
|
|
return -1;
|
|
|
|
}
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_BAD_SERVICE");
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2013-07-22 15:33:37 +00:00
|
|
|
if (rv != -1) {
|
|
|
|
fprintf(stderr, "%s", "Unexpected create machine error\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2013-07-22 15:33:37 +00:00
|
|
|
return 0;
|
2013-07-18 09:54:21 +00:00
|
|
|
}
|
|
|
|
|
2013-07-26 14:18:55 +00:00
|
|
|
|
2019-10-14 12:45:03 +00:00
|
|
|
static int testCreateNetwork(const void *opaque G_GNUC_UNUSED)
|
2014-11-11 17:38:43 +00:00
|
|
|
{
|
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN] = {
|
|
|
|
1, 1, 1, 1,
|
|
|
|
2, 2, 2, 2,
|
|
|
|
3, 3, 3, 3,
|
|
|
|
4, 4, 4, 4
|
|
|
|
};
|
|
|
|
int nicindexes[] = {
|
|
|
|
2, 1729, 87539319,
|
|
|
|
};
|
2019-10-15 11:55:26 +00:00
|
|
|
size_t nnicindexes = G_N_ELEMENTS(nicindexes);
|
2014-11-11 17:38:43 +00:00
|
|
|
if (virSystemdCreateMachine("demo",
|
|
|
|
"lxc",
|
|
|
|
uuid,
|
|
|
|
"/proc/123/root",
|
|
|
|
123,
|
|
|
|
true,
|
|
|
|
nnicindexes, nicindexes,
|
2021-03-10 13:37:56 +00:00
|
|
|
"highpriority.slice", 2) < 0) {
|
2014-11-11 17:38:43 +00:00
|
|
|
fprintf(stderr, "%s", "Failed to create LXC machine\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-02-02 18:45:55 +00:00
|
|
|
static int
|
2019-10-14 12:45:03 +00:00
|
|
|
testGetMachineName(const void *opaque G_GNUC_UNUSED)
|
2016-02-02 18:45:55 +00:00
|
|
|
{
|
2021-09-04 20:37:31 +00:00
|
|
|
g_autofree char *tmp = virSystemdGetMachineNameByPID(1234);
|
2016-02-02 18:45:55 +00:00
|
|
|
int ret = -1;
|
|
|
|
|
|
|
|
if (!tmp) {
|
|
|
|
fprintf(stderr, "%s", "Failed to create LXC machine\n");
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (STREQ(tmp, "qemu-demo"))
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-10-27 13:15:03 +00:00
|
|
|
static int
|
|
|
|
testGetMachineUnit(const void *opaque G_GNUC_UNUSED)
|
|
|
|
{
|
|
|
|
g_autofree char *tmp = virSystemdGetMachineUnitByPID(1234);
|
|
|
|
|
|
|
|
if (!tmp) {
|
|
|
|
fprintf(stderr, "%s", "Failed to create get machine unit\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (STREQ(tmp, "machine-qemu-demo.scope"))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-11-24 14:56:12 +00:00
|
|
|
struct testNameData {
|
2013-07-26 14:18:55 +00:00
|
|
|
const char *name;
|
|
|
|
const char *expected;
|
2020-03-11 16:56:12 +00:00
|
|
|
const char *root;
|
2016-02-01 15:50:54 +00:00
|
|
|
int id;
|
|
|
|
bool legacy;
|
2013-07-26 14:18:55 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static int
|
|
|
|
testScopeName(const void *opaque)
|
|
|
|
{
|
2015-11-24 14:56:12 +00:00
|
|
|
const struct testNameData *data = opaque;
|
2021-09-04 20:37:31 +00:00
|
|
|
g_autofree char *actual = NULL;
|
2013-07-26 14:18:55 +00:00
|
|
|
|
2016-02-01 15:50:54 +00:00
|
|
|
if (!(actual = virSystemdMakeScopeName(data->name, "lxc", data->legacy)))
|
2021-09-04 20:41:36 +00:00
|
|
|
return -1;
|
2013-07-26 14:18:55 +00:00
|
|
|
|
|
|
|
if (STRNEQ(actual, data->expected)) {
|
|
|
|
fprintf(stderr, "Expected '%s' but got '%s'\n",
|
|
|
|
data->expected, actual);
|
2021-09-04 20:41:36 +00:00
|
|
|
return -1;
|
2013-07-26 14:18:55 +00:00
|
|
|
}
|
|
|
|
|
2021-09-04 20:41:36 +00:00
|
|
|
return 0;
|
2013-07-26 14:18:55 +00:00
|
|
|
}
|
|
|
|
|
2015-11-24 14:56:12 +00:00
|
|
|
static int
|
|
|
|
testMachineName(const void *opaque)
|
|
|
|
{
|
|
|
|
const struct testNameData *data = opaque;
|
2021-09-04 20:37:31 +00:00
|
|
|
g_autofree char *actual = NULL;
|
2015-11-24 14:56:12 +00:00
|
|
|
|
2020-03-20 17:14:22 +00:00
|
|
|
if (!(actual = virDomainDriverGenerateMachineName("qemu", data->root,
|
|
|
|
data->id, data->name, true)))
|
2021-09-04 20:41:36 +00:00
|
|
|
return -1;
|
2015-11-24 14:56:12 +00:00
|
|
|
|
|
|
|
if (STRNEQ(actual, data->expected)) {
|
|
|
|
fprintf(stderr, "Expected '%s' but got '%s'\n",
|
|
|
|
data->expected, actual);
|
2021-09-04 20:41:36 +00:00
|
|
|
return -1;
|
2015-11-24 14:56:12 +00:00
|
|
|
}
|
|
|
|
|
2021-09-04 20:41:36 +00:00
|
|
|
return 0;
|
2015-11-24 14:56:12 +00:00
|
|
|
}
|
|
|
|
|
2014-04-11 07:20:48 +00:00
|
|
|
typedef int (*virSystemdCanHelper)(bool * result);
|
|
|
|
struct testPMSupportData {
|
|
|
|
virSystemdCanHelper tested;
|
|
|
|
};
|
|
|
|
|
|
|
|
static int testPMSupportHelper(const void *opaque)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
bool result;
|
|
|
|
size_t i;
|
|
|
|
const char *results[4] = {"yes", "no", "na", "challenge"};
|
|
|
|
int expected[4] = {1, 0, 0, 1};
|
|
|
|
const struct testPMSupportData *data = opaque;
|
|
|
|
|
|
|
|
for (i = 0; i < 4; i++) {
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("RESULT_SUPPORT", results[i], TRUE);
|
2014-04-11 07:20:48 +00:00
|
|
|
if ((rv = data->tested(&result)) < 0) {
|
|
|
|
fprintf(stderr, "%s", "Unexpected canSuspend error\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (result != expected[i]) {
|
|
|
|
fprintf(stderr, "Unexpected result for answer '%s'\n", results[i]);
|
|
|
|
goto error;
|
|
|
|
}
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("RESULT_SUPPORT");
|
2014-04-11 07:20:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
error:
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("RESULT_SUPPORT");
|
2014-04-11 07:20:48 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int testPMSupportHelperNoSystemd(const void *opaque)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
bool result;
|
|
|
|
const struct testPMSupportData *data = opaque;
|
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("FAIL_NO_SERVICE", "1", TRUE);
|
2014-04-11 07:20:48 +00:00
|
|
|
|
|
|
|
if ((rv = data->tested(&result)) == 0) {
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NO_SERVICE");
|
2014-04-11 07:20:48 +00:00
|
|
|
fprintf(stderr, "%s", "Unexpected canSuspend success\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NO_SERVICE");
|
2014-04-11 07:20:48 +00:00
|
|
|
|
|
|
|
if (rv != -2) {
|
|
|
|
fprintf(stderr, "%s", "Unexpected canSuspend error\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int testPMSupportSystemdNotRunning(const void *opaque)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
bool result;
|
|
|
|
const struct testPMSupportData *data = opaque;
|
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("FAIL_NOT_REGISTERED", "1", TRUE);
|
2014-04-11 07:20:48 +00:00
|
|
|
|
|
|
|
if ((rv = data->tested(&result)) == 0) {
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NOT_REGISTERED");
|
2014-04-11 07:20:48 +00:00
|
|
|
fprintf(stderr, "%s", "Unexpected canSuspend success\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("FAIL_NOT_REGISTERED");
|
2014-04-11 07:20:48 +00:00
|
|
|
|
|
|
|
if (rv != -2) {
|
|
|
|
fprintf(stderr, "%s", "Unexpected canSuspend error\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-06-25 12:03:56 +00:00
|
|
|
|
|
|
|
static int
|
2021-03-11 07:16:13 +00:00
|
|
|
testActivationCreateFDs(virNetSocket **sockUNIX,
|
|
|
|
virNetSocket ***sockIP,
|
2019-06-25 12:03:56 +00:00
|
|
|
size_t *nsockIP)
|
|
|
|
{
|
|
|
|
*sockUNIX = NULL;
|
|
|
|
*sockIP = NULL;
|
|
|
|
*nsockIP = 0;
|
|
|
|
|
|
|
|
if (virNetSocketNewListenUNIX("virsystemdtest.sock",
|
|
|
|
0777,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
sockUNIX) < 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (virNetSocketNewListenTCP("localhost",
|
|
|
|
NULL,
|
|
|
|
AF_UNSPEC,
|
|
|
|
sockIP,
|
|
|
|
nsockIP) < 0) {
|
|
|
|
virObjectUnref(*sockUNIX);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
2022-02-16 14:57:05 +00:00
|
|
|
testActivationFDNames(const void *opaque G_GNUC_UNUSED)
|
2019-06-25 12:03:56 +00:00
|
|
|
{
|
2021-03-11 07:16:13 +00:00
|
|
|
virNetSocket *sockUNIX;
|
|
|
|
virNetSocket **sockIP;
|
2019-06-25 12:03:56 +00:00
|
|
|
size_t nsockIP;
|
|
|
|
int ret = -1;
|
|
|
|
size_t i;
|
2020-01-14 13:30:07 +00:00
|
|
|
char nfdstr[VIR_INT64_STR_BUFLEN];
|
|
|
|
char pidstr[VIR_INT64_STR_BUFLEN];
|
2019-06-25 12:03:56 +00:00
|
|
|
int *fds = NULL;
|
|
|
|
size_t nfds = 0;
|
2019-10-15 12:47:50 +00:00
|
|
|
g_autoptr(virSystemdActivation) act = NULL;
|
2019-10-15 12:47:50 +00:00
|
|
|
g_auto(virBuffer) names = VIR_BUFFER_INITIALIZER;
|
2019-07-15 15:58:02 +00:00
|
|
|
|
|
|
|
virBufferAddLit(&names, "demo-unix.socket");
|
2019-06-25 12:03:56 +00:00
|
|
|
|
|
|
|
if (testActivationCreateFDs(&sockUNIX, &sockIP, &nsockIP) < 0)
|
|
|
|
return -1;
|
|
|
|
|
2019-07-15 15:58:02 +00:00
|
|
|
for (i = 0; i < nsockIP; i++)
|
|
|
|
virBufferAddLit(&names, ":demo-ip.socket");
|
2019-06-25 12:03:56 +00:00
|
|
|
|
2019-11-13 13:53:42 +00:00
|
|
|
g_snprintf(nfdstr, sizeof(nfdstr), "%zu", 1 + nsockIP);
|
|
|
|
g_snprintf(pidstr, sizeof(pidstr), "%lld", (long long)getpid());
|
2019-06-25 12:03:56 +00:00
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_setenv("LISTEN_FDS", nfdstr, TRUE);
|
|
|
|
g_setenv("LISTEN_PID", pidstr, TRUE);
|
2022-02-16 14:57:05 +00:00
|
|
|
g_setenv("LISTEN_FDNAMES", virBufferCurrentContent(&names), TRUE);
|
2019-06-25 12:03:56 +00:00
|
|
|
|
2022-02-16 14:57:05 +00:00
|
|
|
if (virSystemdGetActivation(&act) < 0)
|
2019-06-25 12:03:56 +00:00
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
if (act == NULL) {
|
|
|
|
fprintf(stderr, "Activation object was not created: %s", virGetLastErrorMessage());
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virSystemdActivationComplete(act) == 0) {
|
|
|
|
fprintf(stderr, "Activation did not report unclaimed FDs");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
virSystemdActivationClaimFDs(act, "demo-unix.socket", &fds, &nfds);
|
|
|
|
|
|
|
|
if (nfds != 1) {
|
|
|
|
fprintf(stderr, "Expected 1 UNIX fd, but got %zu\n", nfds);
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
VIR_FREE(fds);
|
|
|
|
|
|
|
|
virSystemdActivationClaimFDs(act, "demo-ip.socket", &fds, &nfds);
|
|
|
|
|
|
|
|
if (nfds != nsockIP) {
|
|
|
|
fprintf(stderr, "Expected %zu IP fd, but got %zu\n", nsockIP, nfds);
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
VIR_FREE(fds);
|
|
|
|
|
|
|
|
virSystemdActivationClaimFDs(act, "demo-ip-alt.socket", &fds, &nfds);
|
|
|
|
|
|
|
|
if (nfds != 0) {
|
|
|
|
fprintf(stderr, "Expected 0 IP fd, but got %zu\n", nfds);
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virSystemdActivationComplete(act) < 0) {
|
|
|
|
fprintf(stderr, "Action was not complete: %s\n", virGetLastErrorMessage());
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
cleanup:
|
|
|
|
virObjectUnref(sockUNIX);
|
|
|
|
for (i = 0; i < nsockIP; i++)
|
|
|
|
virObjectUnref(sockIP[i]);
|
|
|
|
VIR_FREE(sockIP);
|
|
|
|
VIR_FREE(fds);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
2019-10-14 12:45:03 +00:00
|
|
|
testActivationEmpty(const void *opaque G_GNUC_UNUSED)
|
2019-06-25 12:03:56 +00:00
|
|
|
{
|
2021-03-11 07:16:13 +00:00
|
|
|
virSystemdActivation *act;
|
2019-06-25 12:03:56 +00:00
|
|
|
|
2019-12-18 17:16:19 +00:00
|
|
|
g_unsetenv("LISTEN_FDS");
|
2019-06-25 12:03:56 +00:00
|
|
|
|
2022-02-16 14:57:05 +00:00
|
|
|
if (virSystemdGetActivation(&act) < 0)
|
2019-06-25 12:03:56 +00:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (act != NULL) {
|
|
|
|
fprintf(stderr, "Unexpectedly got activation object");
|
2019-10-01 09:50:34 +00:00
|
|
|
virSystemdActivationFree(act);
|
2019-06-25 12:03:56 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-07-18 09:54:21 +00:00
|
|
|
static int
|
|
|
|
mymain(void)
|
|
|
|
{
|
|
|
|
int ret = 0;
|
|
|
|
|
2016-02-01 15:50:54 +00:00
|
|
|
unsigned char uuid[VIR_UUID_BUFLEN];
|
|
|
|
|
|
|
|
/* The one we use in tests quite often */
|
|
|
|
if (virUUIDParse("c7a5fdbd-edaf-9455-926a-d65c16db1809", uuid) < 0)
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
|
2017-11-03 12:09:47 +00:00
|
|
|
# define DO_TEST(_name, func) \
|
|
|
|
do { \
|
|
|
|
if (virTestRun(_name, func, NULL) < 0) \
|
|
|
|
ret = -1; \
|
|
|
|
if (virTestRun(_name "again ", func, NULL) < 0) \
|
|
|
|
ret = -1; \
|
|
|
|
virSystemdHasMachinedResetCachedValue(); \
|
2017-02-23 11:25:33 +00:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
DO_TEST("Test create container ", testCreateContainer);
|
|
|
|
DO_TEST("Test terminate container ", testTerminateContainer);
|
|
|
|
DO_TEST("Test create machine ", testCreateMachine);
|
|
|
|
DO_TEST("Test terminate machine ", testTerminateMachine);
|
|
|
|
DO_TEST("Test create no systemd ", testCreateNoSystemd);
|
|
|
|
DO_TEST("Test create systemd not running ", testCreateSystemdNotRunning);
|
|
|
|
DO_TEST("Test create bad systemd ", testCreateBadSystemd);
|
|
|
|
DO_TEST("Test create with network ", testCreateNetwork);
|
|
|
|
DO_TEST("Test getting machine name ", testGetMachineName);
|
2020-10-27 13:15:03 +00:00
|
|
|
DO_TEST("Test getting machine unit ", testGetMachineUnit);
|
2013-07-18 09:54:21 +00:00
|
|
|
|
2017-11-03 12:09:47 +00:00
|
|
|
# define TEST_SCOPE(_name, unitname, _legacy) \
|
|
|
|
do { \
|
|
|
|
struct testNameData data = { \
|
|
|
|
.name = _name, .expected = unitname, .legacy = _legacy, \
|
|
|
|
}; \
|
|
|
|
if (virTestRun("Test scopename", testScopeName, &data) < 0) \
|
|
|
|
ret = -1; \
|
2013-07-26 14:18:55 +00:00
|
|
|
} while (0)
|
|
|
|
|
2017-11-03 12:09:47 +00:00
|
|
|
# define TEST_SCOPE_OLD(name, unitname) \
|
2016-02-01 15:50:54 +00:00
|
|
|
TEST_SCOPE(name, unitname, true)
|
2017-11-03 12:09:47 +00:00
|
|
|
# define TEST_SCOPE_NEW(name, unitname) \
|
2016-02-01 15:50:54 +00:00
|
|
|
TEST_SCOPE(name, unitname, false)
|
|
|
|
|
|
|
|
TEST_SCOPE_OLD("demo", "machine-lxc\\x2ddemo.scope");
|
|
|
|
TEST_SCOPE_OLD("demo-name", "machine-lxc\\x2ddemo\\x2dname.scope");
|
|
|
|
TEST_SCOPE_OLD("demo!name", "machine-lxc\\x2ddemo\\x21name.scope");
|
|
|
|
TEST_SCOPE_OLD(".demo", "machine-lxc\\x2d\\x2edemo.scope");
|
|
|
|
TEST_SCOPE_OLD("bull💩", "machine-lxc\\x2dbull\\xf0\\x9f\\x92\\xa9.scope");
|
|
|
|
|
|
|
|
TEST_SCOPE_NEW("qemu-3-demo", "machine-qemu\\x2d3\\x2ddemo.scope");
|
2015-11-24 14:56:12 +00:00
|
|
|
|
2020-03-11 16:56:12 +00:00
|
|
|
# define TEST_MACHINE(_name, _root, _id, machinename) \
|
2017-11-03 12:09:47 +00:00
|
|
|
do { \
|
|
|
|
struct testNameData data = { \
|
2020-03-11 16:56:12 +00:00
|
|
|
.name = _name, .expected = machinename, .root = _root, .id = _id, \
|
2017-11-03 12:09:47 +00:00
|
|
|
}; \
|
|
|
|
if (virTestRun("Test scopename", testMachineName, &data) < 0) \
|
|
|
|
ret = -1; \
|
2015-11-24 14:56:12 +00:00
|
|
|
} while (0)
|
|
|
|
|
2020-03-11 16:56:12 +00:00
|
|
|
TEST_MACHINE("demo", NULL, 1, "qemu-1-demo");
|
|
|
|
TEST_MACHINE("demo-name", NULL, 2, "qemu-2-demo-name");
|
|
|
|
TEST_MACHINE("demo!name", NULL, 3, "qemu-3-demoname");
|
|
|
|
TEST_MACHINE(".demo", NULL, 4, "qemu-4-demo");
|
|
|
|
TEST_MACHINE("bull\U0001f4a9", NULL, 5, "qemu-5-bull");
|
|
|
|
TEST_MACHINE("demo..name", NULL, 6, "qemu-6-demo.name");
|
|
|
|
TEST_MACHINE("12345678901234567890123456789012345678901234567890123456789", NULL, 7,
|
2016-02-01 15:50:54 +00:00
|
|
|
"qemu-7-123456789012345678901234567890123456789012345678901234567");
|
2020-03-11 16:56:12 +00:00
|
|
|
TEST_MACHINE("123456789012345678901234567890123456789012345678901234567890", NULL, 8,
|
2016-02-01 15:50:54 +00:00
|
|
|
"qemu-8-123456789012345678901234567890123456789012345678901234567");
|
2020-03-11 16:56:12 +00:00
|
|
|
TEST_MACHINE("kstest-network-device-default-httpks_(c9eed63e-981e-48ec-acdc-56b3f8c5f678)",
|
|
|
|
NULL, 100,
|
2020-01-14 05:20:52 +00:00
|
|
|
"qemu-100-kstest-network-device-default-httpksc9eed63e-981e-48ec");
|
2020-03-11 16:56:12 +00:00
|
|
|
TEST_MACHINE("kstest-network-device-default-httpks_(c9eed63e-981e-48ec--cdc-56b3f8c5f678)",
|
|
|
|
NULL, 10,
|
2020-02-28 16:12:41 +00:00
|
|
|
"qemu-10-kstest-network-device-default-httpksc9eed63e-981e-48ec-c");
|
2020-03-11 16:56:12 +00:00
|
|
|
TEST_MACHINE("demo.-.test.", NULL, 11, "qemu-11-demo.test");
|
|
|
|
TEST_MACHINE("demo", "/tmp/root1", 1, "qemu-embed-0991f456-1-demo");
|
|
|
|
TEST_MACHINE("demo", "/tmp/root2", 1, "qemu-embed-95d47ff5-1-demo");
|
2021-06-25 13:51:52 +00:00
|
|
|
TEST_MACHINE("|.-m", NULL, 1, "qemu-1-m");
|
|
|
|
TEST_MACHINE("Auto-esx7.0-rhel7.9-special-characters~!@#$%^&*_=+,?><:;|.\"[]()`\\-m",
|
|
|
|
NULL, 1, "qemu-1-Auto-esx7.0-rhel7.9-special-characters.m");
|
2013-07-26 14:18:55 +00:00
|
|
|
|
2017-11-03 12:09:47 +00:00
|
|
|
# define TESTS_PM_SUPPORT_HELPER(name, function) \
|
|
|
|
do { \
|
|
|
|
struct testPMSupportData data = { \
|
|
|
|
function \
|
|
|
|
}; \
|
|
|
|
if (virTestRun("Test " name " ", testPMSupportHelper, &data) < 0) \
|
|
|
|
ret = -1; \
|
2019-08-13 14:34:30 +00:00
|
|
|
virSystemdHasLogindResetCachedValue(); \
|
2017-11-03 12:09:47 +00:00
|
|
|
if (virTestRun("Test " name " no systemd ", \
|
|
|
|
testPMSupportHelperNoSystemd, &data) < 0) \
|
|
|
|
ret = -1; \
|
2019-08-13 14:34:30 +00:00
|
|
|
virSystemdHasLogindResetCachedValue(); \
|
2017-11-03 12:09:47 +00:00
|
|
|
if (virTestRun("Test systemd " name " not running ", \
|
|
|
|
testPMSupportSystemdNotRunning, &data) < 0) \
|
|
|
|
ret = -1; \
|
2019-08-13 14:34:30 +00:00
|
|
|
virSystemdHasLogindResetCachedValue(); \
|
2014-04-11 07:20:48 +00:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
TESTS_PM_SUPPORT_HELPER("canSuspend", &virSystemdCanSuspend);
|
|
|
|
TESTS_PM_SUPPORT_HELPER("canHibernate", &virSystemdCanHibernate);
|
|
|
|
TESTS_PM_SUPPORT_HELPER("canHybridSleep", &virSystemdCanHybridSleep);
|
|
|
|
|
2019-06-25 12:03:56 +00:00
|
|
|
if (virTestRun("Test activation empty", testActivationEmpty, NULL) < 0)
|
|
|
|
ret = -1;
|
2019-07-12 16:55:13 +00:00
|
|
|
|
|
|
|
if (fcntl(STDERR_FILENO + 1, F_GETFL) == -1 && errno == EBADF &&
|
|
|
|
fcntl(STDERR_FILENO + 2, F_GETFL) == -1 && errno == EBADF &&
|
|
|
|
fcntl(STDERR_FILENO + 3, F_GETFL) == -1 && errno == EBADF) {
|
|
|
|
if (virTestRun("Test activation names", testActivationFDNames, NULL) < 0)
|
|
|
|
ret = -1;
|
|
|
|
} else {
|
|
|
|
VIR_INFO("Skipping activation tests as FD 3/4/5 is open");
|
|
|
|
}
|
2019-06-25 12:03:56 +00:00
|
|
|
|
2014-03-17 09:38:38 +00:00
|
|
|
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
2013-07-18 09:54:21 +00:00
|
|
|
}
|
|
|
|
|
2020-09-09 14:42:42 +00:00
|
|
|
VIR_TEST_MAIN_PRELOAD(mymain, VIR_TEST_MOCK("virgdbus"))
|
2013-09-17 17:11:25 +00:00
|
|
|
|
2020-09-09 14:42:42 +00:00
|
|
|
#else /* ! __linux__ */
|
2013-09-17 17:11:25 +00:00
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
return EXIT_AM_SKIP;
|
|
|
|
}
|
2020-09-09 14:42:42 +00:00
|
|
|
#endif /* ! __linux__ */
|