2013-07-12 11:13:04 +01:00
|
|
|
/*
|
2014-03-17 10:38:38 +01:00
|
|
|
* Copyright (C) 2013, 2014 Red Hat, Inc.
|
2013-07-12 11:13:04 +01: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/>.
|
|
|
|
*
|
|
|
|
* Author: Daniel P. Berrange <berrange@redhat.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "virdbuspriv.h"
|
|
|
|
#include "virlog.h"
|
|
|
|
#include "testutils.h"
|
|
|
|
|
2014-02-28 12:16:17 +00:00
|
|
|
VIR_LOG_INIT("tests.dbustest");
|
|
|
|
|
2013-07-12 11:13:04 +01:00
|
|
|
#define VERIFY(typname, valorig, valnew, fmt) \
|
|
|
|
do { \
|
|
|
|
VIR_DEBUG("Compare " typname " '" fmt "' to '" \
|
|
|
|
fmt "'", valorig, valnew); \
|
|
|
|
if (valorig != valnew) { \
|
|
|
|
fprintf(stderr, "Failed to round-trip " typname " '" \
|
|
|
|
fmt "' to '" fmt "'\n", valorig, valnew); \
|
|
|
|
goto cleanup; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define VERIFY_STR(typname, valorig, valnew, fmt) \
|
|
|
|
do { \
|
|
|
|
VIR_DEBUG("Compare " typname " '" fmt "' to '" \
|
|
|
|
fmt "'", valorig, valnew); \
|
|
|
|
if (STRNEQ(valorig, valnew)) { \
|
|
|
|
fprintf(stderr, "Failed to round-trip " typname " '" \
|
|
|
|
fmt "' to '" fmt "'\n", valorig, valnew); \
|
|
|
|
goto cleanup; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
static int testMessageSimple(const void *args ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
DBusMessage *msg = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
unsigned char in_byte = 200, out_byte = 0;
|
|
|
|
int in_bool = true, out_bool = false;
|
2013-07-29 17:29:00 +01:00
|
|
|
short in_int16 = 0xfefe, out_int16 = 0;
|
|
|
|
unsigned short in_uint16 = 32000, out_uint16 = 0;
|
2013-07-12 11:13:04 +01:00
|
|
|
int in_int32 = 100000000, out_int32 = 0;
|
|
|
|
unsigned int in_uint32 = 200000000, out_uint32 = 0;
|
2013-08-09 07:42:06 -06:00
|
|
|
long long in_int64 = 1000000000000LL, out_int64 = 0;
|
|
|
|
unsigned long long in_uint64 = 2000000000000LL, out_uint64 = 0;
|
2013-07-12 11:13:04 +01:00
|
|
|
double in_double = 3.14159265359, out_double = 0;;
|
|
|
|
const char *in_string = "Hello World";
|
|
|
|
char *out_string = NULL;
|
|
|
|
const char *in_objectpath = "/org/libvirt/test";
|
|
|
|
char *out_objectpath = NULL;
|
|
|
|
const char *in_signature = "ybnqiuxtdsog";
|
|
|
|
char *out_signature = NULL;
|
|
|
|
|
|
|
|
if (!(msg = dbus_message_new_method_call("org.libvirt.test",
|
|
|
|
"/org/libvirt/test",
|
|
|
|
"org.libvirt.test.astrochicken",
|
|
|
|
"cluck"))) {
|
|
|
|
VIR_DEBUG("Failed to allocate method call");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageEncode(msg,
|
|
|
|
"ybnqiuxtdsog",
|
|
|
|
in_byte, in_bool,
|
|
|
|
in_int16, in_uint16,
|
|
|
|
in_int32, in_uint32,
|
|
|
|
in_int64, in_uint64,
|
|
|
|
in_double, in_string,
|
|
|
|
in_objectpath, in_signature) < 0) {
|
|
|
|
VIR_DEBUG("Failed to encode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageDecode(msg,
|
|
|
|
"ybnqiuxtdsog",
|
|
|
|
&out_byte, &out_bool,
|
|
|
|
&out_int16, &out_uint16,
|
|
|
|
&out_int32, &out_uint32,
|
|
|
|
&out_int64, &out_uint64,
|
|
|
|
&out_double, &out_string,
|
|
|
|
&out_objectpath, &out_signature) < 0) {
|
|
|
|
VIR_DEBUG("Failed to decode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
VERIFY("byte", in_byte, out_byte, "%d");
|
|
|
|
VERIFY("bool", in_bool, out_bool, "%d");
|
|
|
|
VERIFY("int16", in_int16, out_int16, "%d");
|
|
|
|
VERIFY("uint16", in_int16, out_int16, "%d");
|
|
|
|
VERIFY("int32", in_int32, out_int32, "%d");
|
|
|
|
VERIFY("uint32", in_int32, out_int32, "%d");
|
|
|
|
VERIFY("int64", in_int64, out_int64, "%lld");
|
|
|
|
VERIFY("uint64", in_int64, out_int64, "%lld");
|
|
|
|
VERIFY("double", in_double, out_double, "%lf");
|
|
|
|
VERIFY_STR("string", in_string, out_string, "%s");
|
|
|
|
VERIFY_STR("objectpath", in_objectpath, out_objectpath, "%s");
|
|
|
|
VERIFY_STR("signature", in_signature, out_signature, "%s");
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(out_string);
|
|
|
|
VIR_FREE(out_signature);
|
|
|
|
VIR_FREE(out_objectpath);
|
|
|
|
dbus_message_unref(msg);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int testMessageVariant(const void *args ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
DBusMessage *msg = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
const char *in_str1 = "Hello";
|
|
|
|
int in_int32 = 100000000, out_int32 = 0;
|
|
|
|
const char *in_str2 = "World";
|
|
|
|
char *out_str1 = NULL, *out_str2 = NULL;
|
|
|
|
|
|
|
|
if (!(msg = dbus_message_new_method_call("org.libvirt.test",
|
|
|
|
"/org/libvirt/test",
|
|
|
|
"org.libvirt.test.astrochicken",
|
|
|
|
"cluck"))) {
|
|
|
|
VIR_DEBUG("Failed to allocate method call");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageEncode(msg,
|
|
|
|
"svs",
|
|
|
|
in_str1,
|
|
|
|
"i", in_int32,
|
|
|
|
in_str2) < 0) {
|
|
|
|
VIR_DEBUG("Failed to encode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageDecode(msg,
|
|
|
|
"svs",
|
|
|
|
&out_str1,
|
|
|
|
"i", &out_int32,
|
|
|
|
&out_str2) < 0) {
|
|
|
|
VIR_DEBUG("Failed to decode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
VERIFY_STR("str1", in_str1, out_str1, "%s");
|
|
|
|
VERIFY("int32", in_int32, out_int32, "%d");
|
|
|
|
VERIFY_STR("str2", in_str2, out_str2, "%s");
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(out_str1);
|
|
|
|
VIR_FREE(out_str2);
|
|
|
|
dbus_message_unref(msg);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int testMessageArray(const void *args ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
DBusMessage *msg = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
const char *in_str1 = "Hello";
|
2013-08-09 08:55:06 -06:00
|
|
|
int in_int32a = 1000000000, out_int32a = 0;
|
|
|
|
int in_int32b = 2000000000, out_int32b = 0;
|
|
|
|
int in_int32c = -2000000000, out_int32c = 0;
|
2013-07-12 11:13:04 +01:00
|
|
|
const char *in_str2 = "World";
|
|
|
|
char *out_str1 = NULL, *out_str2 = NULL;
|
|
|
|
|
|
|
|
if (!(msg = dbus_message_new_method_call("org.libvirt.test",
|
|
|
|
"/org/libvirt/test",
|
|
|
|
"org.libvirt.test.astrochicken",
|
|
|
|
"cluck"))) {
|
|
|
|
VIR_DEBUG("Failed to allocate method call");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageEncode(msg,
|
|
|
|
"sais",
|
|
|
|
in_str1,
|
virdbustest: Don't pass number of arguments as long long
since sizeof(int) != sizeof(long long) on 32bit archs.
This unbreaks virdbustest which otherwise fails like:
(gdb) bt
#0 __strlen_sse2_bsf () at ../sysdeps/i386/i686/multiarch/strlen-sse2-bsf.S:50
#1 0x405907d2 in ?? () from /lib/i386-linux-gnu/libdbus-1.so.3
#2 0x4057c140 in ?? () from /lib/i386-linux-gnu/libdbus-1.so.3
#3 0x4057e7ec in dbus_message_iter_append_basic () from /lib/i386-linux-gnu/libdbus-1.so.3
#4 0x400742ec in virDBusMessageIterEncode (args=0xbfd4b8f0 "k\321\004\b.", types=0x804d260 "",
rootiter=0xbfd4b844) at util/virdbus.c:560
#5 virDBusMessageEncodeArgs (msg=msg@entry=0x893c278, types=types@entry=0x804d25c "sais",
args=args@entry=0xbfd4b8d8 "r\320\004\b\003") at util/virdbus.c:921
#6 0x40075917 in virDBusMessageEncode (msg=0x893c278, types=0x804d25c "sais") at util/virdbus.c:959
#7 0x0804a4a1 in testMessageArray (args=0x0) at virdbustest.c:195
#8 0x0804c404 in virtTestRun (title=title@entry=0x804cfcb "Test message array ",
nloops=nloops@entry=1, body=body@entry=0x804a3f0 <testMessageArray>, data=data@entry=0x0)
at testutils.c:168
#9 0x08049346 in mymain () at virdbustest.c:384
#10 0x0804cb2e in virtTestMain (argc=argc@entry=1, argv=argv@entry=0xbfd4bb24,
func=func@entry=0x80492c0 <mymain>) at testutils.c:764
#11 0x080491af in main (argc=1, argv=0xbfd4bb24) at virdbustest.c:393
2013-07-24 23:19:43 +02:00
|
|
|
3, in_int32a, in_int32b, in_int32c,
|
2013-07-12 11:13:04 +01:00
|
|
|
in_str2) < 0) {
|
|
|
|
VIR_DEBUG("Failed to encode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageDecode(msg,
|
|
|
|
"sais",
|
|
|
|
&out_str1,
|
|
|
|
3, &out_int32a, &out_int32b, &out_int32c,
|
|
|
|
&out_str2) < 0) {
|
|
|
|
VIR_DEBUG("Failed to decode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
VERIFY_STR("str1", in_str1, out_str1, "%s");
|
|
|
|
VERIFY("int32a", in_int32a, out_int32a, "%d");
|
|
|
|
VERIFY("int32b", in_int32b, out_int32b, "%d");
|
|
|
|
VERIFY("int32c", in_int32c, out_int32c, "%d");
|
|
|
|
VERIFY_STR("str2", in_str2, out_str2, "%s");
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(out_str1);
|
|
|
|
VIR_FREE(out_str2);
|
|
|
|
dbus_message_unref(msg);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int testMessageStruct(const void *args ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
DBusMessage *msg = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
unsigned char in_byte = 200, out_byte = 0;
|
|
|
|
int in_bool = true, out_bool = false;
|
2013-07-29 17:29:00 +01:00
|
|
|
short in_int16 = 12000, out_int16 = 0;
|
|
|
|
unsigned short in_uint16 = 32000, out_uint16 = 0;
|
2013-07-12 11:13:04 +01:00
|
|
|
int in_int32 = 100000000, out_int32 = 0;
|
|
|
|
unsigned int in_uint32 = 200000000, out_uint32 = 0;
|
2013-08-09 08:55:06 -06:00
|
|
|
long long in_int64 = -1000000000000LL, out_int64 = 0;
|
2013-08-09 07:42:06 -06:00
|
|
|
unsigned long long in_uint64 = 2000000000000LL, out_uint64 = 0;
|
2013-07-12 11:13:04 +01:00
|
|
|
double in_double = 3.14159265359, out_double = 0;;
|
|
|
|
const char *in_string = "Hello World";
|
|
|
|
char *out_string = NULL;
|
|
|
|
const char *in_objectpath = "/org/libvirt/test";
|
|
|
|
char *out_objectpath = NULL;
|
|
|
|
const char *in_signature = "ybnqiuxtdsog";
|
|
|
|
char *out_signature = NULL;
|
|
|
|
|
|
|
|
if (!(msg = dbus_message_new_method_call("org.libvirt.test",
|
|
|
|
"/org/libvirt/test",
|
|
|
|
"org.libvirt.test.astrochicken",
|
|
|
|
"cluck"))) {
|
|
|
|
VIR_DEBUG("Failed to allocate method call");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageEncode(msg,
|
|
|
|
"ybn(qiuxtds)og",
|
|
|
|
in_byte, in_bool,
|
|
|
|
in_int16, in_uint16,
|
|
|
|
in_int32, in_uint32,
|
|
|
|
in_int64, in_uint64,
|
|
|
|
in_double, in_string,
|
|
|
|
in_objectpath, in_signature) < 0) {
|
|
|
|
VIR_DEBUG("Failed to encode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageDecode(msg,
|
|
|
|
"ybn(qiuxtds)og",
|
|
|
|
&out_byte, &out_bool,
|
|
|
|
&out_int16, &out_uint16,
|
|
|
|
&out_int32, &out_uint32,
|
|
|
|
&out_int64, &out_uint64,
|
|
|
|
&out_double, &out_string,
|
|
|
|
&out_objectpath, &out_signature) < 0) {
|
|
|
|
VIR_DEBUG("Failed to decode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
VERIFY("byte", in_byte, out_byte, "%d");
|
|
|
|
VERIFY("bool", in_bool, out_bool, "%d");
|
|
|
|
VERIFY("int16", in_int16, out_int16, "%d");
|
|
|
|
VERIFY("uint16", in_int16, out_int16, "%d");
|
|
|
|
VERIFY("int32", in_int32, out_int32, "%d");
|
|
|
|
VERIFY("uint32", in_int32, out_int32, "%d");
|
|
|
|
VERIFY("int64", in_int64, out_int64, "%lld");
|
|
|
|
VERIFY("uint64", in_int64, out_int64, "%lld");
|
|
|
|
VERIFY("double", in_double, out_double, "%lf");
|
|
|
|
VERIFY_STR("string", in_string, out_string, "%s");
|
|
|
|
VERIFY_STR("objectpath", in_objectpath, out_objectpath, "%s");
|
|
|
|
VERIFY_STR("signature", in_signature, out_signature, "%s");
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(out_string);
|
|
|
|
VIR_FREE(out_signature);
|
|
|
|
VIR_FREE(out_objectpath);
|
|
|
|
dbus_message_unref(msg);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int testMessageDict(const void *args ATTRIBUTE_UNUSED)
|
|
|
|
{
|
|
|
|
DBusMessage *msg = NULL;
|
|
|
|
int ret = -1;
|
|
|
|
const char *in_str1 = "Hello";
|
|
|
|
int in_int32a = 100000000, out_int32a = 0;
|
|
|
|
const char *in_key1 = "turnover";
|
|
|
|
int in_int32b = 200000000, out_int32b = 0;
|
|
|
|
const char *in_key2 = "revenue";
|
|
|
|
int in_int32c = 300000000, out_int32c = 0;
|
|
|
|
const char *in_key3 = "debt";
|
|
|
|
const char *in_str2 = "World";
|
|
|
|
char *out_str1 = NULL, *out_str2 = NULL;
|
|
|
|
char *out_key1 = NULL, *out_key2 = NULL, *out_key3 = NULL;
|
|
|
|
|
|
|
|
if (!(msg = dbus_message_new_method_call("org.libvirt.test",
|
|
|
|
"/org/libvirt/test",
|
|
|
|
"org.libvirt.test.astrochicken",
|
|
|
|
"cluck"))) {
|
|
|
|
VIR_DEBUG("Failed to allocate method call");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageEncode(msg,
|
|
|
|
"sa{si}s",
|
|
|
|
in_str1,
|
|
|
|
3,
|
|
|
|
in_key1, in_int32a,
|
|
|
|
in_key2, in_int32b,
|
|
|
|
in_key3, in_int32c,
|
|
|
|
in_str2) < 0) {
|
|
|
|
VIR_DEBUG("Failed to encode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (virDBusMessageDecode(msg,
|
|
|
|
"sa{si}s",
|
|
|
|
&out_str1,
|
|
|
|
3,
|
|
|
|
&out_key1, &out_int32a,
|
|
|
|
&out_key2, &out_int32b,
|
|
|
|
&out_key3, &out_int32c,
|
|
|
|
&out_str2) < 0) {
|
|
|
|
VIR_DEBUG("Failed to decode arguments");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
VERIFY_STR("str1", in_str1, out_str1, "%s");
|
|
|
|
VERIFY("int32a", in_int32a, out_int32a, "%d");
|
|
|
|
VERIFY("int32b", in_int32b, out_int32b, "%d");
|
|
|
|
VERIFY("int32c", in_int32c, out_int32c, "%d");
|
|
|
|
VERIFY_STR("key1", in_key1, out_key1, "%s");
|
|
|
|
VERIFY_STR("key1", in_key2, out_key2, "%s");
|
|
|
|
VERIFY_STR("key1", in_key3, out_key3, "%s");
|
|
|
|
VERIFY_STR("str2", in_str2, out_str2, "%s");
|
|
|
|
|
|
|
|
ret = 0;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(out_str1);
|
|
|
|
VIR_FREE(out_str2);
|
|
|
|
VIR_FREE(out_key1);
|
|
|
|
VIR_FREE(out_key2);
|
|
|
|
VIR_FREE(out_key3);
|
|
|
|
dbus_message_unref(msg);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
mymain(void)
|
|
|
|
{
|
|
|
|
int ret = 0;
|
|
|
|
|
2013-09-20 19:13:35 +01:00
|
|
|
if (virtTestRun("Test message simple ", testMessageSimple, NULL) < 0)
|
2013-07-12 11:13:04 +01:00
|
|
|
ret = -1;
|
2013-09-20 19:13:35 +01:00
|
|
|
if (virtTestRun("Test message variant ", testMessageVariant, NULL) < 0)
|
2013-07-12 11:13:04 +01:00
|
|
|
ret = -1;
|
2013-09-20 19:13:35 +01:00
|
|
|
if (virtTestRun("Test message array ", testMessageArray, NULL) < 0)
|
2013-07-12 11:13:04 +01:00
|
|
|
ret = -1;
|
2013-09-20 19:13:35 +01:00
|
|
|
if (virtTestRun("Test message struct ", testMessageStruct, NULL) < 0)
|
2013-07-12 11:13:04 +01:00
|
|
|
ret = -1;
|
2013-09-20 19:13:35 +01:00
|
|
|
if (virtTestRun("Test message dict ", testMessageDict, NULL) < 0)
|
2013-07-12 11:13:04 +01:00
|
|
|
ret = -1;
|
2014-03-17 10:38:38 +01:00
|
|
|
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
2013-07-12 11:13:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
VIRT_TEST_MAIN(mymain)
|