tests/device-introspect: Test with all machines, not only with "none"
Certain device introspection crashes used to only happen if you were using a certain machine, e.g. if the machine was using serial_hd() or nd_table[], and a device was trying to use these in its instance_init function, too. To be able to catch these problems, let's extend the device-introspect test to check the devices on all machine types, with and without the "-nodefaults" parameter (since this makes a difference sometimes, too). Since this is a rather slow operation, and most of the problems are already handled by testing with the "none" machine only, the test with all machines is only run in the "make check SPEED=slow" mode. Reviewed-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Thomas Huth <thuth@redhat.com> Message-Id: <1534419358-10932-8-git-send-email-thuth@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Reviewed-by: John Snow <jsnow@redhat.com> Reviewed-by: Laurent Vivier <lvivier@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
d068521264
commit
410573aa2c
@ -221,13 +221,13 @@ static void test_device_intro_abstract(void)
|
|||||||
qtest_end();
|
qtest_end();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_device_intro_concrete(void)
|
static void test_device_intro_concrete(const void *args)
|
||||||
{
|
{
|
||||||
QList *types;
|
QList *types;
|
||||||
QListEntry *entry;
|
QListEntry *entry;
|
||||||
const char *type;
|
const char *type;
|
||||||
|
|
||||||
qtest_start(common_args);
|
qtest_start(args);
|
||||||
types = device_type_list(false);
|
types = device_type_list(false);
|
||||||
|
|
||||||
QLIST_FOREACH_ENTRY(types, entry) {
|
QLIST_FOREACH_ENTRY(types, entry) {
|
||||||
@ -239,6 +239,7 @@ static void test_device_intro_concrete(void)
|
|||||||
|
|
||||||
qobject_unref(types);
|
qobject_unref(types);
|
||||||
qtest_end();
|
qtest_end();
|
||||||
|
g_free((void *)args);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_abstract_interfaces(void)
|
static void test_abstract_interfaces(void)
|
||||||
@ -275,6 +276,26 @@ static void test_abstract_interfaces(void)
|
|||||||
qtest_end();
|
qtest_end();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void add_machine_test_case(const char *mname)
|
||||||
|
{
|
||||||
|
char *path, *args;
|
||||||
|
|
||||||
|
/* Ignore blacklisted machines */
|
||||||
|
if (g_str_equal("xenfv", mname) || g_str_equal("xenpv", mname)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
path = g_strdup_printf("device/introspect/concrete/defaults/%s", mname);
|
||||||
|
args = g_strdup_printf("-M %s", mname);
|
||||||
|
qtest_add_data_func(path, args, test_device_intro_concrete);
|
||||||
|
g_free(path);
|
||||||
|
|
||||||
|
path = g_strdup_printf("device/introspect/concrete/nodefaults/%s", mname);
|
||||||
|
args = g_strdup_printf("-nodefaults -M %s", mname);
|
||||||
|
qtest_add_data_func(path, args, test_device_intro_concrete);
|
||||||
|
g_free(path);
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
g_test_init(&argc, &argv, NULL);
|
g_test_init(&argc, &argv, NULL);
|
||||||
@ -283,8 +304,13 @@ int main(int argc, char **argv)
|
|||||||
qtest_add_func("device/introspect/list-fields", test_qom_list_fields);
|
qtest_add_func("device/introspect/list-fields", test_qom_list_fields);
|
||||||
qtest_add_func("device/introspect/none", test_device_intro_none);
|
qtest_add_func("device/introspect/none", test_device_intro_none);
|
||||||
qtest_add_func("device/introspect/abstract", test_device_intro_abstract);
|
qtest_add_func("device/introspect/abstract", test_device_intro_abstract);
|
||||||
qtest_add_func("device/introspect/concrete", test_device_intro_concrete);
|
|
||||||
qtest_add_func("device/introspect/abstract-interfaces", test_abstract_interfaces);
|
qtest_add_func("device/introspect/abstract-interfaces", test_abstract_interfaces);
|
||||||
|
if (g_test_quick()) {
|
||||||
|
qtest_add_data_func("device/introspect/concrete/defaults/none",
|
||||||
|
g_strdup(common_args), test_device_intro_concrete);
|
||||||
|
} else {
|
||||||
|
qtest_cb_for_every_machine(add_machine_test_case, true);
|
||||||
|
}
|
||||||
|
|
||||||
return g_test_run();
|
return g_test_run();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user