mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-02 23:33:54 -06:00
qapi: Add tests of complex objects within alternate
Upcoming patches will adjust how we visit an object branch of an alternate; but we were completely lacking testsuite coverage. Rectify this, so that the future patches will be able to highlight the changes and still prove that we avoided regressions. In particular, the use of a flat union UserDefFlatUnion rather than a simple struct UserDefA as the branch will give us coverage of an object with variants. And visiting an alternate as both the top level and as a nested member gives confidence in correct memory allocation handling, especially if the test is run under valgrind. Signed-off-by: Eric Blake <eblake@redhat.com> Message-Id: <1455778109-6278-5-git-send-email-eblake@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
46534309e6
commit
68d078395d
4 changed files with 67 additions and 4 deletions
|
@ -1,7 +1,7 @@
|
|||
/*
|
||||
* QMP Input Visitor unit-tests.
|
||||
*
|
||||
* Copyright (C) 2011, 2015 Red Hat Inc.
|
||||
* Copyright (C) 2011-2016 Red Hat Inc.
|
||||
*
|
||||
* Authors:
|
||||
* Luiz Capitulino <lcapitulino@redhat.com>
|
||||
|
@ -309,6 +309,7 @@ static void test_visitor_in_alternate(TestInputVisitorData *data,
|
|||
Visitor *v;
|
||||
Error *err = NULL;
|
||||
UserDefAlternate *tmp;
|
||||
WrapAlternate *wrap;
|
||||
|
||||
v = visitor_input_test_init(data, "42");
|
||||
visit_type_UserDefAlternate(v, NULL, &tmp, &error_abort);
|
||||
|
@ -322,10 +323,44 @@ static void test_visitor_in_alternate(TestInputVisitorData *data,
|
|||
g_assert_cmpstr(tmp->u.s, ==, "string");
|
||||
qapi_free_UserDefAlternate(tmp);
|
||||
|
||||
v = visitor_input_test_init(data, "{'integer':1, 'string':'str', "
|
||||
"'enum1':'value1', 'boolean':true}");
|
||||
visit_type_UserDefAlternate(v, NULL, &tmp, &error_abort);
|
||||
g_assert_cmpint(tmp->type, ==, QTYPE_QDICT);
|
||||
g_assert_cmpint(tmp->u.udfu->integer, ==, 1);
|
||||
g_assert_cmpstr(tmp->u.udfu->string, ==, "str");
|
||||
g_assert_cmpint(tmp->u.udfu->enum1, ==, ENUM_ONE_VALUE1);
|
||||
g_assert_cmpint(tmp->u.udfu->u.value1->boolean, ==, true);
|
||||
g_assert_cmpint(tmp->u.udfu->u.value1->has_a_b, ==, false);
|
||||
qapi_free_UserDefAlternate(tmp);
|
||||
|
||||
v = visitor_input_test_init(data, "false");
|
||||
visit_type_UserDefAlternate(v, NULL, &tmp, &err);
|
||||
error_free_or_abort(&err);
|
||||
qapi_free_UserDefAlternate(tmp);
|
||||
|
||||
v = visitor_input_test_init(data, "{ 'alt': 42 }");
|
||||
visit_type_WrapAlternate(v, NULL, &wrap, &error_abort);
|
||||
g_assert_cmpint(wrap->alt->type, ==, QTYPE_QINT);
|
||||
g_assert_cmpint(wrap->alt->u.i, ==, 42);
|
||||
qapi_free_WrapAlternate(wrap);
|
||||
|
||||
v = visitor_input_test_init(data, "{ 'alt': 'string' }");
|
||||
visit_type_WrapAlternate(v, NULL, &wrap, &error_abort);
|
||||
g_assert_cmpint(wrap->alt->type, ==, QTYPE_QSTRING);
|
||||
g_assert_cmpstr(wrap->alt->u.s, ==, "string");
|
||||
qapi_free_WrapAlternate(wrap);
|
||||
|
||||
v = visitor_input_test_init(data, "{ 'alt': {'integer':1, 'string':'str', "
|
||||
"'enum1':'value1', 'boolean':true} }");
|
||||
visit_type_WrapAlternate(v, NULL, &wrap, &error_abort);
|
||||
g_assert_cmpint(wrap->alt->type, ==, QTYPE_QDICT);
|
||||
g_assert_cmpint(wrap->alt->u.udfu->integer, ==, 1);
|
||||
g_assert_cmpstr(wrap->alt->u.udfu->string, ==, "str");
|
||||
g_assert_cmpint(wrap->alt->u.udfu->enum1, ==, ENUM_ONE_VALUE1);
|
||||
g_assert_cmpint(wrap->alt->u.udfu->u.value1->boolean, ==, true);
|
||||
g_assert_cmpint(wrap->alt->u.udfu->u.value1->has_a_b, ==, false);
|
||||
qapi_free_WrapAlternate(wrap);
|
||||
}
|
||||
|
||||
static void test_visitor_in_alternate_number(TestInputVisitorData *data,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue