virshtest: Prepare for testing against output files

Modify testCompareOutputLit to take a filename argument and compare it
against and populate the arguments.

For tests which don't use the 'data' from virTestRun, we'll expect to
pass the output filename, thus we also propagate it.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
Peter Krempa 2024-03-12 13:52:48 +01:00
parent de9dfeee9a
commit 86bf707838
2 changed files with 76 additions and 60 deletions

View File

@ -1386,7 +1386,7 @@ exclude_file_name_regexp--sc_prohibit_close = \
(\.p[yl]$$|\.spec\.in$$|^docs/|^(src/util/vir(file|event)\.c|src/libvirt-stream\.c|tests/(vir.+mock\.c|commandhelper\.c|qemusecuritymock\.c)|tools/nss/libvirt_nss_(leases|macs)\.c)|tools/virt-qemu-qmp-proxy$$) (\.p[yl]$$|\.spec\.in$$|^docs/|^(src/util/vir(file|event)\.c|src/libvirt-stream\.c|tests/(vir.+mock\.c|commandhelper\.c|qemusecuritymock\.c)|tools/nss/libvirt_nss_(leases|macs)\.c)|tools/virt-qemu-qmp-proxy$$)
exclude_file_name_regexp--sc_prohibit_empty_lines_at_EOF = \ exclude_file_name_regexp--sc_prohibit_empty_lines_at_EOF = \
((^tests/(nodedevmdevctl|viracpi|virhostcpu|virpcitest|virstoragetest|qemunbdkit)data/|docs/js/.*\.js|docs/fonts/.*\.woff|\.diff|tests/virconfdata/no-newline\.conf$$)|\.bin) ((^tests/(nodedevmdevctl|viracpi|virhostcpu|virpcitest|virstoragetest|qemunbdkit|virshtest)data/|docs/js/.*\.js|docs/fonts/.*\.woff|\.diff|tests/virconfdata/no-newline\.conf$$)|\.bin)
exclude_file_name_regexp--sc_prohibit_fork_wrappers = \ exclude_file_name_regexp--sc_prohibit_fork_wrappers = \
(^(src/(util/(vircommand|virdaemon)|lxc/lxc_controller)|tests/testutils)\.c$$) (^(src/(util/(vircommand|virdaemon)|lxc/lxc_controller)|tests/testutils)\.c$$)
@ -1437,7 +1437,7 @@ exclude_file_name_regexp--sc_require_config_h_first = \
^(examples/|tools/virsh-edit\.c$$|tests/virmockstathelpers\.c$$|scripts/rpcgen/tests/test_demo\.c$$) ^(examples/|tools/virsh-edit\.c$$|tests/virmockstathelpers\.c$$|scripts/rpcgen/tests/test_demo\.c$$)
exclude_file_name_regexp--sc_trailing_blank = \ exclude_file_name_regexp--sc_trailing_blank = \
/sysinfodata/.*\.data|/virhostcpudata/.*\.cpuinfo$$ /sysinfodata/.*\.data|/virhostcpudata/.*\.cpuinfo|tests/virshtestdata/.*$$
exclude_file_name_regexp--sc_unmarked_diagnostics = \ exclude_file_name_regexp--sc_unmarked_diagnostics = \
^(scripts/apibuild.py|tests/virt-aa-helper-test|docs/js/.*\.js)$$ ^(scripts/apibuild.py|tests/virt-aa-helper-test|docs/js/.*\.js)$$
@ -1466,7 +1466,7 @@ exclude_file_name_regexp--sc_prohibit_mixed_case_abbreviations = \
^src/(vbox/vbox_CAPI.*.h|esx/esx_vi.(c|h)|esx/esx_storage_backend_iscsi.c)$$ ^src/(vbox/vbox_CAPI.*.h|esx/esx_vi.(c|h)|esx/esx_storage_backend_iscsi.c)$$
exclude_file_name_regexp--sc_prohibit_empty_first_line = \ exclude_file_name_regexp--sc_prohibit_empty_first_line = \
^tests/vmwareverdata/fusion-5.0.3.txt|scripts/rpcgen/tests/demo\.c$$ ^tests/vmwareverdata/fusion-5.0.3.txt|scripts/rpcgen/tests/demo\.c|^tests/virshtestdata/.*$$
exclude_file_name_regexp--sc_prohibit_useless_translation = \ exclude_file_name_regexp--sc_prohibit_useless_translation = \
^tests/virpolkittest.c ^tests/virpolkittest.c

View File

@ -108,8 +108,10 @@ static int testFilterLine(char *buffer,
} }
static int static int
testCompareOutputLit(const char *expectData, testCompareOutputLit(const char *expectFile,
const char *filter, const char *const argv[]) const char *expectData,
const char *filter,
const char *const argv[])
{ {
g_autofree char *actualData = NULL; g_autofree char *actualData = NULL;
const char *empty = ""; const char *empty = "";
@ -134,8 +136,14 @@ testCompareOutputLit(const char *expectData,
if (filter && testFilterLine(actualData, filter) < 0) if (filter && testFilterLine(actualData, filter) < 0)
return -1; return -1;
if (virTestCompareToString(expectData, actualData) < 0) { if (expectData) {
return -1; if (virTestCompareToString(expectData, actualData) < 0)
return -1;
}
if (expectFile) {
if (virTestCompareToFileFull(actualData, expectFile, false) < 0)
return -1;
} }
return 0; return 0;
@ -151,7 +159,7 @@ static char *custom_uri;
"--connect", \ "--connect", \
custom_uri custom_uri
static int testCompareListDefault(const void *data G_GNUC_UNUSED) static int testCompareListDefault(const void *data)
{ {
const char *const argv[] = { VIRSH_DEFAULT, "list", NULL }; const char *const argv[] = { VIRSH_DEFAULT, "list", NULL };
const char *exp = "\ const char *exp = "\
@ -159,10 +167,10 @@ static int testCompareListDefault(const void *data G_GNUC_UNUSED)
----------------------\n\ ----------------------\n\
1 test running\n\ 1 test running\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareListCustom(const void *data G_GNUC_UNUSED) static int testCompareListCustom(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "list", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "list", NULL };
const char *exp = "\ const char *exp = "\
@ -172,10 +180,10 @@ static int testCompareListCustom(const void *data G_GNUC_UNUSED)
2 fc4 running\n\ 2 fc4 running\n\
3 fc5 running\n\ 3 fc5 running\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareNodeinfoDefault(const void *data G_GNUC_UNUSED) static int testCompareNodeinfoDefault(const void *data)
{ {
const char *const argv[] = { VIRSH_DEFAULT, "nodeinfo", NULL }; const char *const argv[] = { VIRSH_DEFAULT, "nodeinfo", NULL };
const char *exp = "\ const char *exp = "\
@ -188,10 +196,10 @@ Thread(s) per core: 2\n\
NUMA cell(s): 2\n\ NUMA cell(s): 2\n\
Memory size: 3145728 KiB\n\ Memory size: 3145728 KiB\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareNodeinfoCustom(const void *data G_GNUC_UNUSED) static int testCompareNodeinfoCustom(const void *data)
{ {
const char *const argv[] = { const char *const argv[] = {
VIRSH_CUSTOM, VIRSH_CUSTOM,
@ -208,115 +216,115 @@ Thread(s) per core: 2\n\
NUMA cell(s): 4\n\ NUMA cell(s): 4\n\
Memory size: 8192000 KiB\n\ Memory size: 8192000 KiB\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDominfoByID(const void *data G_GNUC_UNUSED) static int testCompareDominfoByID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "dominfo", "2", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "dominfo", "2", NULL };
const char *exp = dominfo_fc4; const char *exp = dominfo_fc4;
return testCompareOutputLit(exp, "\nCPU time:", argv); return testCompareOutputLit((const char *) data, exp, "\nCPU time:", argv);
} }
static int testCompareDominfoByUUID(const void *data G_GNUC_UNUSED) static int testCompareDominfoByUUID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "dominfo", DOM_FC4_UUID, NULL }; const char *const argv[] = { VIRSH_CUSTOM, "dominfo", DOM_FC4_UUID, NULL };
const char *exp = dominfo_fc4; const char *exp = dominfo_fc4;
return testCompareOutputLit(exp, "\nCPU time:", argv); return testCompareOutputLit((const char *) data, exp, "\nCPU time:", argv);
} }
static int testCompareDominfoByName(const void *data G_GNUC_UNUSED) static int testCompareDominfoByName(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "dominfo", "fc4", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "dominfo", "fc4", NULL };
const char *exp = dominfo_fc4; const char *exp = dominfo_fc4;
return testCompareOutputLit(exp, "\nCPU time:", argv); return testCompareOutputLit((const char *) data, exp, "\nCPU time:", argv);
} }
static int testCompareTaintedDominfoByName(const void *data G_GNUC_UNUSED) static int testCompareTaintedDominfoByName(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "dominfo", "fc5", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "dominfo", "fc5", NULL };
const char *exp = dominfo_fc5; const char *exp = dominfo_fc5;
return testCompareOutputLit(exp, "\nCPU time:", argv); return testCompareOutputLit((const char *) data, exp, "\nCPU time:", argv);
} }
static int testCompareDomuuidByID(const void *data G_GNUC_UNUSED) static int testCompareDomuuidByID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domuuid", "2", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domuuid", "2", NULL };
const char *exp = domuuid_fc4; const char *exp = domuuid_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomuuidByName(const void *data G_GNUC_UNUSED) static int testCompareDomuuidByName(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domuuid", "fc4", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domuuid", "fc4", NULL };
const char *exp = domuuid_fc4; const char *exp = domuuid_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomidByName(const void *data G_GNUC_UNUSED) static int testCompareDomidByName(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domid", "fc4", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domid", "fc4", NULL };
const char *exp = domid_fc4; const char *exp = domid_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomidByUUID(const void *data G_GNUC_UNUSED) static int testCompareDomidByUUID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domid", DOM_FC4_UUID, NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domid", DOM_FC4_UUID, NULL };
const char *exp = domid_fc4; const char *exp = domid_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomnameByID(const void *data G_GNUC_UNUSED) static int testCompareDomnameByID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domname", "2", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domname", "2", NULL };
const char *exp = domname_fc4; const char *exp = domname_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomnameByUUID(const void *data G_GNUC_UNUSED) static int testCompareDomnameByUUID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domname", DOM_FC4_UUID, NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domname", DOM_FC4_UUID, NULL };
const char *exp = domname_fc4; const char *exp = domname_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomstateByID(const void *data G_GNUC_UNUSED) static int testCompareDomstateByID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domstate", "2", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domstate", "2", NULL };
const char *exp = domstate_fc4; const char *exp = domstate_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomstateByUUID(const void *data G_GNUC_UNUSED) static int testCompareDomstateByUUID(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domstate", DOM_FC4_UUID, NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domstate", DOM_FC4_UUID, NULL };
const char *exp = domstate_fc4; const char *exp = domstate_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomstateByName(const void *data G_GNUC_UNUSED) static int testCompareDomstateByName(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domstate", "fc4", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domstate", "fc4", NULL };
const char *exp = domstate_fc4; const char *exp = domstate_fc4;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareDomControlInfoByName(const void *data G_GNUC_UNUSED) static int testCompareDomControlInfoByName(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domcontrol", "fc4", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "domcontrol", "fc4", NULL };
const char *exp = "ok\n\n"; const char *exp = "ok\n\n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareGetBlkioParameters(const void *data G_GNUC_UNUSED) static int testCompareGetBlkioParameters(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "blkiotune", "fv0", NULL }; const char *const argv[] = { VIRSH_CUSTOM, "blkiotune", "fv0", NULL };
const char *exp = get_blkio_parameters; const char *exp = get_blkio_parameters;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testCompareSetBlkioParameters(const void *data G_GNUC_UNUSED) static int testCompareSetBlkioParameters(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "blkiotune fv0\ const char *const argv[] = { VIRSH_CUSTOM, "blkiotune fv0\
--weight 500\ --weight 500\
@ -332,10 +340,10 @@ static int testCompareSetBlkioParameters(const void *data G_GNUC_UNUSED)
" SET_BLKIO_PARAMETER ";\ " SET_BLKIO_PARAMETER ";\
blkiotune fv0", NULL }; blkiotune fv0", NULL };
const char *exp = set_blkio_parameters; const char *exp = set_blkio_parameters;
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testIOThreadAdd(const void *data G_GNUC_UNUSED) static int testIOThreadAdd(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "iothreadinfo --domain fc4;\ const char *const argv[] = { VIRSH_CUSTOM, "iothreadinfo --domain fc4;\
iothreadadd --domain fc4 --id 6;\ iothreadadd --domain fc4 --id 6;\
@ -353,10 +361,10 @@ static int testIOThreadAdd(const void *data G_GNUC_UNUSED)
4 0\n\ 4 0\n\
6 0\n\ 6 0\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testIOThreadDel(const void *data G_GNUC_UNUSED) static int testIOThreadDel(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "iothreadinfo --domain fc4;\ const char *const argv[] = { VIRSH_CUSTOM, "iothreadinfo --domain fc4;\
iothreaddel --domain fc4 --id 2;\ iothreaddel --domain fc4 --id 2;\
@ -372,10 +380,10 @@ static int testIOThreadDel(const void *data G_GNUC_UNUSED)
-----------------------------\n\ -----------------------------\n\
4 0\n\ 4 0\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testIOThreadSet(const void *data G_GNUC_UNUSED) static int testIOThreadSet(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, "domstats --domain fc4;\ const char *const argv[] = { VIRSH_CUSTOM, "domstats --domain fc4;\
iothreadset --domain fc4\ iothreadset --domain fc4\
@ -404,10 +412,10 @@ Domain: 'fc4'\n\
iothread.4.poll-max-ns" EQUAL "32768\n\ iothread.4.poll-max-ns" EQUAL "32768\n\
iothread.4.poll-grow" EQUAL "0\n\ iothread.4.poll-grow" EQUAL "0\n\
iothread.4.poll-shrink" EQUAL "0\n\n"; iothread.4.poll-shrink" EQUAL "0\n\n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
static int testIOThreadPin(const void *data G_GNUC_UNUSED) static int testIOThreadPin(const void *data)
{ {
const char *const argv[] = { VIRSH_CUSTOM, const char *const argv[] = { VIRSH_CUSTOM,
"iothreadadd --domain fc5 --id 2;\ "iothreadadd --domain fc5 --id 2;\
@ -425,18 +433,27 @@ static int testIOThreadPin(const void *data G_GNUC_UNUSED)
-----------------------------\n\ -----------------------------\n\
2 0\n\ 2 0\n\
\n"; \n";
return testCompareOutputLit(exp, NULL, argv); return testCompareOutputLit((const char *) data, exp, NULL, argv);
} }
struct testInfo { struct testInfo {
const char *testname; /* used to generate output filename */
const char *filter;
const char *const *argv; const char *const *argv;
const char *result; const char *result;
}; };
static int testCompareEcho(const void *data) static int testCompare(const void *data)
{ {
const struct testInfo *info = data; const struct testInfo *info = data;
return testCompareOutputLit(info->result, NULL, info->argv); g_autofree char *outfile = NULL;
if (info->testname) {
outfile = g_strdup_printf("%s/virshtestdata/%s.out",
abs_srcdir, info->testname);
}
return testCompareOutputLit(outfile, info->result, info->filter, info->argv);
} }
@ -549,9 +566,8 @@ mymain(void)
# define DO_TEST(i, result, ...) \ # define DO_TEST(i, result, ...) \
do { \ do { \
const char *myargv[] = { VIRSH_DEFAULT, __VA_ARGS__, NULL }; \ const char *myargv[] = { VIRSH_DEFAULT, __VA_ARGS__, NULL }; \
const struct testInfo info = { myargv, result }; \ const struct testInfo info = { NULL, NULL, myargv, result }; \
if (virTestRun("virsh echo " #i, \ if (virTestRun("virsh echo " #i, testCompare, &info) < 0) \
testCompareEcho, &info) < 0) \
ret = -1; \ ret = -1; \
} while (0) } while (0)