qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [PATCH 2/9] check-qdict: Add test for qdict_iter()


From: Luiz Capitulino
Subject: [Qemu-devel] [PATCH 2/9] check-qdict: Add test for qdict_iter()
Date: Tue, 13 Oct 2009 13:56:59 -0300

Signed-off-by: Luiz Capitulino <address@hidden>
---
 check-qdict.c |   35 +++++++++++++++++++++++++++++++++++
 1 files changed, 35 insertions(+), 0 deletions(-)

diff --git a/check-qdict.c b/check-qdict.c
index c37d448..c80ff22 100644
--- a/check-qdict.c
+++ b/check-qdict.c
@@ -191,6 +191,40 @@ START_TEST(qobject_to_qdict_test)
 }
 END_TEST
 
+static int iter_called;
+static const int iter_max = 42;
+
+static void iter_func(const char *key, QObject *obj, void *opaque)
+{
+    QInt *qi;
+
+    fail_unless(key != NULL);
+    fail_unless(strstr(key, "key_") != NULL);
+    fail_unless(opaque == NULL),
+
+    qi = qobject_to_qint(obj);
+    fail_unless(qi != NULL);
+    fail_unless((qint_get_int(qi) >= 0) && (qint_get_int(qi) <= iter_max));
+
+    iter_called++;
+}
+
+START_TEST(qdict_iter_test)
+{
+    int i;
+
+    for (i = 0; i < iter_max; i++) {
+        char key[12];
+        sprintf(key, "key_%d", i);
+        qdict_put(tests_dict, key, qint_from_int(i));
+    }
+
+    iter_called = 0;
+    qdict_iter(tests_dict, iter_func, NULL);
+    fail_unless(iter_called == iter_max, "%d\n", iter_called);
+}
+END_TEST
+
 /*
  * Errors test-cases
  */
@@ -333,6 +367,7 @@ static Suite *qdict_suite(void)
     tcase_add_test(qdict_public2_tcase, qdict_haskey_test);
     tcase_add_test(qdict_public2_tcase, qdict_del_test);
     tcase_add_test(qdict_public2_tcase, qobject_to_qdict_test);
+    tcase_add_test(qdict_public2_tcase, qdict_iter_test);
 
     qdict_errors_tcase = tcase_create("Errors");
     suite_add_tcase(s, qdict_errors_tcase);
-- 
1.6.5.rc3.8.g8ba5e





reply via email to

[Prev in Thread] Current Thread [Next in Thread]