mirror of https://github.com/xqemu/xqemu.git
tests: Simplify abstract-interfaces check with a helper
Add a new type_list_find() helper to device-introspect-test.c, to simplify the code at test_abstract_interfaces(). Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Eduardo Habkost <ehabkost@redhat.com> Message-Id: <20170707122215.8819-2-ehabkost@redhat.com> Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
This commit is contained in:
parent
53f9a6f45f
commit
dbb2a604a9
|
@ -45,6 +45,22 @@ static QList *qom_list_types(const char *implements, bool abstract)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Find an entry on a list returned by qom-list-types */
|
||||||
|
static QDict *type_list_find(QList *types, const char *name)
|
||||||
|
{
|
||||||
|
QListEntry *e;
|
||||||
|
|
||||||
|
QLIST_FOREACH_ENTRY(types, e) {
|
||||||
|
QDict *d = qobject_to_qdict(qlist_entry_obj(e));
|
||||||
|
const char *ename = qdict_get_str(d, "name");
|
||||||
|
if (!strcmp(ename, name)) {
|
||||||
|
return d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
static QList *device_type_list(bool abstract)
|
static QList *device_type_list(bool abstract)
|
||||||
{
|
{
|
||||||
return qom_list_types("device", abstract);
|
return qom_list_types("device", abstract);
|
||||||
|
@ -125,7 +141,7 @@ static void test_abstract_interfaces(void)
|
||||||
{
|
{
|
||||||
QList *all_types;
|
QList *all_types;
|
||||||
QList *obj_types;
|
QList *obj_types;
|
||||||
QListEntry *ae;
|
QListEntry *e;
|
||||||
|
|
||||||
qtest_start(common_args);
|
qtest_start(common_args);
|
||||||
/* qom-list-types implements=interface would return any type
|
/* qom-list-types implements=interface would return any type
|
||||||
|
@ -138,24 +154,15 @@ static void test_abstract_interfaces(void)
|
||||||
all_types = qom_list_types(NULL, false);
|
all_types = qom_list_types(NULL, false);
|
||||||
obj_types = qom_list_types("object", false);
|
obj_types = qom_list_types("object", false);
|
||||||
|
|
||||||
QLIST_FOREACH_ENTRY(all_types, ae) {
|
QLIST_FOREACH_ENTRY(all_types, e) {
|
||||||
QDict *at = qobject_to_qdict(qlist_entry_obj(ae));
|
QDict *d = qobject_to_qdict(qlist_entry_obj(e));
|
||||||
const char *aname = qdict_get_str(at, "name");
|
|
||||||
QListEntry *oe;
|
|
||||||
const char *found = NULL;
|
|
||||||
|
|
||||||
QLIST_FOREACH_ENTRY(obj_types, oe) {
|
/*
|
||||||
QDict *ot = qobject_to_qdict(qlist_entry_obj(oe));
|
* An interface (incorrectly) marked as non-abstract would
|
||||||
const char *oname = qdict_get_str(ot, "name");
|
* appear on all_types, but not on obj_types:
|
||||||
if (!strcmp(aname, oname)) {
|
*/
|
||||||
found = oname;
|
g_assert(type_list_find(obj_types, qdict_get_str(d, "name")));
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Using g_assert_cmpstr() will give more useful failure
|
|
||||||
* messages than g_assert(found) */
|
|
||||||
g_assert_cmpstr(aname, ==, found);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDECREF(all_types);
|
QDECREF(all_types);
|
||||||
|
|
Loading…
Reference in New Issue