|
|
397dc2 |
From ff54ea3d2a61a25079339d38caa6c509cf697ce3 Mon Sep 17 00:00:00 2001
|
|
|
397dc2 |
Message-Id: <ff54ea3d2a61a25079339d38caa6c509cf697ce3@dist-git>
|
|
|
397dc2 |
From: "Mauro S. M. Rodrigues" <maurosr@linux.vnet.ibm.com>
|
|
|
397dc2 |
Date: Tue, 19 Jan 2021 21:04:08 -0300
|
|
|
397dc2 |
Subject: [PATCH] util: virhostcpu: Fail when fetching CPU Stats for invalid
|
|
|
397dc2 |
cpu
|
|
|
397dc2 |
|
|
|
397dc2 |
virHostCPUGetStatsLinux walks through every cpu in /proc/stat until it
|
|
|
397dc2 |
finds cpu%cpuNum that matches with the requested cpu.
|
|
|
397dc2 |
If none is found it logs the error but it should return -1, instead of 0.
|
|
|
397dc2 |
Otherwise virsh nodecpustats --cpu <invalid cpu number> and API bindings
|
|
|
397dc2 |
don't fail properly, printing a blank line instead of an error message.
|
|
|
397dc2 |
|
|
|
397dc2 |
This patch also includes an additional test for virhostcputest to avoid
|
|
|
397dc2 |
this regression to happen again in the future.
|
|
|
397dc2 |
|
|
|
397dc2 |
Fixes: 93af79fba3fd75a8df6b7ca608719dd97f9511a0
|
|
|
397dc2 |
Reported-by: Satheesh Rajendran <satheera@in.ibm.com>
|
|
|
397dc2 |
Signed-off-by: Mauro S. M. Rodrigues <maurosr@linux.vnet.ibm.com>
|
|
|
397dc2 |
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
|
|
|
397dc2 |
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
|
|
|
397dc2 |
Reviewed-by: Christian Ehrhardt <christian.ehrhardt@canonical.com>
|
|
|
397dc2 |
Tested-by: Christian Ehrhardt <christian.ehrhardt@canonical.com>
|
|
|
397dc2 |
(cherry picked from commit 75a4ec42f70b5324f95d7ffbbfbf7457620735e4)
|
|
|
397dc2 |
|
|
|
397dc2 |
https://bugzilla.redhat.com/1915183
|
|
|
397dc2 |
|
|
|
397dc2 |
Signed-off-by: Daniel Henrique Barboza <dbarboza@redhat.com>
|
|
|
397dc2 |
Message-Id: <20210120000408.106596-1-dbarboza@redhat.com>
|
|
|
397dc2 |
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
397dc2 |
---
|
|
|
397dc2 |
src/util/virhostcpu.c | 2 +-
|
|
|
397dc2 |
tests/virhostcputest.c | 21 ++++++++++++++++++---
|
|
|
397dc2 |
2 files changed, 19 insertions(+), 4 deletions(-)
|
|
|
397dc2 |
|
|
|
397dc2 |
diff --git a/src/util/virhostcpu.c b/src/util/virhostcpu.c
|
|
|
397dc2 |
index 218272d7ec..37cc45e3a6 100644
|
|
|
397dc2 |
--- a/src/util/virhostcpu.c
|
|
|
397dc2 |
+++ b/src/util/virhostcpu.c
|
|
|
397dc2 |
@@ -855,7 +855,7 @@ virHostCPUGetStatsLinux(FILE *procstat,
|
|
|
397dc2 |
_("Invalid cpuNum in %s"),
|
|
|
397dc2 |
__FUNCTION__);
|
|
|
397dc2 |
|
|
|
397dc2 |
- return 0;
|
|
|
397dc2 |
+ return -1;
|
|
|
397dc2 |
}
|
|
|
397dc2 |
|
|
|
397dc2 |
|
|
|
397dc2 |
diff --git a/tests/virhostcputest.c b/tests/virhostcputest.c
|
|
|
397dc2 |
index 7865b61578..70a723098b 100644
|
|
|
397dc2 |
--- a/tests/virhostcputest.c
|
|
|
397dc2 |
+++ b/tests/virhostcputest.c
|
|
|
397dc2 |
@@ -196,6 +196,7 @@ linuxTestHostCPU(const void *opaque)
|
|
|
397dc2 |
struct nodeCPUStatsData {
|
|
|
397dc2 |
const char *name;
|
|
|
397dc2 |
int ncpus;
|
|
|
397dc2 |
+ bool shouldFail;
|
|
|
397dc2 |
};
|
|
|
397dc2 |
|
|
|
397dc2 |
static int
|
|
|
397dc2 |
@@ -214,6 +215,19 @@ linuxTestNodeCPUStats(const void *data)
|
|
|
397dc2 |
result = linuxCPUStatsCompareFiles(cpustatfile,
|
|
|
397dc2 |
testData->ncpus,
|
|
|
397dc2 |
outfile);
|
|
|
397dc2 |
+ if (result < 0) {
|
|
|
397dc2 |
+ if (testData->shouldFail) {
|
|
|
397dc2 |
+ /* Expected error */
|
|
|
397dc2 |
+ result = 0;
|
|
|
397dc2 |
+ }
|
|
|
397dc2 |
+ } else {
|
|
|
397dc2 |
+ if (testData->shouldFail) {
|
|
|
397dc2 |
+ fprintf(stderr, "Expected a failure, got success");
|
|
|
397dc2 |
+ result = -1;
|
|
|
397dc2 |
+ }
|
|
|
397dc2 |
+ }
|
|
|
397dc2 |
+
|
|
|
397dc2 |
+
|
|
|
397dc2 |
VIR_FREE(cpustatfile);
|
|
|
397dc2 |
VIR_FREE(outfile);
|
|
|
397dc2 |
return result;
|
|
|
397dc2 |
@@ -258,14 +272,15 @@ mymain(void)
|
|
|
397dc2 |
if (virTestRun(nodeData[i].testName, linuxTestHostCPU, &nodeData[i]) != 0)
|
|
|
397dc2 |
ret = -1;
|
|
|
397dc2 |
|
|
|
397dc2 |
-# define DO_TEST_CPU_STATS(name, ncpus) \
|
|
|
397dc2 |
+# define DO_TEST_CPU_STATS(name, ncpus, shouldFail) \
|
|
|
397dc2 |
do { \
|
|
|
397dc2 |
- static struct nodeCPUStatsData data = { name, ncpus }; \
|
|
|
397dc2 |
+ static struct nodeCPUStatsData data = { name, ncpus, shouldFail}; \
|
|
|
397dc2 |
if (virTestRun("CPU stats " name, linuxTestNodeCPUStats, &data) < 0) \
|
|
|
397dc2 |
ret = -1; \
|
|
|
397dc2 |
} while (0)
|
|
|
397dc2 |
|
|
|
397dc2 |
- DO_TEST_CPU_STATS("24cpu", 24);
|
|
|
397dc2 |
+ DO_TEST_CPU_STATS("24cpu", 24, false);
|
|
|
397dc2 |
+ DO_TEST_CPU_STATS("24cpu", 25, true);
|
|
|
397dc2 |
|
|
|
397dc2 |
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
|
397dc2 |
}
|
|
|
397dc2 |
--
|
|
|
397dc2 |
2.30.0
|
|
|
397dc2 |
|