]> xenbits.xensource.com Git - people/liuw/libxenctrl-split/libvirt.git/commitdiff
qemumonitorjsontest: Test qemuMonitorJSONGetBalloonInfo
authorMichal Privoznik <mprivozn@redhat.com>
Wed, 2 Oct 2013 10:02:53 +0000 (12:02 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Thu, 3 Oct 2013 09:25:53 +0000 (11:25 +0200)
tests/qemumonitorjsontest.c

index 0fb8d65ac8e0093f8d5b6ad5885c8d6919923e30..adc5ee5d141d531a5d16a78ffbcc6e957e88f144 100644 (file)
@@ -1037,6 +1037,42 @@ cleanup:
     return ret;
 }
 
+static int
+testQemuMonitorJSONqemuMonitorJSONGetBalloonInfo(const void *data)
+{
+    virDomainXMLOptionPtr xmlopt = (virDomainXMLOptionPtr)data;
+    qemuMonitorTestPtr test = qemuMonitorTestNewSimple(true, xmlopt);
+    int ret = -1;
+    unsigned long long currmem;
+
+    if (!test)
+        return -1;
+
+    if (qemuMonitorTestAddItem(test, "query-balloon",
+                               "{"
+                               "    \"return\": {"
+                               "        \"actual\": 4294967296"
+                               "    },"
+                               "    \"id\": \"libvirt-9\""
+                               "}") < 0)
+        goto cleanup;
+
+    if (qemuMonitorJSONGetBalloonInfo(qemuMonitorTestGetMonitor(test), &currmem) < 0)
+        goto cleanup;
+
+    if (currmem != (4294967296/1024)) {
+        virReportError(VIR_ERR_INTERNAL_ERROR,
+                       "Unexpected currmem value: %llu", currmem);
+        goto cleanup;
+    }
+
+    ret = 0;
+
+cleanup:
+    qemuMonitorTestFree(test);
+    return ret;
+}
+
 static int
 mymain(void)
 {
@@ -1086,6 +1122,7 @@ mymain(void)
     DO_TEST_SIMPLE("inject-nmi", qemuMonitorJSONInjectNMI);
     DO_TEST_SIMPLE("system_wakeup", qemuMonitorJSONSystemWakeup);
     DO_TEST_SIMPLE("nbd-server-stop", qemuMonitorJSONNBDServerStop);
+    DO_TEST(qemuMonitorJSONGetBalloonInfo);
 
     virObjectUnref(xmlopt);