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:
Eduardo Habkost 2017-07-07 09:22:13 -03:00
parent 53f9a6f45f
commit dbb2a604a9
1 changed files with 24 additions and 17 deletions

View File

@ -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);