|
|
c480ed |
From 356b50b2014aafc7c1555e11cf93650dad39f03a Mon Sep 17 00:00:00 2001
|
|
|
c480ed |
Message-Id: <356b50b2014aafc7c1555e11cf93650dad39f03a@dist-git>
|
|
|
c480ed |
From: John Ferlan <jferlan@redhat.com>
|
|
|
c480ed |
Date: Mon, 1 Jul 2019 17:08:08 +0200
|
|
|
c480ed |
Subject: [PATCH] tests: Augment vcgrouptest to add virCgroupGetMemoryStat
|
|
|
c480ed |
MIME-Version: 1.0
|
|
|
c480ed |
Content-Type: text/plain; charset=UTF-8
|
|
|
c480ed |
Content-Transfer-Encoding: 8bit
|
|
|
c480ed |
|
|
|
c480ed |
Add a test to fetch the GetMemoryStat output. This only gets
|
|
|
c480ed |
data for v1 only right now since the v2 data from commit 61ff6021
|
|
|
c480ed |
is rather useless returning all 0's. The v1 data was originally
|
|
|
c480ed |
added in commit d1452470.
|
|
|
c480ed |
|
|
|
c480ed |
Signed-off-by: John Ferlan <jferlan@redhat.com>
|
|
|
c480ed |
Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
|
|
|
c480ed |
(cherry picked from commit 99b8ef7a98d6ad4a01549204195f5e17ee1984ee)
|
|
|
c480ed |
|
|
|
c480ed |
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1689297
|
|
|
c480ed |
|
|
|
c480ed |
Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
|
|
|
c480ed |
Message-Id: <3c217939ce31a379e149865bc0f3342fc334ba42.1561993100.git.phrdina@redhat.com>
|
|
|
c480ed |
Reviewed-by: Ján Tomko <jtomko@redhat.com>
|
|
|
c480ed |
---
|
|
|
c480ed |
tests/vircgrouptest.c | 64 +++++++++++++++++++++++++++++++++++++++++++
|
|
|
c480ed |
1 file changed, 64 insertions(+)
|
|
|
c480ed |
|
|
|
c480ed |
diff --git a/tests/vircgrouptest.c b/tests/vircgrouptest.c
|
|
|
c480ed |
index 118b1bc246..e9cf792bdd 100644
|
|
|
c480ed |
--- a/tests/vircgrouptest.c
|
|
|
c480ed |
+++ b/tests/vircgrouptest.c
|
|
|
c480ed |
@@ -803,6 +803,67 @@ static int testCgroupGetMemoryUsage(const void *args ATTRIBUTE_UNUSED)
|
|
|
c480ed |
return ret;
|
|
|
c480ed |
}
|
|
|
c480ed |
|
|
|
c480ed |
+
|
|
|
c480ed |
+static int
|
|
|
c480ed |
+testCgroupGetMemoryStat(const void *args ATTRIBUTE_UNUSED)
|
|
|
c480ed |
+{
|
|
|
c480ed |
+ virCgroupPtr cgroup = NULL;
|
|
|
c480ed |
+ int rv;
|
|
|
c480ed |
+ int ret = -1;
|
|
|
c480ed |
+ size_t i;
|
|
|
c480ed |
+
|
|
|
c480ed |
+ const unsigned long long expected_values[] = {
|
|
|
c480ed |
+ 1336619008ULL,
|
|
|
c480ed |
+ 67100672ULL,
|
|
|
c480ed |
+ 145887232ULL,
|
|
|
c480ed |
+ 661872640ULL,
|
|
|
c480ed |
+ 627400704UL,
|
|
|
c480ed |
+ 3690496ULL
|
|
|
c480ed |
+ };
|
|
|
c480ed |
+ const char* names[] = {
|
|
|
c480ed |
+ "cache",
|
|
|
c480ed |
+ "active_anon",
|
|
|
c480ed |
+ "inactive_anon",
|
|
|
c480ed |
+ "active_file",
|
|
|
c480ed |
+ "inactive_file",
|
|
|
c480ed |
+ "unevictable"
|
|
|
c480ed |
+ };
|
|
|
c480ed |
+ unsigned long long values[ARRAY_CARDINALITY(expected_values)];
|
|
|
c480ed |
+
|
|
|
c480ed |
+ if ((rv = virCgroupNewPartition("/virtualmachines", true,
|
|
|
c480ed |
+ (1 << VIR_CGROUP_CONTROLLER_MEMORY),
|
|
|
c480ed |
+ &cgroup)) < 0) {
|
|
|
c480ed |
+ fprintf(stderr, "Could not create /virtualmachines cgroup: %d\n", -rv);
|
|
|
c480ed |
+ goto cleanup;
|
|
|
c480ed |
+ }
|
|
|
c480ed |
+
|
|
|
c480ed |
+ if ((rv = virCgroupGetMemoryStat(cgroup, &values[0],
|
|
|
c480ed |
+ &values[1], &values[2],
|
|
|
c480ed |
+ &values[3], &values[4],
|
|
|
c480ed |
+ &values[5])) < 0) {
|
|
|
c480ed |
+ fprintf(stderr, "Could not retrieve GetMemoryStat for /virtualmachines cgroup: %d\n", -rv);
|
|
|
c480ed |
+ goto cleanup;
|
|
|
c480ed |
+ }
|
|
|
c480ed |
+
|
|
|
c480ed |
+ for (i = 0; i < ARRAY_CARDINALITY(expected_values); i++) {
|
|
|
c480ed |
+ /* NB: virCgroupGetMemoryStat returns a KiB scaled value */
|
|
|
c480ed |
+ if ((expected_values[i] >> 10) != values[i]) {
|
|
|
c480ed |
+ fprintf(stderr,
|
|
|
c480ed |
+ "Wrong value (%llu) for %s from virCgroupGetMemoryStat "
|
|
|
c480ed |
+ "(expected %llu)\n",
|
|
|
c480ed |
+ values[i], names[i], (expected_values[i] >> 10));
|
|
|
c480ed |
+ goto cleanup;
|
|
|
c480ed |
+ }
|
|
|
c480ed |
+ }
|
|
|
c480ed |
+
|
|
|
c480ed |
+ ret = 0;
|
|
|
c480ed |
+
|
|
|
c480ed |
+ cleanup:
|
|
|
c480ed |
+ virCgroupFree(&cgroup);
|
|
|
c480ed |
+ return ret;
|
|
|
c480ed |
+}
|
|
|
c480ed |
+
|
|
|
c480ed |
+
|
|
|
c480ed |
static int testCgroupGetBlkioIoServiced(const void *args ATTRIBUTE_UNUSED)
|
|
|
c480ed |
{
|
|
|
c480ed |
virCgroupPtr cgroup = NULL;
|
|
|
c480ed |
@@ -1036,6 +1097,9 @@ mymain(void)
|
|
|
c480ed |
if (virTestRun("virCgroupGetMemoryUsage works", testCgroupGetMemoryUsage, NULL) < 0)
|
|
|
c480ed |
ret = -1;
|
|
|
c480ed |
|
|
|
c480ed |
+ if (virTestRun("virCgroupGetMemoryStat works", testCgroupGetMemoryStat, NULL) < 0)
|
|
|
c480ed |
+ ret = -1;
|
|
|
c480ed |
+
|
|
|
c480ed |
if (virTestRun("virCgroupGetPercpuStats works", testCgroupGetPercpuStats, NULL) < 0)
|
|
|
c480ed |
ret = -1;
|
|
|
c480ed |
cleanupFakeFS(fakerootdir);
|
|
|
c480ed |
--
|
|
|
c480ed |
2.22.0
|
|
|
c480ed |
|