From 94ef3b309273c37717fad34acd8c8b58a21861a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc-Andr=C3=A9=20Lureau?= Date: Thu, 6 Sep 2018 18:13:34 +0400 Subject: [PATCH] tests/qom-proplist: check properties are not listed multiple times MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit And factor out a common function used by the follow class properties iterator test. Fix uninitialized "seentype" variable. Signed-off-by: Marc-André Lureau Reviewed-by: Paolo Bonzini --- tests/check-qom-proplist.c | 50 ++++++++++++++++++++------------------ 1 file changed, 27 insertions(+), 23 deletions(-) diff --git a/tests/check-qom-proplist.c b/tests/check-qom-proplist.c index 0f6d9c1ce3..2c07719607 100644 --- a/tests/check-qom-proplist.c +++ b/tests/check-qom-proplist.c @@ -520,6 +520,32 @@ static void test_dummy_getenum(void) } +static void test_dummy_prop_iterator(ObjectPropertyIterator *iter) +{ + bool seenbv = false, seensv = false, seenav = false, seentype = false; + ObjectProperty *prop; + + while ((prop = object_property_iter_next(iter))) { + if (!seenbv && g_str_equal(prop->name, "bv")) { + seenbv = true; + } else if (!seensv && g_str_equal(prop->name, "sv")) { + seensv = true; + } else if (!seenav && g_str_equal(prop->name, "av")) { + seenav = true; + } else if (!seentype && g_str_equal(prop->name, "type")) { + /* This prop comes from the base Object class */ + seentype = true; + } else { + g_printerr("Found prop '%s'\n", prop->name); + g_assert_not_reached(); + } + } + g_assert(seenbv); + g_assert(seenav); + g_assert(seensv); + g_assert(seentype); +} + static void test_dummy_iterator(void) { Object *parent = object_get_objects_root(); @@ -532,32 +558,10 @@ static void test_dummy_iterator(void) "sv", "Hiss hiss hiss", "av", "platypus", NULL)); - - ObjectProperty *prop; ObjectPropertyIterator iter; - bool seenbv = false, seensv = false, seenav = false, seentype; object_property_iter_init(&iter, OBJECT(dobj)); - while ((prop = object_property_iter_next(&iter))) { - if (g_str_equal(prop->name, "bv")) { - seenbv = true; - } else if (g_str_equal(prop->name, "sv")) { - seensv = true; - } else if (g_str_equal(prop->name, "av")) { - seenav = true; - } else if (g_str_equal(prop->name, "type")) { - /* This prop comes from the base Object class */ - seentype = true; - } else { - g_printerr("Found prop '%s'\n", prop->name); - g_assert_not_reached(); - } - } - g_assert(seenbv); - g_assert(seenav); - g_assert(seensv); - g_assert(seentype); - + test_dummy_prop_iterator(&iter); object_unparent(OBJECT(dobj)); }