mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-06 17:17:56 +03:00
32228ecb02
The nvram image can have any supported format and there's no technical requirement of them having the same format. In fact the actual nvram image doesn't necessarily need to have the same format as the template if the user is willing to format it themselves (as libvirt is not going to convert it). Remove the nonsensical check and adjust tests. The test case required swapping around the format in order to work properly. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
3041 lines
129 KiB
C
3041 lines
129 KiB
C
#include <config.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <sys/types.h>
|
|
#include <fcntl.h>
|
|
|
|
#include "testutils.h"
|
|
|
|
#ifdef WITH_QEMU
|
|
|
|
# include "internal.h"
|
|
# include "viralloc.h"
|
|
# include "viridentity.h"
|
|
# include "qemu/qemu_block.h"
|
|
# include "qemu/qemu_capabilities.h"
|
|
# include "qemu/qemu_domain.h"
|
|
# include "qemu/qemu_migration.h"
|
|
# include "qemu/qemu_process.h"
|
|
# include "qemu/qemu_slirp.h"
|
|
# include "datatypes.h"
|
|
# include "conf/storage_conf.h"
|
|
# include "virfilewrapper.h"
|
|
# include "configmake.h"
|
|
# include "testutilsqemuschema.h"
|
|
|
|
# define LIBVIRT_QEMU_CAPSPRIV_H_ALLOW
|
|
# include "qemu/qemu_capspriv.h"
|
|
|
|
# include "testutilsqemu.h"
|
|
|
|
# define VIR_FROM_THIS VIR_FROM_QEMU
|
|
|
|
static virQEMUDriver driver;
|
|
|
|
static unsigned char *
|
|
fakeSecretGetValue(virSecretPtr obj G_GNUC_UNUSED,
|
|
size_t *value_size,
|
|
unsigned int fakeflags G_GNUC_UNUSED)
|
|
{
|
|
char *secret;
|
|
secret = g_strdup("AQCVn5hO6HzFAhAAq0NCv8jtJcIcE+HOBlMQ1A");
|
|
*value_size = strlen(secret);
|
|
return (unsigned char *) secret;
|
|
}
|
|
|
|
static virSecretPtr
|
|
fakeSecretLookupByUsage(virConnectPtr conn,
|
|
int usageType,
|
|
const char *usageID)
|
|
{
|
|
unsigned char uuid[VIR_UUID_BUFLEN];
|
|
if (usageType == VIR_SECRET_USAGE_TYPE_VOLUME) {
|
|
if (!STRPREFIX(usageID, "/storage/guest_disks/")) {
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
"test provided invalid volume storage prefix '%s'",
|
|
usageID);
|
|
return NULL;
|
|
}
|
|
} else if (STRNEQ(usageID, "mycluster_myname") &&
|
|
STRNEQ(usageID, "client.admin secret")) {
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
"test provided incorrect usage '%s'", usageID);
|
|
return NULL;
|
|
}
|
|
|
|
if (virUUIDGenerate(uuid) < 0)
|
|
return NULL;
|
|
|
|
return virGetSecret(conn, uuid, usageType, usageID);
|
|
}
|
|
|
|
static virSecretPtr
|
|
fakeSecretLookupByUUID(virConnectPtr conn,
|
|
const unsigned char *uuid)
|
|
{
|
|
/* NB: This mocked value could be "tls" or "volume" depending on
|
|
* which test is being run, we'll leave at NONE (or 0) */
|
|
return virGetSecret(conn, uuid, VIR_SECRET_USAGE_TYPE_NONE, "");
|
|
}
|
|
|
|
static virSecretDriver fakeSecretDriver = {
|
|
.connectNumOfSecrets = NULL,
|
|
.connectListSecrets = NULL,
|
|
.secretLookupByUUID = fakeSecretLookupByUUID,
|
|
.secretLookupByUsage = fakeSecretLookupByUsage,
|
|
.secretDefineXML = NULL,
|
|
.secretGetXMLDesc = NULL,
|
|
.secretSetValue = NULL,
|
|
.secretGetValue = fakeSecretGetValue,
|
|
.secretUndefine = NULL,
|
|
};
|
|
|
|
|
|
# define STORAGE_POOL_XML_PATH "storagepoolxml2xmlout/"
|
|
static const unsigned char fakeUUID[VIR_UUID_BUFLEN] = "fakeuuid";
|
|
|
|
static virStoragePoolPtr
|
|
fakeStoragePoolLookupByName(virConnectPtr conn,
|
|
const char *name)
|
|
{
|
|
g_autofree char *xmlpath = NULL;
|
|
|
|
if (STRNEQ(name, "inactive")) {
|
|
xmlpath = g_strdup_printf("%s/%s%s.xml", abs_srcdir,
|
|
STORAGE_POOL_XML_PATH, name);
|
|
|
|
if (!virFileExists(xmlpath)) {
|
|
virReportError(VIR_ERR_NO_STORAGE_POOL,
|
|
"File '%s' not found", xmlpath);
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
return virGetStoragePool(conn, name, fakeUUID, NULL, NULL);
|
|
}
|
|
|
|
|
|
static virStorageVolPtr
|
|
fakeStorageVolLookupByName(virStoragePoolPtr pool,
|
|
const char *name)
|
|
{
|
|
g_auto(GStrv) volinfo = NULL;
|
|
|
|
if (STREQ(pool->name, "inactive")) {
|
|
virReportError(VIR_ERR_OPERATION_INVALID,
|
|
"storage pool '%s' is not active", pool->name);
|
|
return NULL;
|
|
}
|
|
|
|
if (STREQ(name, "nonexistent")) {
|
|
virReportError(VIR_ERR_NO_STORAGE_VOL,
|
|
"no storage vol with matching name '%s'", name);
|
|
return NULL;
|
|
}
|
|
|
|
if (!(volinfo = g_strsplit(name, "+", 2)))
|
|
return NULL;
|
|
|
|
if (!volinfo[1]) {
|
|
return virGetStorageVol(pool->conn, pool->name, name, "block", NULL, NULL);
|
|
}
|
|
|
|
return virGetStorageVol(pool->conn, pool->name, volinfo[1], volinfo[0],
|
|
NULL, NULL);
|
|
}
|
|
|
|
static int
|
|
fakeStorageVolGetInfo(virStorageVolPtr vol,
|
|
virStorageVolInfoPtr info)
|
|
{
|
|
memset(info, 0, sizeof(*info));
|
|
|
|
info->type = virStorageVolTypeFromString(vol->key);
|
|
|
|
if (info->type < 0) {
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
"Invalid volume type '%s'", vol->key);
|
|
return -1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static char *
|
|
fakeStorageVolGetPath(virStorageVolPtr vol)
|
|
{
|
|
return g_strdup_printf("/some/%s/device/%s", vol->key, vol->name);
|
|
}
|
|
|
|
|
|
static char *
|
|
fakeStoragePoolGetXMLDesc(virStoragePoolPtr pool,
|
|
unsigned int flags_unused G_GNUC_UNUSED)
|
|
{
|
|
g_autofree char *xmlpath = NULL;
|
|
char *xmlbuf = NULL;
|
|
|
|
if (STREQ(pool->name, "inactive")) {
|
|
virReportError(VIR_ERR_NO_STORAGE_POOL, NULL);
|
|
return NULL;
|
|
}
|
|
|
|
xmlpath = g_strdup_printf("%s/%s%s.xml", abs_srcdir, STORAGE_POOL_XML_PATH,
|
|
pool->name);
|
|
|
|
if (virTestLoadFile(xmlpath, &xmlbuf) < 0) {
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
"failed to load XML file '%s'",
|
|
xmlpath);
|
|
return NULL;
|
|
}
|
|
|
|
return xmlbuf;
|
|
}
|
|
|
|
static int
|
|
fakeStoragePoolIsActive(virStoragePoolPtr pool)
|
|
{
|
|
if (STREQ(pool->name, "inactive"))
|
|
return 0;
|
|
|
|
return 1;
|
|
}
|
|
|
|
/* Test storage pool implementation
|
|
*
|
|
* These functions aid testing of storage pool related stuff when creating a
|
|
* qemu command line.
|
|
*
|
|
* There are a few "magic" values to pass to these functions:
|
|
*
|
|
* 1) "inactive" as a pool name to create an inactive pool. All other names are
|
|
* interpreted as file names in storagepoolxml2xmlout/ and are used as the
|
|
* definition for the pool. If the file doesn't exist the pool doesn't exist.
|
|
*
|
|
* 2) "nonexistent" returns an error while looking up a volume. Otherwise
|
|
* pattern VOLUME_TYPE+VOLUME_PATH can be used to simulate a volume in a pool.
|
|
* This creates a fake path for this volume. If the '+' sign is omitted, block
|
|
* type is assumed.
|
|
*/
|
|
static virStorageDriver fakeStorageDriver = {
|
|
.storagePoolLookupByName = fakeStoragePoolLookupByName,
|
|
.storageVolLookupByName = fakeStorageVolLookupByName,
|
|
.storagePoolGetXMLDesc = fakeStoragePoolGetXMLDesc,
|
|
.storageVolGetPath = fakeStorageVolGetPath,
|
|
.storageVolGetInfo = fakeStorageVolGetInfo,
|
|
.storagePoolIsActive = fakeStoragePoolIsActive,
|
|
};
|
|
|
|
|
|
/* virNetDevOpenvswitchGetVhostuserIfname mocks a portdev name - handle that */
|
|
static virNWFilterBindingPtr
|
|
fakeNWFilterBindingLookupByPortDev(virConnectPtr conn,
|
|
const char *portdev)
|
|
{
|
|
if (STREQ(portdev, "vhost-user0"))
|
|
return virGetNWFilterBinding(conn, "fake_vnet0", "fakeFilterName");
|
|
|
|
virReportError(VIR_ERR_NO_NWFILTER_BINDING,
|
|
"no nwfilter binding for port dev '%s'", portdev);
|
|
return NULL;
|
|
}
|
|
|
|
|
|
static int
|
|
fakeNWFilterBindingDelete(virNWFilterBindingPtr binding G_GNUC_UNUSED)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
|
|
static virNWFilterDriver fakeNWFilterDriver = {
|
|
.nwfilterBindingLookupByPortDev = fakeNWFilterBindingLookupByPortDev,
|
|
.nwfilterBindingDelete = fakeNWFilterBindingDelete,
|
|
};
|
|
|
|
|
|
/* name of the fake network shall be constructed as:
|
|
* NETWORKXMLNAME;NETWORKPORTXMLNAME
|
|
* where:
|
|
* NETWORKXMLNAME resolves to abs_srcdir/networkxml2xmlin/NETWORKXMLNAME.xml
|
|
* NETWORKPORTXMLNAME resolves to abs_srcdir/virnetworkportxml2xmldata/NETWORKPORTXMLNAME.xml
|
|
*/
|
|
static virNetworkPtr
|
|
fakeNetworkLookupByName(virConnectPtr conn,
|
|
const char *name)
|
|
{
|
|
unsigned char uuid[VIR_UUID_BUFLEN];
|
|
g_autofree char *netname = g_strdup(name);
|
|
g_autofree char *path = NULL;
|
|
char *tmp;
|
|
|
|
memset(uuid, 0, VIR_UUID_BUFLEN);
|
|
|
|
if ((tmp = strchr(netname, ';'))) {
|
|
*tmp = '\0';
|
|
} else {
|
|
virReportError(VIR_ERR_NO_NETWORK,
|
|
"Malformed fake network name '%s'. See fakeNetworkLookupByName.",
|
|
name);
|
|
return NULL;
|
|
}
|
|
|
|
path = g_strdup_printf(abs_srcdir "/networkxml2xmlin/%s.xml", netname);
|
|
|
|
if (!virFileExists(path)) {
|
|
virReportError(VIR_ERR_NO_NETWORK, "fake network '%s' not found", path);
|
|
return NULL;
|
|
}
|
|
|
|
return virGetNetwork(conn, name, uuid);
|
|
}
|
|
|
|
|
|
static char *
|
|
fakeNetworkGetXMLDesc(virNetworkPtr network,
|
|
unsigned int noflags G_GNUC_UNUSED)
|
|
{
|
|
g_autofree char *netname = g_strdup(network->name);
|
|
g_autofree char *path = NULL;
|
|
char *xml = NULL;
|
|
|
|
*(strchr(netname, ';')) = '\0';
|
|
|
|
path = g_strdup_printf(abs_srcdir "/networkxml2xmlin/%s.xml", netname);
|
|
|
|
if (virFileReadAll(path, 4 * 1024, &xml) < 0)
|
|
return NULL;
|
|
|
|
return xml;
|
|
}
|
|
|
|
|
|
static virNetworkPortPtr
|
|
fakeNetworkPortCreateXML(virNetworkPtr net,
|
|
const char *xmldesc G_GNUC_UNUSED,
|
|
unsigned int noflags G_GNUC_UNUSED)
|
|
{
|
|
unsigned char uuid[VIR_UUID_BUFLEN];
|
|
g_autofree char *portname = g_strdup(strchr(net->name, ';') + 1);
|
|
g_autofree char *path = g_strdup_printf(abs_srcdir "/virnetworkportxml2xmldata/%s.xml", portname);
|
|
|
|
memset(uuid, 0, VIR_UUID_BUFLEN);
|
|
|
|
if (!virFileExists(path)) {
|
|
virReportError(VIR_ERR_NO_NETWORK_PORT, "fake network port '%s' not found", path);
|
|
return NULL;
|
|
}
|
|
|
|
return virGetNetworkPort(net, uuid);
|
|
}
|
|
|
|
|
|
static char *
|
|
fakeNetworkPortGetXMLDesc(virNetworkPortPtr port,
|
|
unsigned int noflags G_GNUC_UNUSED)
|
|
{
|
|
g_autofree char *portname = g_strdup(strchr(port->net->name, ';') + 1);
|
|
g_autofree char *path = g_strdup_printf(abs_srcdir "/virnetworkportxml2xmldata/%s.xml", portname);
|
|
char *xml = NULL;
|
|
|
|
if (virFileReadAll(path, 4 * 1024, &xml) < 0)
|
|
return NULL;
|
|
|
|
return xml;
|
|
}
|
|
|
|
|
|
static virNetworkDriver fakeNetworkDriver = {
|
|
.networkLookupByName = fakeNetworkLookupByName,
|
|
.networkGetXMLDesc = fakeNetworkGetXMLDesc,
|
|
.networkPortCreateXML = fakeNetworkPortCreateXML,
|
|
.networkPortGetXMLDesc = fakeNetworkPortGetXMLDesc,
|
|
};
|
|
|
|
|
|
static void
|
|
testUpdateQEMUCapsHostCPUModel(virQEMUCaps *qemuCaps, virArch hostArch)
|
|
{
|
|
virQEMUCapsUpdateHostCPUModel(qemuCaps, hostArch, VIR_DOMAIN_VIRT_KVM);
|
|
virQEMUCapsUpdateHostCPUModel(qemuCaps, hostArch, VIR_DOMAIN_VIRT_QEMU);
|
|
}
|
|
|
|
|
|
static int
|
|
testCheckExclusiveFlags(int flags)
|
|
{
|
|
virCheckFlags(FLAG_EXPECT_FAILURE |
|
|
FLAG_EXPECT_PARSE_ERROR |
|
|
FLAG_REAL_CAPS |
|
|
FLAG_SLIRP_HELPER |
|
|
FLAG_ALLOW_DUPLICATE_OUTPUT |
|
|
FLAG_ALLOW_MISSING_INPUT |
|
|
0, -1);
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static virCommand *
|
|
testCompareXMLToArgvCreateArgs(virQEMUDriver *drv,
|
|
virDomainObj *vm,
|
|
const char *migrateURI,
|
|
testQemuInfo *info,
|
|
unsigned int flags)
|
|
{
|
|
qemuDomainObjPrivate *priv = vm->privateData;
|
|
size_t i;
|
|
|
|
if (qemuProcessCreatePretendCmdPrepare(drv, vm, migrateURI,
|
|
VIR_QEMU_PROCESS_START_COLD) < 0)
|
|
return NULL;
|
|
|
|
if (qemuDomainDeviceBackendChardevForeach(vm->def,
|
|
testQemuPrepareHostBackendChardevOne,
|
|
vm) < 0)
|
|
return NULL;
|
|
|
|
if (testQemuPrepareHostBackendChardevOne(NULL, priv->monConfig, vm) < 0)
|
|
return NULL;
|
|
|
|
for (i = 0; i < vm->def->ndisks; i++) {
|
|
virDomainDiskDef *disk = vm->def->disks[i];
|
|
virStorageSource *src;
|
|
|
|
/* host cdrom requires special treatment in qemu, mock it */
|
|
if (disk->device == VIR_DOMAIN_DISK_DEVICE_CDROM &&
|
|
disk->src->format == VIR_STORAGE_FILE_RAW &&
|
|
virStorageSourceIsBlockLocal(disk->src) &&
|
|
STREQ(disk->src->path, "/dev/cdrom"))
|
|
disk->src->hostcdrom = true;
|
|
|
|
if (info->args.vdpafds) {
|
|
for (src = disk->src; virStorageSourceIsBacking(src); src = src->backingStore) {
|
|
gpointer value;
|
|
|
|
if (src->type != VIR_STORAGE_TYPE_VHOST_VDPA)
|
|
continue;
|
|
|
|
if ((value = g_hash_table_lookup(info->args.vdpafds, src->vdpadev))) {
|
|
int fd = GPOINTER_TO_INT(value);
|
|
qemuDomainStorageSourcePrivate *srcpriv;
|
|
VIR_AUTOCLOSE fakefd = open("/dev/zero", O_RDWR);
|
|
|
|
if (fcntl(fd, F_GETFD) != -1) {
|
|
fprintf(stderr, "fd '%d' is already in use\n", fd);
|
|
abort();
|
|
}
|
|
|
|
if (dup2(fakefd, fd) < 0) {
|
|
fprintf(stderr, "failed to duplicate fake fd: %s",
|
|
g_strerror(errno));
|
|
abort();
|
|
}
|
|
|
|
srcpriv = qemuDomainStorageSourcePrivateFetch(src);
|
|
|
|
srcpriv->fdpass = qemuFDPassNew(qemuBlockStorageSourceGetStorageNodename(src), priv);
|
|
qemuFDPassAddFD(srcpriv->fdpass, &fd, "-vdpa");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (vm->def->vsock) {
|
|
virDomainVsockDef *vsock = vm->def->vsock;
|
|
qemuDomainVsockPrivate *vsockPriv =
|
|
(qemuDomainVsockPrivate *)vsock->privateData;
|
|
|
|
if (vsock->auto_cid == VIR_TRISTATE_BOOL_YES)
|
|
vsock->guest_cid = 42;
|
|
|
|
vsockPriv->vhostfd = 6789;
|
|
}
|
|
|
|
for (i = 0; i < vm->def->ntpms; i++) {
|
|
if (vm->def->tpms[i]->type != VIR_DOMAIN_TPM_TYPE_EMULATOR)
|
|
continue;
|
|
|
|
VIR_FREE(vm->def->tpms[i]->data.emulator.source->data.nix.path);
|
|
vm->def->tpms[i]->data.emulator.source->type = VIR_DOMAIN_CHR_TYPE_UNIX;
|
|
vm->def->tpms[i]->data.emulator.source->data.nix.path = g_strdup("/dev/test");
|
|
}
|
|
|
|
for (i = 0; i < vm->def->nvideos; i++) {
|
|
virDomainVideoDef *video = vm->def->videos[i];
|
|
|
|
if (video->backend == VIR_DOMAIN_VIDEO_BACKEND_TYPE_VHOSTUSER) {
|
|
qemuDomainVideoPrivate *vpriv = QEMU_DOMAIN_VIDEO_PRIVATE(video);
|
|
|
|
vpriv->vhost_user_fd = 1729;
|
|
}
|
|
}
|
|
|
|
if (flags & FLAG_SLIRP_HELPER) {
|
|
for (i = 0; i < vm->def->nnets; i++) {
|
|
virDomainNetDef *net = vm->def->nets[i];
|
|
|
|
if (net->type == VIR_DOMAIN_NET_TYPE_USER &&
|
|
net->backend.type == VIR_DOMAIN_NET_BACKEND_DEFAULT &&
|
|
virQEMUCapsGet(info->qemuCaps, QEMU_CAPS_DBUS_VMSTATE)) {
|
|
qemuSlirp *slirp = qemuSlirpNew();
|
|
slirp->fd[0] = 42;
|
|
QEMU_DOMAIN_NETWORK_PRIVATE(net)->slirp = slirp;
|
|
}
|
|
}
|
|
}
|
|
|
|
return qemuProcessCreatePretendCmdBuild(vm, migrateURI);
|
|
}
|
|
|
|
|
|
struct testValidateSchemaCommandData {
|
|
const char *name;
|
|
const char *schema;
|
|
bool allowIncomplete; /* relax validator for commands with incomplete schema */
|
|
};
|
|
|
|
|
|
static const struct testValidateSchemaCommandData commands[] = {
|
|
{ "-blockdev", "blockdev-add", false },
|
|
{ "-netdev", "netdev_add", false },
|
|
{ "-object", "object-add", false },
|
|
{ "-device", "device_add", true },
|
|
{ "-chardev", "chardev-add", false },
|
|
};
|
|
|
|
static int
|
|
testCompareXMLToArgvValidateSchemaCommand(GStrv args,
|
|
GHashTable *schema)
|
|
{
|
|
GStrv arg;
|
|
|
|
for (arg = args; *arg; arg++) {
|
|
const char *curcommand = *arg;
|
|
const char *curargs = *(arg + 1);
|
|
size_t i;
|
|
|
|
for (i = 0; i < G_N_ELEMENTS(commands); i++) {
|
|
const struct testValidateSchemaCommandData *command = commands + i;
|
|
g_auto(virBuffer) debug = VIR_BUFFER_INITIALIZER;
|
|
g_autoptr(virJSONValue) jsonargs = NULL;
|
|
|
|
if (STRNEQ(curcommand, command->name))
|
|
continue;
|
|
|
|
if (!curargs) {
|
|
VIR_TEST_VERBOSE("expected arguments for command '%s'",
|
|
command->name);
|
|
return -1;
|
|
}
|
|
|
|
if (*curargs != '{') {
|
|
arg++;
|
|
break;
|
|
}
|
|
|
|
if (!(jsonargs = virJSONValueFromString(curargs)))
|
|
return -1;
|
|
|
|
if (testQEMUSchemaValidateCommand(command->schema, jsonargs,
|
|
schema, false, false,
|
|
command->allowIncomplete,
|
|
&debug) < 0) {
|
|
VIR_TEST_VERBOSE("failed to validate '%s %s' against QAPI schema: %s",
|
|
command->name, curargs, virBufferCurrentContent(&debug));
|
|
return -1;
|
|
}
|
|
|
|
arg++;
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static int
|
|
testCompareXMLToArgvValidateSchema(virCommand *cmd,
|
|
testQemuInfo *info)
|
|
{
|
|
g_auto(GStrv) args = NULL;
|
|
|
|
if (!info->qmpSchema)
|
|
return 0;
|
|
|
|
if (virCommandGetArgList(cmd, &args) < 0)
|
|
return -1;
|
|
|
|
if (testCompareXMLToArgvValidateSchemaCommand(args, info->qmpSchema) < 0)
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static int
|
|
testInfoCheckDuplicate(testQemuInfo *info)
|
|
{
|
|
const char *path = info->outfile;
|
|
|
|
if (info->flags & FLAG_ALLOW_DUPLICATE_OUTPUT)
|
|
return 0;
|
|
|
|
if (!path)
|
|
path = info->errfile;
|
|
|
|
if (g_hash_table_contains(info->conf->duplicateTests, path)) {
|
|
fprintf(stderr, "\nduplicate invocation of test case: %s\n'", path);
|
|
return -1;
|
|
}
|
|
|
|
g_hash_table_insert(info->conf->duplicateTests, g_strdup(path), NULL);
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
/**
|
|
* testQemuConfXMLCommon: Prepare common test data (e.g. parse input XML)
|
|
* for a test case.
|
|
*
|
|
* @info: test info struct to prepare
|
|
* @rv: return value that the caller is supposed to return (see below)
|
|
*
|
|
* Since some of the prepared data is reused by multiple tests, which can be
|
|
* potentially skipped via 'VIR_TEST_RANGE', this function is designed to be
|
|
* callable multiple times but processes data just once.
|
|
*
|
|
* Returns 'true' if subsequent tests are expected to run (input XML was parsed
|
|
* properly and test is not expected to fail on parse error). Otherwise 'false'
|
|
* is returned and rv is populated according to the following logic:
|
|
* 1) expected failure of parsing (FLAG_EXPECT_PARSE_ERROR)
|
|
* - first invocation sets @rv to 0
|
|
* - other invocations set rv to EXIT_AM_SKIP
|
|
* 2) unexpected error
|
|
* - all invocations return -1
|
|
* - first invocation reports actual error
|
|
* - other invocations report replacement error
|
|
*/
|
|
static bool
|
|
testQemuConfXMLCommon(testQemuInfo *info,
|
|
int *rv)
|
|
{
|
|
g_autoptr(virDomainDef) def = NULL;
|
|
|
|
/* initialize a test just once */
|
|
if (info->prepared)
|
|
goto cleanup;
|
|
|
|
/* mark test case as used */
|
|
ignore_value(g_hash_table_remove(info->conf->existingTestCases, info->infile));
|
|
if (info->outfile)
|
|
ignore_value(g_hash_table_remove(info->conf->existingTestCases, info->outfile));
|
|
if (info->errfile)
|
|
ignore_value(g_hash_table_remove(info->conf->existingTestCases, info->errfile));
|
|
if (info->out_xml_inactive)
|
|
ignore_value(g_hash_table_remove(info->conf->existingTestCases, info->out_xml_inactive));
|
|
|
|
if (testQemuInfoInitArgs((testQemuInfo *) info) < 0)
|
|
goto cleanup;
|
|
|
|
if (testInfoCheckDuplicate(info) < 0)
|
|
goto cleanup;
|
|
|
|
# if !WITH_NBDKIT
|
|
/* when compiled without nbdkit support we want to skip the test after
|
|
* marking it as used */
|
|
if (info->args.fakeNbdkitCaps) {
|
|
info->prep_skip = true;
|
|
info->prepared = true;
|
|
goto cleanup;
|
|
}
|
|
# endif /* !WITH_NBDKIT */
|
|
|
|
if (info->arch != VIR_ARCH_NONE && info->arch != VIR_ARCH_X86_64)
|
|
qemuTestSetHostArch(&driver, info->arch);
|
|
|
|
if (info->args.capsHostCPUModel) {
|
|
virCPUDef *hostCPUModel = qemuTestGetCPUDef(info->args.capsHostCPUModel);
|
|
|
|
qemuTestSetHostCPU(&driver, driver.hostarch, hostCPUModel);
|
|
testUpdateQEMUCapsHostCPUModel(info->qemuCaps, driver.hostarch);
|
|
}
|
|
|
|
if (testCheckExclusiveFlags(info->flags) < 0)
|
|
goto cleanup;
|
|
|
|
virFileCacheClear(driver.qemuCapsCache);
|
|
|
|
if (qemuTestCapsCacheInsert(driver.qemuCapsCache, info->qemuCaps) < 0)
|
|
goto cleanup;
|
|
|
|
if (!(info->flags & FLAG_ALLOW_MISSING_INPUT) &&
|
|
!virFileExists(info->infile)) {
|
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
"Input file '%s' not found", info->infile);
|
|
goto cleanup;
|
|
}
|
|
|
|
if (!(def = virDomainDefParseFile(info->infile, driver.xmlopt, NULL,
|
|
info->parseFlags | VIR_DOMAIN_DEF_PARSE_INACTIVE))) {
|
|
virError *err = virGetLastError();
|
|
|
|
if (!err) {
|
|
VIR_TEST_DEBUG("no error was reported for expected parse error");
|
|
goto cleanup;
|
|
}
|
|
|
|
if (info->flags & FLAG_EXPECT_PARSE_ERROR) {
|
|
g_autoptr(GString) errstr = g_string_new(NULLSTR(err->message));
|
|
|
|
g_string_replace(errstr, abs_srcdir, "ABS_SRCDIR", 0);
|
|
g_string_append_c(errstr, '\n');
|
|
|
|
if (virTestCompareToFile(errstr->str, info->errfile) >= 0) {
|
|
info->prep_skip = true;
|
|
}
|
|
}
|
|
|
|
goto cleanup;
|
|
}
|
|
|
|
if (info->flags & FLAG_EXPECT_PARSE_ERROR) {
|
|
VIR_TEST_DEBUG("passed instead of expected parse error");
|
|
goto cleanup;
|
|
}
|
|
|
|
info->def = g_steal_pointer(&def);
|
|
|
|
cleanup:
|
|
/* definition is present and correct, return true to signal that caller can continue */
|
|
if (info->def) {
|
|
info->prepared = true;
|
|
return true;
|
|
}
|
|
|
|
/* definition is not present, but failure was expected */
|
|
if (info->prep_skip) {
|
|
/* first time we report success, any subsequent time EXIT_AM_SKIP */
|
|
if (!info->prepared)
|
|
*rv = 0;
|
|
else
|
|
*rv = EXIT_AM_SKIP;
|
|
} else {
|
|
/* any other failure always results in error in all invocations
|
|
* so that the user will see all the failures in the final error
|
|
* message which is suggesting a VIR_TEST_RANGE-limited run for
|
|
* debugging. */
|
|
*rv = -1;
|
|
|
|
/* report replacement error on subsequent runs */
|
|
if (!info->prepared)
|
|
VIR_TEST_VERBOSE("error from testQemuConfXMLCommon() was reported in the first invocation");
|
|
}
|
|
|
|
info->prepared = true;
|
|
/* caller is not expected to run tests */
|
|
return false;
|
|
}
|
|
|
|
|
|
static int
|
|
testCompareDef2XML(const void *data)
|
|
{
|
|
testQemuInfo *info = (void *) data;
|
|
g_autofree char *actual = NULL;
|
|
unsigned int format_flags = VIR_DOMAIN_DEF_FORMAT_SECURE;
|
|
int rc = 0;
|
|
|
|
if (!testQemuConfXMLCommon(info, &rc))
|
|
return rc;
|
|
|
|
/* we deliberately format the XML as live to catch potential test regressions
|
|
* as virDomainDefFormatInternalSetRootName implies _INACTIVE if 'def->id'
|
|
* is -1, thus VM is inactive. */
|
|
if (!(actual = virDomainDefFormat(info->def, driver.xmlopt, format_flags)))
|
|
return -1;
|
|
|
|
if (virTestCompareToFile(actual, info->out_xml_inactive) < 0)
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static int
|
|
testCompareOutXML2XML(const void *data)
|
|
{
|
|
testQemuInfo *info = (void *) data;
|
|
g_autofree char *actual = NULL;
|
|
g_autoptr(virDomainDef) outdef = NULL;
|
|
unsigned int format_flags = VIR_DOMAIN_DEF_FORMAT_SECURE;
|
|
int rc = 0;
|
|
|
|
if (!testQemuConfXMLCommon(info, &rc))
|
|
return rc;
|
|
|
|
/* parsing of the file produced by libvirt MUST succeed */
|
|
if (!(outdef = virDomainDefParseFile(info->out_xml_inactive, driver.xmlopt, NULL,
|
|
info->parseFlags | VIR_DOMAIN_DEF_PARSE_INACTIVE))) {
|
|
VIR_TEST_VERBOSE("failed to parse '%s'", info->out_xml_inactive);
|
|
return -1;
|
|
}
|
|
|
|
/* we deliberately format the XML as live to catch potential test regressions
|
|
* as virDomainDefFormatInternalSetRootName implies _INACTIVE if 'def->id'
|
|
* is -1, thus VM is inactive. */
|
|
if (!(actual = virDomainDefFormat(outdef, driver.xmlopt, format_flags)))
|
|
return -1;
|
|
|
|
if (virTestCompareToFile(actual, info->out_xml_inactive) < 0)
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static int
|
|
testCompareXMLToArgv(const void *data)
|
|
{
|
|
testQemuInfo *info = (void *) data;
|
|
g_autofree char *migrateURI = NULL;
|
|
g_auto(virBuffer) actualBuf = VIR_BUFFER_INITIALIZER;
|
|
g_autofree char *actualargv = NULL;
|
|
unsigned int flags = info->flags;
|
|
int ret = -1;
|
|
virDomainObj *vm = NULL;
|
|
virDomainChrSourceDef monitor_chr = { 0 };
|
|
virError *err = NULL;
|
|
g_autofree char *log = NULL;
|
|
g_autoptr(virCommand) cmd = NULL;
|
|
qemuDomainObjPrivate *priv = NULL;
|
|
g_autoptr(virIdentity) sysident = virIdentityGetSystem();
|
|
int rc = 0;
|
|
|
|
if (!testQemuConfXMLCommon(info, &rc))
|
|
return rc;
|
|
|
|
if (virIdentitySetCurrent(sysident) < 0)
|
|
goto cleanup;
|
|
|
|
if (info->nbdkitCaps) {
|
|
if (virFileCacheInsertData(driver.nbdkitCapsCache, TEST_NBDKIT_PATH,
|
|
g_object_ref(info->nbdkitCaps)) < 0) {
|
|
g_object_unref(info->nbdkitCaps);
|
|
goto cleanup;
|
|
}
|
|
}
|
|
|
|
if (info->migrateFrom &&
|
|
!(migrateURI = qemuMigrationDstGetURI(info->migrateFrom,
|
|
info->migrateFd)))
|
|
goto cleanup;
|
|
|
|
if (!(vm = virDomainObjNew(driver.xmlopt)))
|
|
goto cleanup;
|
|
|
|
vm->def = info->def;
|
|
priv = vm->privateData;
|
|
|
|
if (info->args.fds) {
|
|
g_clear_pointer(&priv->fds, g_hash_table_unref);
|
|
priv->fds = g_steal_pointer(&info->args.fds);
|
|
}
|
|
|
|
if (virBitmapParse("0-3", &priv->autoNodeset, 4) < 0)
|
|
goto cleanup;
|
|
|
|
if (!virDomainDefCheckABIStability(vm->def, vm->def, driver.xmlopt)) {
|
|
VIR_TEST_DEBUG("ABI stability check failed on %s", info->infile);
|
|
goto cleanup;
|
|
}
|
|
|
|
vm->def->id = -1;
|
|
|
|
if (qemuProcessPrepareMonitorChr(&monitor_chr, priv->libDir) < 0)
|
|
goto cleanup;
|
|
|
|
virResetLastError();
|
|
|
|
if (!(cmd = testCompareXMLToArgvCreateArgs(&driver, vm, migrateURI, info,
|
|
flags))) {
|
|
err = virGetLastError();
|
|
if (!err) {
|
|
VIR_TEST_DEBUG("no error was reported for expected failure");
|
|
goto cleanup;
|
|
}
|
|
if (flags & FLAG_EXPECT_FAILURE) {
|
|
g_autofree char *tmperr = g_strdup_printf("%s\n", NULLSTR(err->message));
|
|
if (virTestCompareToFile(tmperr, info->errfile) >= 0)
|
|
goto ok;
|
|
}
|
|
goto cleanup;
|
|
}
|
|
if (flags & FLAG_EXPECT_FAILURE) {
|
|
VIR_TEST_DEBUG("passed instead of expected failure");
|
|
goto cleanup;
|
|
}
|
|
|
|
if (testCompareXMLToArgvValidateSchema(cmd, info) < 0)
|
|
goto cleanup;
|
|
|
|
if (virCommandToStringBuf(cmd, &actualBuf, true, false) < 0)
|
|
goto cleanup;
|
|
|
|
virBufferAddLit(&actualBuf, "\n");
|
|
actualargv = virBufferContentAndReset(&actualBuf);
|
|
|
|
if (virTestCompareToFileFull(actualargv, info->outfile, false) < 0)
|
|
goto cleanup;
|
|
|
|
ret = 0;
|
|
|
|
ok:
|
|
if (ret == 0 && flags & FLAG_EXPECT_FAILURE) {
|
|
ret = -1;
|
|
VIR_TEST_DEBUG("Error expected but there wasn't any.");
|
|
goto cleanup;
|
|
}
|
|
if (flags & FLAG_EXPECT_FAILURE) {
|
|
if ((log = virTestLogContentAndReset()))
|
|
VIR_TEST_DEBUG("Got expected error: \n%s", log);
|
|
}
|
|
virResetLastError();
|
|
ret = 0;
|
|
|
|
cleanup:
|
|
/* clear overriden host cpu */
|
|
if (info->args.capsHostCPUModel)
|
|
qemuTestSetHostCPU(&driver, driver.hostarch, NULL);
|
|
virDomainChrSourceDefClear(&monitor_chr);
|
|
if (vm) {
|
|
vm->def = NULL;
|
|
virObjectUnref(vm);
|
|
}
|
|
virIdentitySetCurrent(NULL);
|
|
if (info->arch != VIR_ARCH_NONE && info->arch != VIR_ARCH_X86_64)
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_NONE);
|
|
|
|
return ret;
|
|
}
|
|
|
|
|
|
static int
|
|
testConfXMLCheck(GHashTable *existingTestCases)
|
|
{
|
|
g_autofree virHashKeyValuePair *items = virHashGetItems(existingTestCases, NULL, true);
|
|
size_t i;
|
|
int ret = 0;
|
|
|
|
for (i = 0; items[i].key; i++) {
|
|
if (ret == 0)
|
|
fprintf(stderr, "\n");
|
|
|
|
fprintf(stderr, "unused file: %s\n", (const char *) items[i].key);
|
|
ret = -1;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
|
|
static int
|
|
testConfXMLEnumerate(GHashTable *existingTestCases)
|
|
{
|
|
struct dirent *ent;
|
|
g_autoptr(DIR) dir = NULL;
|
|
int rc;
|
|
|
|
/* If VIR_TEST_RANGE is in use don't bother filling in the data, which
|
|
* also makes testConfXMLCheck succeed. */
|
|
if (virTestHasRangeBitmap())
|
|
return 0;
|
|
|
|
if (virDirOpen(&dir, abs_srcdir "/qemuxmlconfdata") < 0)
|
|
return -1;
|
|
|
|
while ((rc = virDirRead(dir, &ent, abs_srcdir "/qemuxmlconfdata")) > 0) {
|
|
if (virStringHasSuffix(ent->d_name, ".xml") ||
|
|
virStringHasSuffix(ent->d_name, ".args") ||
|
|
virStringHasSuffix(ent->d_name, ".err")) {
|
|
g_hash_table_insert(existingTestCases,
|
|
g_strdup_printf(abs_srcdir "/qemuxmlconfdata/%s", ent->d_name),
|
|
NULL);
|
|
}
|
|
}
|
|
|
|
return rc;
|
|
}
|
|
|
|
|
|
static int
|
|
testXMLParse(const void *data)
|
|
{
|
|
testQemuInfo *info = (void *) data;
|
|
int rc = 0;
|
|
|
|
testQemuConfXMLCommon(info, &rc);
|
|
|
|
return rc;
|
|
}
|
|
|
|
|
|
static void
|
|
testRun(const char *name,
|
|
const char *suffix,
|
|
int *ret,
|
|
struct testQemuConf *testConf,
|
|
...)
|
|
{
|
|
g_autofree char *name_parse = g_strdup_printf("QEMU XML def parse %s%s", name, suffix);
|
|
g_autofree char *name_xml = g_strdup_printf("QEMU XML def -> XML %s%s", name, suffix);
|
|
g_autofree char *name_outxml = g_strdup_printf("QEMU XML OUT -> XML %s%s", name, suffix);
|
|
g_autofree char *name_argv = g_strdup_printf("QEMU XML def -> ARGV %s%s", name, suffix);
|
|
g_autoptr(testQemuInfo) info = g_new0(testQemuInfo, 1);
|
|
va_list ap;
|
|
|
|
info->name = name;
|
|
info->conf = testConf;
|
|
|
|
va_start(ap, testConf);
|
|
testQemuInfoSetArgs(info, ap);
|
|
va_end(ap);
|
|
|
|
info->infile = g_strdup_printf("%s/qemuxmlconfdata/%s.xml", abs_srcdir, info->name);
|
|
if (info->flags & (FLAG_EXPECT_FAILURE | FLAG_EXPECT_PARSE_ERROR)) {
|
|
info->errfile = g_strdup_printf("%s/qemuxmlconfdata/%s%s.err", abs_srcdir, info->name, suffix);
|
|
} else {
|
|
info->outfile = g_strdup_printf("%s/qemuxmlconfdata/%s%s.args", abs_srcdir, info->name, suffix);
|
|
}
|
|
|
|
if (!(info->flags & FLAG_EXPECT_PARSE_ERROR))
|
|
info->out_xml_inactive = g_strdup_printf("%s/qemuxmlconfdata/%s%s.xml", abs_srcdir, info->name, suffix);
|
|
|
|
virTestRunLog(ret, name_parse, testXMLParse, info);
|
|
virTestRunLog(ret, name_xml, testCompareDef2XML, info);
|
|
virTestRunLog(ret, name_outxml, testCompareOutXML2XML, info);
|
|
virTestRunLog(ret, name_argv, testCompareXMLToArgv, info);
|
|
|
|
/* clear overriden host cpu */
|
|
if (info->args.capsHostCPUModel)
|
|
qemuTestSetHostCPU(&driver, driver.hostarch, NULL);
|
|
if (info->arch != VIR_ARCH_NONE && info->arch != VIR_ARCH_X86_64)
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_NONE);
|
|
}
|
|
|
|
|
|
static int
|
|
mymain(void)
|
|
{
|
|
int ret = 0;
|
|
g_autoptr(virConnect) conn = NULL;
|
|
g_autoptr(GHashTable) duplicateTests = virHashNew(NULL);
|
|
g_autoptr(GHashTable) existingTestCases = virHashNew(NULL);
|
|
g_autoptr(GHashTable) capslatest = testQemuGetLatestCaps();
|
|
g_autoptr(GHashTable) qapiSchemaCache = virHashNew((GDestroyNotify) g_hash_table_unref);
|
|
g_autoptr(GHashTable) capscache = virHashNew(virObjectUnref);
|
|
struct testQemuConf testConf = { .capslatest = capslatest,
|
|
.capscache = capscache,
|
|
.qapiSchemaCache = qapiSchemaCache,
|
|
.duplicateTests = duplicateTests,
|
|
.existingTestCases = existingTestCases };
|
|
|
|
if (!capslatest)
|
|
return EXIT_FAILURE;
|
|
|
|
/* enumerate and store all available test cases to verify at the end that
|
|
* all of them were invoked */
|
|
if (testConfXMLEnumerate(existingTestCases) < 0)
|
|
return EXIT_FAILURE;
|
|
|
|
/* Set the timezone because we are mocking the time() function.
|
|
* If we don't do that, then localtime() may return unpredictable
|
|
* results. In order to detect things that just work by a blind
|
|
* chance, we need to set an virtual timezone that no libvirt
|
|
* developer resides in. */
|
|
if (g_setenv("TZ", "VIR00:30", TRUE) == FALSE) {
|
|
perror("g_setenv");
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
if (qemuTestDriverInit(&driver) < 0)
|
|
return EXIT_FAILURE;
|
|
|
|
virFileWrapperAddPrefix("/sys/devices/system",
|
|
abs_srcdir "/vircaps2xmldata/linux-basic/system");
|
|
virFileWrapperAddPrefix(SYSCONFDIR "/qemu/firmware",
|
|
abs_srcdir "/qemufirmwaredata/etc/qemu/firmware");
|
|
virFileWrapperAddPrefix(PREFIX "/share/qemu/firmware",
|
|
abs_srcdir "/qemufirmwaredata/usr/share/qemu/firmware");
|
|
virFileWrapperAddPrefix("/home/user/.config/qemu/firmware",
|
|
abs_srcdir "/qemufirmwaredata/home/user/.config/qemu/firmware");
|
|
|
|
virFileWrapperAddPrefix(SYSCONFDIR "/qemu/vhost-user",
|
|
abs_srcdir "/qemuvhostuserdata/etc/qemu/vhost-user");
|
|
virFileWrapperAddPrefix(PREFIX "/share/qemu/vhost-user",
|
|
abs_srcdir "/qemuvhostuserdata/usr/share/qemu/vhost-user");
|
|
virFileWrapperAddPrefix("/home/user/.config/qemu/vhost-user",
|
|
abs_srcdir "/qemuvhostuserdata/home/user/.config/qemu/vhost-user");
|
|
|
|
virFileWrapperAddPrefix("/usr/libexec/qemu/vhost-user",
|
|
abs_srcdir "/qemuvhostuserdata/usr/libexec/qemu/vhost-user");
|
|
virFileWrapperAddPrefix("/usr/libexec/virtiofsd",
|
|
abs_srcdir "/qemuvhostuserdata/usr/libexec/qemu/vhost-user/test-virtiofsd");
|
|
|
|
if (!(conn = virGetConnect()))
|
|
return EXIT_FAILURE;
|
|
|
|
conn->secretDriver = &fakeSecretDriver;
|
|
conn->storageDriver = &fakeStorageDriver;
|
|
conn->nwfilterDriver = &fakeNWFilterDriver;
|
|
conn->networkDriver = &fakeNetworkDriver;
|
|
|
|
virSetConnectInterface(conn);
|
|
virSetConnectNetwork(conn);
|
|
virSetConnectNWFilter(conn);
|
|
virSetConnectNodeDev(conn);
|
|
virSetConnectSecret(conn);
|
|
virSetConnectStorage(conn);
|
|
|
|
/**
|
|
* The following set of macros allows testing of XML -> argv conversion with a
|
|
* real set of capabilities gathered from a real qemu copy. It is desired to use
|
|
* these for positive test cases as it provides combinations of flags which
|
|
* can be met in real life.
|
|
*
|
|
* The capabilities are taken from the real capabilities stored in
|
|
* tests/qemucapabilitiesdata.
|
|
*
|
|
* It is suggested to use the DO_TEST_CAPS_LATEST macro which always takes the
|
|
* most recent capability set. In cases when the new code would change behaviour
|
|
* the test cases should be forked using DO_TEST_CAPS_VER with the appropriate
|
|
* version.
|
|
*/
|
|
# define DO_TEST_FULL(_name, _suffix, ...) \
|
|
testRun(_name, _suffix, &ret, &testConf, __VA_ARGS__);
|
|
|
|
# define DO_TEST_CAPS_INTERNAL(name, arch, ver, ...) \
|
|
DO_TEST_FULL(name, "." arch "-" ver, \
|
|
ARG_CAPS_ARCH, arch, \
|
|
ARG_CAPS_VER, ver, \
|
|
__VA_ARGS__, \
|
|
ARG_END)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST_FULL(name, arch, ...) \
|
|
DO_TEST_CAPS_INTERNAL(name, arch, "latest", __VA_ARGS__)
|
|
|
|
# define DO_TEST_CAPS_ARCH_VER_FULL(name, arch, ver, ...) \
|
|
DO_TEST_CAPS_INTERNAL(name, arch, ver, __VA_ARGS__)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST(name, arch) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL(name, arch, ARG_END)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE(name, arch) \
|
|
DO_TEST_FULL(name, "." arch "-latest.abi-update", \
|
|
ARG_CAPS_ARCH, arch, \
|
|
ARG_CAPS_VER, "latest", \
|
|
ARG_PARSEFLAGS, VIR_DOMAIN_DEF_PARSE_ABI_UPDATE, \
|
|
ARG_END)
|
|
|
|
# define DO_TEST_CAPS_ARCH_VER(name, arch, ver) \
|
|
DO_TEST_CAPS_ARCH_VER_FULL(name, arch, ver, ARG_END)
|
|
|
|
# define DO_TEST_CAPS_LATEST_NBDKIT(name, ...) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL(name, "x86_64", ARG_NBDKIT_CAPS, __VA_ARGS__, QEMU_NBDKIT_CAPS_LAST, ARG_END)
|
|
|
|
# define DO_TEST_CAPS_LATEST(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST(name, "x86_64")
|
|
|
|
# define DO_TEST_CAPS_LATEST_ABI_UPDATE(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE(name, "x86_64")
|
|
|
|
# define DO_TEST_CAPS_VER(name, ver) \
|
|
DO_TEST_CAPS_ARCH_VER(name, "x86_64", ver)
|
|
|
|
# define DO_TEST_CAPS_LATEST_PPC64(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST(name, "ppc64")
|
|
|
|
# define DO_TEST_CAPS_LATEST_PPC64_HOSTCPU(name, hostcpu) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL(name, "ppc64", \
|
|
ARG_CAPS_HOST_CPU_MODEL, hostcpu)
|
|
|
|
# define DO_TEST_CAPS_LATEST_PPC64_HOSTCPU_FAILURE(name, hostcpu) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL(name, "ppc64", \
|
|
ARG_CAPS_HOST_CPU_MODEL, hostcpu, \
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST_FAILURE(name, arch) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL(name, arch, \
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE_FAILURE(name, arch) \
|
|
DO_TEST_FULL(name, "." arch "-latest.abi-update", \
|
|
ARG_CAPS_ARCH, arch, \
|
|
ARG_CAPS_VER, "latest", \
|
|
ARG_PARSEFLAGS, VIR_DOMAIN_DEF_PARSE_ABI_UPDATE, \
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE, \
|
|
ARG_END)
|
|
|
|
# define DO_TEST_CAPS_ARCH_VER_FAILURE(name, arch, ver) \
|
|
DO_TEST_CAPS_ARCH_VER_FULL(name, arch, ver, \
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE)
|
|
|
|
# define DO_TEST_CAPS_LATEST_FAILURE(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FAILURE(name, "x86_64")
|
|
|
|
# define DO_TEST_CAPS_LATEST_ABI_UPDATE_FAILURE(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE_FAILURE(name, "x86_64")
|
|
|
|
# define DO_TEST_CAPS_VER_FAILURE(name, ver) \
|
|
DO_TEST_CAPS_ARCH_VER_FAILURE(name, "x86_64", ver)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR(name, arch) \
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL(name, arch, \
|
|
ARG_FLAGS, FLAG_EXPECT_PARSE_ERROR)
|
|
|
|
# define DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE_PARSE_ERROR(name, arch) \
|
|
DO_TEST_FULL(name, "." arch "-latest.abi-update", \
|
|
ARG_CAPS_ARCH, arch, \
|
|
ARG_CAPS_VER, "latest", \
|
|
ARG_PARSEFLAGS, VIR_DOMAIN_DEF_PARSE_ABI_UPDATE, \
|
|
ARG_FLAGS, FLAG_EXPECT_PARSE_ERROR, \
|
|
ARG_END)
|
|
|
|
# define DO_TEST_CAPS_ARCH_VER_PARSE_ERROR(name, arch, ver) \
|
|
DO_TEST_CAPS_ARCH_VER_FULL(name, arch, ver, \
|
|
ARG_FLAGS, FLAG_EXPECT_PARSE_ERROR)
|
|
|
|
# define DO_TEST_CAPS_LATEST_PARSE_ERROR(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR(name, "x86_64")
|
|
|
|
# define DO_TEST_CAPS_LATEST_ABI_UPDATE_PARSE_ERROR(name) \
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE_PARSE_ERROR(name, "x86_64")
|
|
|
|
# define DO_TEST_CAPS_VER_PARSE_ERROR(name, ver) \
|
|
DO_TEST_CAPS_ARCH_VER_PARSE_ERROR(name, "x86_64", ver)
|
|
|
|
# define DO_TEST_GIC(name, ver, gic) \
|
|
DO_TEST_CAPS_ARCH_VER_FULL(name, "aarch64", ver, ARG_GIC, gic, ARG_FLAGS, FLAG_ALLOW_DUPLICATE_OUTPUT, ARG_END)
|
|
|
|
/* Unset or set all envvars here that are copied in qemudBuildCommandLine
|
|
* using ADD_ENV_COPY, otherwise these tests may fail due to unexpected
|
|
* values for these envvars */
|
|
g_setenv("PATH", "/bin", TRUE);
|
|
g_setenv("USER", "test", TRUE);
|
|
g_setenv("LOGNAME", "test", TRUE);
|
|
g_setenv("HOME", "/home/test", TRUE);
|
|
g_setenv("LC_ALL", "C", TRUE);
|
|
g_unsetenv("TMPDIR");
|
|
g_unsetenv("LD_PRELOAD");
|
|
g_unsetenv("LD_LIBRARY_PATH");
|
|
g_unsetenv("DYLD_INSERT_LIBRARIES");
|
|
g_unsetenv("DYLD_FORCE_FLAT_NAMESPACE");
|
|
g_unsetenv("QEMU_AUDIO_DRV");
|
|
g_unsetenv("SDL_AUDIODRIVER");
|
|
g_unsetenv("PIPEWIRE_CORE");
|
|
g_unsetenv("PIPEWIRE_REMOTE");
|
|
g_unsetenv("PIPEWIRE_RUNTIME_DIR");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("nonexistent-file", "x86_64",
|
|
ARG_FLAGS, FLAG_EXPECT_PARSE_ERROR | FLAG_ALLOW_MISSING_INPUT);
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("broken-xml-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST("x86_64-pc-minimal");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("x86_64-pc-minimal");
|
|
DO_TEST_CAPS_LATEST("x86_64-q35-minimal");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("x86_64-q35-minimal");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("aarch64-virt-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-versatilepb-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("aarch64-versatilepb-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("armv7l-versatilepb-minimal", "armv7l");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("armv7l-versatilepb-minimal", "armv7l");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-realview-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("aarch64-realview-minimal", "aarch64");
|
|
/* The '-nousb' test case tests machine without a built-in USB controller */
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-nousb-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("aarch64-nousb-minimal", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("loongarch64-virt-minimal", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("loongarch64-virt-minimal", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("riscv64-virt-minimal", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("riscv64-virt-minimal", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-pseries-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("ppc64-pseries-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-g3beige-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("ppc64-g3beige-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-mac99-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("ppc64-mac99-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc-mac99-minimal", "ppc");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("ppc-mac99-minimal", "ppc");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-powernv9-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("ppc64-powernv9-minimal", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390x-ccw-minimal", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("s390x-ccw-minimal", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("x86_64-pc-default-models");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("x86_64-pc-default-models");
|
|
DO_TEST_CAPS_LATEST("x86_64-q35-default-models");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("x86_64-q35-default-models");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-default-models", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("aarch64-virt-default-models", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("loongarch64-virt-default-models", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("loongarch64-virt-default-models", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("riscv64-virt-default-models", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("riscv64-virt-default-models", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-pseries-default-models", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("ppc64-pseries-default-models", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390x-ccw-default-models", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("s390x-ccw-default-models", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("no-memory");
|
|
|
|
DO_TEST_CAPS_LATEST("genid");
|
|
DO_TEST_CAPS_LATEST("genid-auto");
|
|
|
|
DO_TEST_CAPS_LATEST("machine-aliases1");
|
|
DO_TEST_CAPS_LATEST("machine-aliases2");
|
|
DO_TEST_CAPS_LATEST("machine-core-on");
|
|
driver.config->dumpGuestCore = true;
|
|
DO_TEST_CAPS_LATEST("machine-core-off");
|
|
driver.config->dumpGuestCore = false;
|
|
DO_TEST_CAPS_LATEST("machine-smm-on");
|
|
DO_TEST_CAPS_LATEST("machine-smm-off");
|
|
DO_TEST_CAPS_LATEST("machine-vmport-opt");
|
|
DO_TEST_CAPS_LATEST("machine-i8042-on");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("machine-i8042-on", "6.2.0");
|
|
DO_TEST_CAPS_LATEST("machine-i8042-off");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("machine-i8042-off", "6.2.0");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("machine-i8042-off-vmport-on");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("machine-i8042-off-explicit-ps2-inputs");
|
|
DO_TEST_CAPS_LATEST("default-kvm-host-arch");
|
|
DO_TEST_CAPS_LATEST("default-qemu-host-arch");
|
|
DO_TEST_CAPS_LATEST("x86-kvm-32-on-64");
|
|
DO_TEST_CAPS_LATEST("boot-cdrom");
|
|
DO_TEST_CAPS_LATEST("boot-network");
|
|
DO_TEST_CAPS_LATEST("boot-floppy");
|
|
DO_TEST_CAPS_LATEST("boot-floppy-q35");
|
|
DO_TEST_CAPS_LATEST("boot-multi");
|
|
DO_TEST_CAPS_LATEST("boot-menu-enable");
|
|
DO_TEST_CAPS_LATEST("boot-menu-enable-with-timeout");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("boot-menu-enable-with-timeout-invalid");
|
|
DO_TEST_CAPS_LATEST("boot-menu-disable");
|
|
DO_TEST_CAPS_LATEST("boot-menu-disable-drive");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("boot-dev+order");
|
|
DO_TEST_CAPS_LATEST("boot-order");
|
|
DO_TEST_CAPS_LATEST("boot-complex");
|
|
|
|
DO_TEST_CAPS_LATEST("audio-none-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-alsa-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-coreaudio-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-jack-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-oss-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-pulseaudio-minimal");
|
|
g_setenv("PIPEWIRE_RUNTIME_DIR", "/run/user/1000", TRUE);
|
|
DO_TEST_CAPS_LATEST("audio-pipewire-minimal");
|
|
g_unsetenv("PIPEWIRE_RUNTIME_DIR");
|
|
DO_TEST_CAPS_LATEST("audio-sdl-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-spice-minimal");
|
|
DO_TEST_CAPS_LATEST("audio-file-minimal");
|
|
|
|
DO_TEST_CAPS_LATEST("audio-none-best");
|
|
DO_TEST_CAPS_LATEST("audio-alsa-best");
|
|
DO_TEST_CAPS_LATEST("audio-coreaudio-best");
|
|
DO_TEST_CAPS_LATEST("audio-oss-best");
|
|
DO_TEST_CAPS_LATEST("audio-pulseaudio-best");
|
|
DO_TEST_CAPS_LATEST("audio-pipewire-best");
|
|
DO_TEST_CAPS_LATEST("audio-sdl-best");
|
|
DO_TEST_CAPS_LATEST("audio-spice-best");
|
|
DO_TEST_CAPS_LATEST("audio-file-best");
|
|
|
|
DO_TEST_CAPS_LATEST("audio-none-full");
|
|
DO_TEST_CAPS_LATEST("audio-alsa-full");
|
|
DO_TEST_CAPS_LATEST("audio-coreaudio-full");
|
|
DO_TEST_CAPS_LATEST("audio-jack-full");
|
|
DO_TEST_CAPS_LATEST("audio-oss-full");
|
|
DO_TEST_CAPS_LATEST("audio-pulseaudio-full");
|
|
DO_TEST_CAPS_LATEST("audio-pipewire-full");
|
|
DO_TEST_CAPS_LATEST("audio-sdl-full");
|
|
DO_TEST_CAPS_LATEST("audio-spice-full");
|
|
DO_TEST_CAPS_LATEST("audio-file-full");
|
|
|
|
g_setenv("PIPEWIRE_RUNTIME_DIR", "/run/user/1000", TRUE);
|
|
DO_TEST_CAPS_LATEST("audio-many-backends");
|
|
g_unsetenv("PIPEWIRE_RUNTIME_DIR");
|
|
|
|
/* Validate auto-creation of <audio> for legacy compat */
|
|
g_setenv("QEMU_AUDIO_DRV", "sdl", TRUE);
|
|
g_setenv("SDL_AUDIODRIVER", "esd", TRUE);
|
|
DO_TEST_CAPS_LATEST("audio-default-sdl");
|
|
g_unsetenv("QEMU_AUDIO_DRV");
|
|
g_unsetenv("SDL_AUDIODRIVER");
|
|
|
|
g_setenv("QEMU_AUDIO_DRV", "alsa", TRUE);
|
|
driver.config->vncAllowHostAudio = true;
|
|
DO_TEST_CAPS_LATEST("audio-default-vnc");
|
|
driver.config->vncAllowHostAudio = false;
|
|
g_unsetenv("QEMU_AUDIO_DRV");
|
|
|
|
DO_TEST_CAPS_LATEST("audio-default-spice");
|
|
|
|
g_setenv("QEMU_AUDIO_DRV", "alsa", TRUE);
|
|
driver.config->nogfxAllowHostAudio = true;
|
|
DO_TEST_CAPS_LATEST("audio-default-nographics");
|
|
driver.config->nogfxAllowHostAudio = false;
|
|
g_unsetenv("QEMU_AUDIO_DRV");
|
|
|
|
DO_TEST_CAPS_LATEST("reboot-timeout-disabled");
|
|
DO_TEST_CAPS_LATEST("reboot-timeout-enabled");
|
|
|
|
DO_TEST_CAPS_LATEST("firmware-manual-bios");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-bios-stateless");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-manual-bios-not-stateless");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-features");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE_PARSE_ERROR("firmware-manual-efi-features");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-rw");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-rw-legacy-paths");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-rw-modern-paths");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-rw-implicit");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-loader-secure");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-manual-efi-loader-no-path");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-loader-path-nonstandard");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-secboot");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-no-enrolled-keys");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-no-secboot");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-stateless");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-nvram-template");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-nvram-template-nonstandard");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-manual-efi-nvram-template-stateless");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-nvram-network-iscsi");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-nvram-network-nbd");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-nvram-file");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-manual-efi-nvram-stateless");
|
|
|
|
/* Make sure all combinations of ACPI and UEFI behave as expected */
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-manual-efi-acpi-aarch64", "aarch64");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-acpi-q35");
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-manual-efi-noacpi-aarch64", "aarch64");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-manual-efi-noacpi-q35");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("firmware-manual-noefi-acpi-aarch64", "aarch64");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-noefi-acpi-q35");
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-manual-noefi-noacpi-aarch64", "aarch64");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-noefi-noacpi-q35");
|
|
|
|
/* Ensure that legacy firmware paths keep working */
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-secboot-legacy-paths");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-no-enrolled-keys-legacy-paths");
|
|
DO_TEST_CAPS_LATEST("firmware-manual-efi-no-secboot-legacy-paths");
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-manual-efi-aarch64-legacy-paths", "aarch64");
|
|
|
|
DO_TEST_CAPS_LATEST("firmware-auto-bios");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-bios-stateless");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-auto-bios-not-stateless");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-auto-bios-nvram");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("firmware-auto-efi");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-stateless");
|
|
DO_TEST_CAPS_LATEST_FAILURE("firmware-auto-efi-rw");
|
|
DO_TEST_CAPS_LATEST_FAILURE("firmware-auto-efi-rw-pflash");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-loader-secure");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("firmware-auto-efi-loader-secure");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-loader-insecure");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-loader-path");
|
|
DO_TEST_CAPS_LATEST_FAILURE("firmware-auto-efi-loader-path-nonstandard");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-secboot");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-no-secboot");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-enrolled-keys");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-no-enrolled-keys");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("firmware-auto-efi-enrolled-keys-no-secboot");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-smm-off");
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-auto-efi-aarch64", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("firmware-auto-efi-aarch64", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-auto-efi-loongarch64", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("firmware-auto-efi-loongarch64", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("firmware-auto-efi-riscv64", "riscv64");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-nvram-path");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-nvram-template");
|
|
DO_TEST_CAPS_LATEST_FAILURE("firmware-auto-efi-nvram-template-nonstandard");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-nvram-file");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-nvram-network-nbd");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-nvram-network-iscsi");
|
|
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-format-loader-qcow2");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-format-loader-qcow2-nvram-path");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-format-nvram-qcow2");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-format-nvram-qcow2-path");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-format-nvram-qcow2-network-nbd");
|
|
DO_TEST_CAPS_ARCH_LATEST("firmware-auto-efi-format-loader-raw", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("firmware-auto-efi-format-loader-raw", "aarch64");
|
|
DO_TEST_CAPS_LATEST("firmware-auto-efi-format-mismatch");
|
|
|
|
DO_TEST_CAPS_LATEST("clock-utc");
|
|
DO_TEST_CAPS_LATEST("clock-localtime");
|
|
DO_TEST_CAPS_LATEST("clock-localtime-basis-localtime");
|
|
DO_TEST_CAPS_LATEST("clock-variable");
|
|
DO_TEST_CAPS_LATEST("clock-france");
|
|
DO_TEST_CAPS_VER("clock-hpet-off", "7.2.0");
|
|
DO_TEST_CAPS_LATEST("clock-hpet-off");
|
|
DO_TEST_CAPS_LATEST("clock-catchup");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-kvmclock", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_LATEST("cpu-host-kvmclock");
|
|
DO_TEST_CAPS_LATEST("kvmclock");
|
|
DO_TEST_CAPS_LATEST("clock-timer-hyperv-rtc");
|
|
DO_TEST_CAPS_LATEST("clock-realtime");
|
|
DO_TEST_CAPS_LATEST("clock-absolute");
|
|
|
|
DO_TEST_CAPS_LATEST("controller-usb-order");
|
|
|
|
DO_TEST_CAPS_LATEST("controller-order");
|
|
/* 'eoi' cpu feature with an explicit CPU defined */
|
|
DO_TEST_CAPS_LATEST("cpu-eoi-disabled");
|
|
DO_TEST_CAPS_LATEST("cpu-eoi-enabled");
|
|
/* 'eoi' cpu feature without an explicit CPU defined */
|
|
DO_TEST_CAPS_LATEST("eoi-disabled");
|
|
DO_TEST_CAPS_LATEST("eoi-enabled");
|
|
DO_TEST_CAPS_LATEST("pv-spinlock-disabled");
|
|
DO_TEST_CAPS_LATEST("pv-spinlock-enabled");
|
|
DO_TEST_CAPS_LATEST("kvmclock+eoi-disabled");
|
|
|
|
DO_TEST_CAPS_LATEST("hyperv");
|
|
DO_TEST_CAPS_LATEST("hyperv-off");
|
|
DO_TEST_CAPS_LATEST("hyperv-panic");
|
|
DO_TEST_CAPS_VER("hyperv-passthrough", "6.1.0");
|
|
DO_TEST_CAPS_LATEST("hyperv-passthrough");
|
|
DO_TEST_CAPS_LATEST("hyperv-stimer-direct");
|
|
|
|
DO_TEST_CAPS_LATEST("kvm-features");
|
|
DO_TEST_CAPS_LATEST("kvm-features-off");
|
|
|
|
DO_TEST_CAPS_LATEST("pmu-feature");
|
|
DO_TEST_CAPS_LATEST("pmu-feature-off");
|
|
|
|
DO_TEST_CAPS_LATEST("pages-discard");
|
|
DO_TEST_CAPS_LATEST("pages-discard-hugepages");
|
|
DO_TEST_CAPS_LATEST("pages-dimm-discard");
|
|
DO_TEST_CAPS_LATEST("hugepages-default");
|
|
DO_TEST_CAPS_LATEST("hugepages-default-2M");
|
|
DO_TEST_CAPS_LATEST("hugepages-default-system-size");
|
|
DO_TEST_CAPS_LATEST_FAILURE("hugepages-default-5M");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hugepages-default-1G-nodeset-2M");
|
|
DO_TEST_CAPS_LATEST("hugepages-nodeset");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hugepages-nodeset-nonexist");
|
|
DO_TEST_CAPS_LATEST("hugepages-numa-default");
|
|
DO_TEST_CAPS_LATEST("hugepages-numa-default-2M");
|
|
DO_TEST_CAPS_LATEST("hugepages-numa-default-dimm");
|
|
DO_TEST_CAPS_LATEST("hugepages-numa-nodeset");
|
|
DO_TEST_CAPS_LATEST("hugepages-numa-nodeset-part");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hugepages-numa-nodeset-nonexist");
|
|
DO_TEST_CAPS_LATEST("hugepages-shared");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hugepages-memaccess-invalid");
|
|
DO_TEST_CAPS_LATEST("hugepages-memaccess");
|
|
DO_TEST_CAPS_LATEST("hugepages-memaccess2");
|
|
DO_TEST_CAPS_LATEST("hugepages-memaccess3");
|
|
DO_TEST_CAPS_LATEST("hugepages-nvdimm");
|
|
DO_TEST_CAPS_LATEST("nosharepages");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("non-x86_64-timer-error", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("disk-cdrom");
|
|
DO_TEST_CAPS_LATEST("disk-cdrom-empty-network-invalid");
|
|
DO_TEST_CAPS_LATEST("disk-cdrom-bus-other");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-cdrom-usb-empty");
|
|
DO_TEST_CAPS_LATEST("disk-cdrom-network");
|
|
DO_TEST_CAPS_LATEST("disk-cdrom-tray");
|
|
DO_TEST_CAPS_LATEST("disk-floppy");
|
|
DO_TEST_CAPS_LATEST("disk-floppy-q35");
|
|
DO_TEST_CAPS_ARCH_LATEST_FAILURE("disk-floppy-pseries", "ppc64");
|
|
DO_TEST_CAPS_LATEST("disk-floppy-tray");
|
|
DO_TEST_CAPS_LATEST("disk-virtio");
|
|
DO_TEST_CAPS_ARCH_LATEST("disk-virtio-ccw", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("disk-virtio-ccw-many", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("disk-virtio-s390-zpci", "s390x");
|
|
DO_TEST_CAPS_LATEST("disk-order");
|
|
DO_TEST_CAPS_LATEST("disk-virtio-queues");
|
|
DO_TEST_CAPS_LATEST("disk-boot-disk");
|
|
DO_TEST_CAPS_LATEST("disk-boot-cdrom");
|
|
DO_TEST_CAPS_LATEST("floppy-drive-fat");
|
|
DO_TEST_CAPS_LATEST("disk-readonly-disk");
|
|
DO_TEST_CAPS_LATEST("disk-fmt-qcow");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-fmt-cow");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-fmt-dir");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-fmt-iso");
|
|
DO_TEST_CAPS_LATEST("disk-shared");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-shared-qcow");
|
|
DO_TEST_CAPS_LATEST("disk-error-policy");
|
|
DO_TEST_CAPS_ARCH_LATEST("disk-error-policy-s390x", "s390x");
|
|
DO_TEST_CAPS_LATEST("disk-cache");
|
|
DO_TEST_CAPS_LATEST("disk-metadata-cache");
|
|
DO_TEST_CAPS_LATEST("disk-transient");
|
|
DO_TEST_CAPS_LATEST("disk-network-nbd");
|
|
DO_TEST_CAPS_LATEST("disk-network-iscsi");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-network-iscsi-auth-secrettype-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-network-iscsi-auth-wrong-secrettype");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-network-source-auth-both");
|
|
/* 'gluster' protocol backend was deprecated in qemu-9.2 */
|
|
DO_TEST_CAPS_VER("disk-network-gluster", "9.1.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-rbd");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("disk-network-rbd-encryption", "6.0.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-rbd-encryption");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("disk-network-rbd-encryption-layering", "7.2.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-rbd-encryption-layering");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("disk-network-rbd-encryption-luks-any", "7.2.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-rbd-encryption-luks-any");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-encryption-wrong");
|
|
DO_TEST_CAPS_LATEST("disk-network-rbd-no-colon");
|
|
/* qemu-6.0 is the last qemu version supporting sheepdog */
|
|
DO_TEST_CAPS_VER("disk-network-sheepdog", "6.0.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-source-auth");
|
|
DO_TEST_CAPS_LATEST("disk-network-source-curl");
|
|
DO_TEST_CAPS_LATEST("disk-network-nfs");
|
|
driver.config->vxhsTLS = 1;
|
|
driver.config->nbdTLSx509secretUUID = g_strdup("6fd3f62d-9fe7-4a4e-a869-7acd6376d8ea");
|
|
driver.config->vxhsTLSx509secretUUID = g_strdup("6fd3f62d-9fe7-4a4e-a869-7acd6376d8ea");
|
|
DO_TEST_CAPS_VER("disk-network-tlsx509-nbd", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-tlsx509-nbd");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("disk-network-tlsx509-nbd-hostname", "6.2.0");
|
|
DO_TEST_CAPS_LATEST("disk-network-tlsx509-nbd-hostname");
|
|
DO_TEST_CAPS_LATEST("disk-network-http");
|
|
VIR_FREE(driver.config->nbdTLSx509secretUUID);
|
|
VIR_FREE(driver.config->vxhsTLSx509secretUUID);
|
|
driver.config->vxhsTLS = 0;
|
|
DO_TEST_CAPS_LATEST("disk-network-ssh");
|
|
DO_TEST_CAPS_LATEST("disk-no-boot");
|
|
DO_TEST_CAPS_LATEST("disk-nvme");
|
|
DO_TEST_CAPS_LATEST("disk-vhostuser-numa");
|
|
DO_TEST_CAPS_LATEST("disk-vhostuser");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("disk-vhostvdpa", "x86_64",
|
|
ARG_VDPA_FD, "/dev/vhost-vdpa-0", 201);
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-device-lun-type-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-attaching-partition-nosupport");
|
|
DO_TEST_CAPS_LATEST("disk-usb-device");
|
|
DO_TEST_CAPS_LATEST("disk-device-removable");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-usb-pci");
|
|
DO_TEST_CAPS_LATEST("disk-scsi");
|
|
DO_TEST_CAPS_LATEST("disk-scsi-device-auto");
|
|
DO_TEST_CAPS_LATEST("disk-scsi-disk-split");
|
|
DO_TEST_CAPS_LATEST("disk-scsi-disk-wwn");
|
|
DO_TEST_CAPS_LATEST("disk-scsi-disk-vpd");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-scsi-disk-vpd-build-error");
|
|
DO_TEST_CAPS_LATEST("controller-virtio-scsi");
|
|
DO_TEST_CAPS_LATEST("controller-scsi-auto");
|
|
DO_TEST_CAPS_LATEST("disk-sata-device");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-target-overflow");
|
|
DO_TEST_CAPS_LATEST("disk-aio");
|
|
DO_TEST_CAPS_LATEST("disk-aio-io_uring");
|
|
DO_TEST_CAPS_LATEST("disk-source-pool");
|
|
DO_TEST_CAPS_LATEST("disk-source-pool-mode");
|
|
DO_TEST_CAPS_LATEST("disk-ioeventfd");
|
|
DO_TEST_CAPS_LATEST("disk-copy_on_read");
|
|
DO_TEST_CAPS_LATEST("disk-discard");
|
|
DO_TEST_CAPS_LATEST("disk-detect-zeroes");
|
|
DO_TEST_CAPS_LATEST("disk-discard_no_unref");
|
|
DO_TEST_CAPS_LATEST("disk-snapshot");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-same-targets");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-missing-target-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-address-conflict");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-hostdev-scsi-address-conflict");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdevs-drive-address-conflict");
|
|
DO_TEST_CAPS_LATEST("event_idx");
|
|
DO_TEST_CAPS_VER("virtio-lun", "9.0.0");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-lun");
|
|
DO_TEST_CAPS_LATEST("disk-scsi-lun-passthrough");
|
|
DO_TEST_CAPS_LATEST("disk-serial");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-fdc-incompatible-address");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-ide-incompatible-address");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-sata-incompatible-address");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("disk-scsi-incompatible-address");
|
|
DO_TEST_CAPS_LATEST("disk-backing-chains-index");
|
|
DO_TEST_CAPS_LATEST("disk-backing-chains-noindex");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("disk-source-fd", "x86_64",
|
|
ARG_FD_GROUP, "testgroup2", 2, 200, 205,
|
|
ARG_FD_GROUP, "testgroup5", 1, 204,
|
|
ARG_FD_GROUP, "testgroup6", 2, 247, 248);
|
|
|
|
DO_TEST_CAPS_LATEST("disk-slices");
|
|
DO_TEST_CAPS_LATEST("disk-rotation");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("disk-arm-virtio-sd", "aarch64");
|
|
|
|
DO_TEST_CAPS_LATEST("encrypted-disk");
|
|
DO_TEST_CAPS_LATEST("encrypted-disk-usage");
|
|
DO_TEST_CAPS_LATEST("luks-disks");
|
|
DO_TEST_CAPS_LATEST("luks-disks-source");
|
|
DO_TEST_CAPS_VER("luks-disks-source-qcow2", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("luks-disks-source-qcow2");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("luks-disk-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("luks-disks-source-both");
|
|
|
|
DO_TEST_CAPS_LATEST("disk-ide-split");
|
|
DO_TEST_CAPS_LATEST("disk-ide-wwn");
|
|
DO_TEST_CAPS_LATEST("disk-geometry");
|
|
DO_TEST_CAPS_LATEST("disk-blockio");
|
|
|
|
driver.config->storageUseNbdkit = 1;
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-cdrom-network-nbdkit", QEMU_NBDKIT_CAPS_PLUGIN_CURL);
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-network-source-curl-nbdkit", QEMU_NBDKIT_CAPS_PLUGIN_CURL);
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-network-source-curl-nbdkit-backing", QEMU_NBDKIT_CAPS_PLUGIN_CURL);
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-network-http-nbdkit", QEMU_NBDKIT_CAPS_PLUGIN_CURL);
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-network-ssh-nbdkit", QEMU_NBDKIT_CAPS_PLUGIN_SSH);
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-network-ssh-password", QEMU_NBDKIT_CAPS_PLUGIN_SSH);
|
|
DO_TEST_CAPS_LATEST_NBDKIT("disk-network-ssh-key", QEMU_NBDKIT_CAPS_PLUGIN_SSH);
|
|
driver.config->storageUseNbdkit = 0;
|
|
|
|
DO_TEST_CAPS_VER("disk-virtio-scsi-reservations", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("disk-virtio-scsi-reservations");
|
|
|
|
DO_TEST_CAPS_LATEST("graphics-egl-headless");
|
|
DO_TEST_CAPS_LATEST("graphics-egl-headless-rendernode");
|
|
|
|
DO_TEST_CAPS_LATEST("graphics-vnc");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-socket");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-websocket");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-policy");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-power");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-no-listen-attr");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-remove-generated-socket");
|
|
driver.config->vncAutoUnixSocket = true;
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-auto-socket-cfg");
|
|
driver.config->vncAutoUnixSocket = false;
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-auto-socket");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-none");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-socket-new-cmdline");
|
|
|
|
driver.config->vncSASL = 1;
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-sasl");
|
|
driver.config->vncTLS = 1;
|
|
driver.config->vncTLSx509verify = 1;
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-tls");
|
|
driver.config->vncTLSx509secretUUID = g_strdup("6fd3f62d-9fe7-4a4e-a869-7acd6376d8ea");
|
|
DO_TEST_CAPS_VER("graphics-vnc-tls-secret", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-tls-secret");
|
|
VIR_FREE(driver.config->vncTLSx509secretUUID);
|
|
driver.config->vncSASL = driver.config->vncTLSx509verify = driver.config->vncTLS = 0;
|
|
DO_TEST_CAPS_LATEST("graphics-vnc-egl-headless");
|
|
|
|
DO_TEST_CAPS_LATEST("graphics-sdl");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("graphics-sdl-egl-headless");
|
|
DO_TEST_CAPS_LATEST("graphics-sdl-fullscreen");
|
|
|
|
driver.config->spiceTLS = 1;
|
|
DO_TEST_CAPS_LATEST("graphics-spice");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-no-args");
|
|
driver.config->spiceSASL = 1;
|
|
DO_TEST_CAPS_LATEST("graphics-spice-sasl");
|
|
driver.config->spiceSASL = 0;
|
|
DO_TEST_CAPS_LATEST("graphics-spice-agentmouse");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-compression");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-timeout");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-qxl-vga");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-usb-redir");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-agent-file-xfer");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-socket");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-auto-socket");
|
|
driver.config->spiceAutoUnixSocket = true;
|
|
DO_TEST_CAPS_LATEST("graphics-spice-auto-socket-cfg");
|
|
driver.config->spiceAutoUnixSocket = false;
|
|
DO_TEST_CAPS_LATEST("graphics-spice-egl-headless");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("graphics-spice-invalid-egl-headless");
|
|
DO_TEST_CAPS_LATEST("graphics-spice-gl-auto-rendernode");
|
|
driver.config->spiceTLS = 0;
|
|
|
|
DO_TEST_CAPS_LATEST("graphics-dbus");
|
|
DO_TEST_CAPS_LATEST("graphics-dbus-address");
|
|
DO_TEST_CAPS_LATEST("graphics-dbus-p2p");
|
|
DO_TEST_CAPS_LATEST("graphics-dbus-audio");
|
|
DO_TEST_CAPS_LATEST("graphics-dbus-chardev");
|
|
DO_TEST_CAPS_LATEST("graphics-dbus-usbredir");
|
|
|
|
DO_TEST_CAPS_LATEST("input-usbmouse");
|
|
DO_TEST_CAPS_LATEST("input-usbtablet");
|
|
|
|
/* tests for ACPI support handling:
|
|
* - existing positive test cases enabling ACPI for aarch64/x86_64/loongarch:
|
|
* - firmware-manual-efi-acpi-q35
|
|
* - firmware-manual-efi-acpi-aarch64
|
|
* - firmware-auto-efi-loongarch64
|
|
*
|
|
* - negative case for aarch64 with 'borzoi' machine not supporting ACPI
|
|
*
|
|
* - s390x has hack to strip ACPI to preserve migration of old configs,
|
|
* but should produce error when ABI_UPDATE is requested
|
|
*/
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("aarch64-noacpi-acpi", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("riscv64-virt-acpi", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390x-ccw-acpi", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE_PARSE_ERROR("s390x-ccw-acpi", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("misc-disable-s3");
|
|
DO_TEST_CAPS_LATEST("misc-disable-suspends");
|
|
DO_TEST_CAPS_LATEST("misc-enable-s4");
|
|
DO_TEST_CAPS_VER("misc-no-reboot", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("misc-no-reboot");
|
|
DO_TEST_CAPS_LATEST("misc-uuid");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("vhost_queues-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST("net-vhostuser");
|
|
DO_TEST_CAPS_LATEST("net-vhostuser-multiq");
|
|
DO_TEST_CAPS_LATEST_FAILURE("net-vhostuser-fail");
|
|
DO_TEST_CAPS_LATEST("net-user");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("net-user", "x86_64", ARG_FLAGS, FLAG_SLIRP_HELPER | FLAG_ALLOW_DUPLICATE_OUTPUT);
|
|
DO_TEST_CAPS_LATEST("net-user-addr");
|
|
DO_TEST_CAPS_LATEST("net-user-passt");
|
|
DO_TEST_CAPS_VER("net-user-passt", "7.2.0");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("net-user-slirp-portforward");
|
|
DO_TEST_CAPS_LATEST("net-virtio");
|
|
DO_TEST_CAPS_LATEST("net-virtio-device");
|
|
DO_TEST_CAPS_LATEST("net-virtio-disable-offloads");
|
|
DO_TEST_CAPS_LATEST("net-virtio-netdev");
|
|
DO_TEST_CAPS_LATEST("net-virtio-vhost");
|
|
DO_TEST_CAPS_ARCH_LATEST("net-virtio-ccw", "s390x");
|
|
DO_TEST_CAPS_LATEST("net-virtio-rxtxqueuesize");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("net-virtio-rxqueuesize-invalid-size");
|
|
DO_TEST_CAPS_LATEST("net-virtio-teaming");
|
|
DO_TEST_CAPS_LATEST("net-virtio-teaming-hostdev");
|
|
DO_TEST_CAPS_LATEST("net-linkstate");
|
|
DO_TEST_CAPS_LATEST("net-eth");
|
|
DO_TEST_CAPS_LATEST("net-eth-ifname");
|
|
DO_TEST_CAPS_LATEST("net-eth-names");
|
|
DO_TEST_CAPS_LATEST("net-eth-hostip");
|
|
DO_TEST_CAPS_LATEST("net-eth-unmanaged-tap");
|
|
DO_TEST_CAPS_LATEST("net-client");
|
|
DO_TEST_CAPS_LATEST("net-server");
|
|
DO_TEST_CAPS_LATEST("net-many-models");
|
|
DO_TEST_CAPS_LATEST("net-mcast");
|
|
DO_TEST_CAPS_LATEST("net-udp");
|
|
DO_TEST_CAPS_LATEST("net-hostdev");
|
|
DO_TEST_CAPS_LATEST("net-hostdev-bootorder");
|
|
DO_TEST_CAPS_LATEST("net-hostdev-multidomain");
|
|
DO_TEST_CAPS_LATEST("net-hostdev-vfio");
|
|
DO_TEST_CAPS_LATEST("net-hostdev-vfio-multidomain");
|
|
DO_TEST_CAPS_LATEST_FAILURE("net-hostdev-fail");
|
|
DO_TEST_CAPS_LATEST("net-vdpa");
|
|
DO_TEST_CAPS_LATEST("net-vdpa-multiqueue");
|
|
DO_TEST_CAPS_LATEST("net-virtio-rss");
|
|
|
|
DO_TEST_CAPS_LATEST("hostdev-pci-multifunction");
|
|
|
|
DO_TEST_CAPS_LATEST("hostdev-pci-address-unassigned");
|
|
|
|
DO_TEST_CAPS_LATEST("serial-file-log");
|
|
driver.config->spiceTLS = 1;
|
|
DO_TEST_CAPS_LATEST("serial-spiceport");
|
|
driver.config->spiceTLS = 0;
|
|
DO_TEST_CAPS_LATEST("serial-debugcon");
|
|
|
|
DO_TEST_CAPS_LATEST("console-compat");
|
|
DO_TEST_CAPS_LATEST("console-compat-auto");
|
|
DO_TEST_CAPS_LATEST("console-compat-crash");
|
|
|
|
/* 'qemu-9.2' deprecated 'reconnect' in favor of 'reconnect-ms' */
|
|
DO_TEST_CAPS_VER("chardev-backends", "9.1.0");
|
|
DO_TEST_CAPS_LATEST("chardev-backends");
|
|
/* As qemu doesn't yet support JSON syntax for -chardev we use the
|
|
* QEMU_CAPS_CHARDEV_JSON capability just in the tests to have QMP schema
|
|
* validation also for the QMP mode of the -chardev props generator */
|
|
DO_TEST_CAPS_ARCH_VER_FULL("chardev-backends-json", "x86_64", "9.1.0", ARG_QEMU_CAPS, QEMU_CAPS_CHARDEV_JSON, QEMU_CAPS_LAST);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("chardev-backends-json", "x86_64", ARG_QEMU_CAPS, QEMU_CAPS_CHARDEV_JSON, QEMU_CAPS_LAST);
|
|
|
|
DO_TEST_CAPS_LATEST("serial-vc-chardev");
|
|
DO_TEST_CAPS_LATEST("serial-pty-chardev");
|
|
DO_TEST_CAPS_LATEST("serial-dev-chardev");
|
|
DO_TEST_CAPS_LATEST("serial-dev-chardev-iobase");
|
|
DO_TEST_CAPS_LATEST("serial-file-chardev");
|
|
DO_TEST_CAPS_LATEST("serial-unix-chardev");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("serial-unix-missing-source");
|
|
DO_TEST_CAPS_LATEST("serial-tcp-chardev");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("serial-tcp-chardev-telnets");
|
|
DO_TEST_CAPS_LATEST("serial-udp-chardev");
|
|
DO_TEST_CAPS_LATEST("serial-tcp-telnet-chardev");
|
|
driver.config->chardevTLS = 1;
|
|
DO_TEST_CAPS_LATEST("serial-tcp-tlsx509-chardev");
|
|
driver.config->chardevTLSx509verify = 1;
|
|
DO_TEST_CAPS_LATEST("serial-tcp-tlsx509-chardev-verify");
|
|
driver.config->chardevTLSx509verify = 0;
|
|
DO_TEST_CAPS_LATEST("serial-tcp-tlsx509-chardev-notls");
|
|
driver.config->chardevTLSx509secretUUID = g_strdup("6fd3f62d-9fe7-4a4e-a869-7acd6376d8ea");
|
|
DO_TEST_CAPS_LATEST("serial-tcp-tlsx509-secret-chardev");
|
|
VIR_FREE(driver.config->chardevTLSx509secretUUID);
|
|
driver.config->chardevTLS = 0;
|
|
DO_TEST_CAPS_LATEST("serial-many-chardev");
|
|
DO_TEST_CAPS_LATEST("parallel-tcp-chardev");
|
|
DO_TEST_CAPS_LATEST("parallel-parport-chardev");
|
|
DO_TEST_CAPS_LATEST("parallel-unix-chardev");
|
|
DO_TEST_CAPS_LATEST("console-compat-chardev");
|
|
DO_TEST_CAPS_LATEST("pci-serial-dev-chardev");
|
|
|
|
DO_TEST_CAPS_LATEST("channel-guestfwd");
|
|
DO_TEST_CAPS_LATEST("channel-unix-guestfwd");
|
|
DO_TEST_CAPS_LATEST("channel-virtio");
|
|
DO_TEST_CAPS_LATEST("channel-virtio-state");
|
|
DO_TEST_CAPS_LATEST("channel-virtio-auto");
|
|
DO_TEST_CAPS_LATEST("channel-virtio-autoassign");
|
|
DO_TEST_CAPS_LATEST("channel-virtio-autoadd");
|
|
DO_TEST_CAPS_LATEST("console-virtio");
|
|
DO_TEST_CAPS_LATEST("console-virtio-many");
|
|
DO_TEST_CAPS_ARCH_LATEST("console-virtio-ccw", "s390x");
|
|
DO_TEST_CAPS_LATEST("console-virtio-unix");
|
|
DO_TEST_CAPS_ARCH_LATEST("console-sclp", "s390x");
|
|
driver.config->spiceTLS = 1;
|
|
DO_TEST_CAPS_LATEST("channel-spicevmc");
|
|
driver.config->spiceTLS = 0;
|
|
DO_TEST_CAPS_LATEST("channel-qemu-vdagent");
|
|
DO_TEST_CAPS_LATEST("channel-qemu-vdagent-features");
|
|
DO_TEST_CAPS_LATEST("channel-virtio-default");
|
|
DO_TEST_CAPS_LATEST("channel-virtio-unix");
|
|
|
|
DO_TEST_CAPS_LATEST("smartcard-host");
|
|
DO_TEST_CAPS_LATEST("smartcard-host-certificates");
|
|
DO_TEST_CAPS_LATEST("smartcard-host-certificates-database");
|
|
DO_TEST_CAPS_LATEST("smartcard-passthrough-tcp");
|
|
DO_TEST_CAPS_LATEST("smartcard-passthrough-spicevmc");
|
|
DO_TEST_CAPS_LATEST("smartcard-controller");
|
|
DO_TEST_CAPS_LATEST("smartcard-passthrough-unix");
|
|
|
|
/* 'qemu-9.2' deprecated 'reconnect' in favor of 'reconnect-ms' */
|
|
DO_TEST_CAPS_VER("chardev-reconnect", "9.1.0");
|
|
DO_TEST_CAPS_LATEST("chardev-reconnect");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("chardev-reconnect-invalid-timeout");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("chardev-reconnect-generated-path");
|
|
|
|
DO_TEST_CAPS_LATEST("usb-controller-implicit-isapc");
|
|
DO_TEST_CAPS_LATEST("usb-controller-implicit-i440fx");
|
|
DO_TEST_CAPS_LATEST("usb-controller-implicit-q35");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-controller-default-isapc");
|
|
DO_TEST_CAPS_LATEST("usb-controller-default-i440fx");
|
|
DO_TEST_CAPS_LATEST("usb-controller-default-q35");
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-pseries", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("usb-controller-default-pseries", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-g3beige", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-mac99", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-mac99ppc", "ppc");
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-powernv9", "ppc64");
|
|
/* Until qemu-8.1 (see commit 6fe4464c05f) it was possible to compile
|
|
* out USB support from i440fx; the implicit -usb controller still failed */
|
|
DO_TEST_FULL("usb-controller-default-unavailable-i440fx", ".x86_64-latest",
|
|
ARG_CAPS_ARCH, "x86_64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
/* The implicit controller can be compiled out for q35; initialization fails though */
|
|
DO_TEST_FULL("usb-controller-default-unavailable-q35", ".x86_64-latest",
|
|
ARG_CAPS_ARCH, "x86_64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
/* However, if the USB controller is the one that gets added
|
|
* automatically for every guest instead of one that the user has
|
|
* explicitly asked for, we prefer simply skipping it */
|
|
DO_TEST_FULL("usb-controller-automatic-unavailable-q35", ".x86_64-latest",
|
|
ARG_CAPS_ARCH, "x86_64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_ICH9_USB_EHCI1, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
/* The USB controllers can be compiled out but downgrade to -usb fails in qemu */
|
|
DO_TEST_FULL("usb-controller-default-unavailable-pseries", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
/* controller selection tests for various uncommon machine types */
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-versatilepb-aarch64", "aarch64");
|
|
DO_TEST_FULL("usb-controller-default-fallback-versatilepb-aarch64", ".aarch64-latest",
|
|
ARG_CAPS_ARCH, "aarch64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-versatilepb-aarch64", ".aarch64-latest",
|
|
ARG_CAPS_ARCH, "aarch64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-versatilepb-armv7l", "armv7l");
|
|
DO_TEST_FULL("usb-controller-default-fallback-versatilepb-armv7l", ".armv7l-latest",
|
|
ARG_CAPS_ARCH, "armv7l",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-versatilepb-armv7l", ".armv7l-latest",
|
|
ARG_CAPS_ARCH, "armv7l",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-realview", "aarch64");
|
|
DO_TEST_FULL("usb-controller-default-fallback-realview", ".aarch64-latest",
|
|
ARG_CAPS_ARCH, "aarch64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-realview", ".aarch64-latest",
|
|
ARG_CAPS_ARCH, "aarch64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
/* The '-nousb' test case tests machine without a built-in USB controller */
|
|
DO_TEST_CAPS_ARCH_LATEST("usb-controller-default-nousb", "aarch64");
|
|
DO_TEST_FULL("usb-controller-default-fallback-nousb", ".aarch64-latest",
|
|
ARG_CAPS_ARCH, "aarch64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-nousb", ".aarch64-latest",
|
|
ARG_CAPS_ARCH, "aarch64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
DO_TEST_FULL("usb-controller-default-fallback-g3beige", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-g3beige", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
DO_TEST_FULL("usb-controller-default-fallback-mac99", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-mac99", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
DO_TEST_FULL("usb-controller-default-fallback-mac99ppc", ".ppc-latest",
|
|
ARG_CAPS_ARCH, "ppc",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-mac99ppc", ".ppc-latest",
|
|
ARG_CAPS_ARCH, "ppc",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_PIIX3_USB_UHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
|
|
DO_TEST_FULL("usb-controller-default-fallback-powernv9", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_FULL("usb-controller-default-unavailable-powernv9", ".ppc64-latest",
|
|
ARG_CAPS_ARCH, "ppc64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_PCI_OHCI, QEMU_CAPS_DEVICE_QEMU_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_CAPS_LATEST("usb-none");
|
|
|
|
DO_TEST_CAPS_LATEST("usb-controller-piix3");
|
|
DO_TEST_CAPS_LATEST("usb-controller-ich9-ehci-addr");
|
|
DO_TEST_CAPS_LATEST("usb-controller-ich9-companion");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-controller-ich9-no-companion");
|
|
DO_TEST_CAPS_LATEST("usb-controller-ich9-autoassign");
|
|
DO_TEST_CAPS_LATEST("usb1-usb2");
|
|
|
|
DO_TEST_CAPS_LATEST("usb-controller-nec-xhci");
|
|
DO_TEST_FULL("usb-controller-nec-xhci-unavailable", ".x86_64-latest",
|
|
ARG_CAPS_ARCH, "x86_64",
|
|
ARG_CAPS_VER, "latest",
|
|
ARG_FLAGS, FLAG_EXPECT_FAILURE,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_NEC_USB_XHCI, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_CAPS_LATEST("usb-controller-nex-xhci-autoassign");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-controller-nec-xhci-limit");
|
|
DO_TEST_CAPS_LATEST("usb-controller-qemu-xhci");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-controller-qemu-xhci-limit");
|
|
|
|
DO_TEST_CAPS_LATEST("input-usbmouse-addr");
|
|
DO_TEST_CAPS_LATEST("usb-hub");
|
|
DO_TEST_CAPS_LATEST("usb-hub-autoadd");
|
|
DO_TEST_CAPS_LATEST("usb-hub-autoadd-deluxe");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-hub-conflict");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-hub-nonexistent");
|
|
DO_TEST_CAPS_LATEST("usb-port-missing");
|
|
DO_TEST_CAPS_LATEST_FAILURE("usb-bus-missing");
|
|
DO_TEST_CAPS_LATEST("usb-ports");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-ports-out-of-range");
|
|
DO_TEST_CAPS_LATEST("usb-port-autoassign");
|
|
DO_TEST_CAPS_LATEST("usb-redir");
|
|
DO_TEST_CAPS_LATEST("usb-redir-boot");
|
|
DO_TEST_CAPS_LATEST("usb-redir-filter");
|
|
DO_TEST_CAPS_LATEST("usb-redir-filter-version");
|
|
DO_TEST_CAPS_LATEST("usb-redir-unix");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-none-other");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-none-hub");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-none-usbtablet");
|
|
DO_TEST_CAPS_LATEST("usb-long-port-path");
|
|
|
|
DO_TEST_CAPS_LATEST("smbios");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("smbios-date");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("smbios-uuid-match");
|
|
DO_TEST_CAPS_LATEST("smbios-type-fwcfg");
|
|
|
|
DO_TEST_CAPS_LATEST("watchdog");
|
|
DO_TEST_CAPS_LATEST("watchdog-device");
|
|
DO_TEST_CAPS_LATEST("watchdog-dump");
|
|
DO_TEST_CAPS_LATEST("watchdog-injectnmi");
|
|
DO_TEST_CAPS_LATEST("watchdog-q35-multiple");
|
|
DO_TEST_CAPS_ARCH_LATEST("watchdog-diag288", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("balloon-device");
|
|
DO_TEST_CAPS_LATEST("balloon-device-deflate");
|
|
DO_TEST_CAPS_ARCH_LATEST("balloon-ccw-deflate", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("balloon-mmio-deflate", "aarch64");
|
|
DO_TEST_CAPS_LATEST("balloon-device-deflate-off");
|
|
DO_TEST_CAPS_LATEST("balloon-device-auto");
|
|
DO_TEST_CAPS_LATEST("balloon-device-period");
|
|
|
|
DO_TEST_CAPS_LATEST("sound-device");
|
|
DO_TEST_CAPS_LATEST("fs9p");
|
|
DO_TEST_CAPS_ARCH_LATEST("fs9p-ccw", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("hostdev-usb-address");
|
|
DO_TEST_CAPS_LATEST("hostdev-usb-address-device");
|
|
DO_TEST_CAPS_LATEST("hostdev-usb-address-device-boot");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-usb-duplicate");
|
|
DO_TEST_CAPS_LATEST("hostdev-pci-address");
|
|
DO_TEST_CAPS_LATEST("hostdev-pci-address-device");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-pci-duplicate");
|
|
DO_TEST_CAPS_LATEST("hostdev-pci-display-ramfb");
|
|
DO_TEST_CAPS_LATEST("hostdev-vfio");
|
|
DO_TEST_CAPS_LATEST("hostdev-vfio-multidomain");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-precreated");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-mdev-src-address-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-mdev-invalid-target-address");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-mdev-duplicate");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-display-spice-opengl");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-display-spice-egl-headless");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-display-vnc");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-display-vnc-egl-headless");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-mdev-display-missing-graphics");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-display-ramfb");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-mdev-display-ramfb-multiple");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-vfio-zpci-wrong-arch");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-vfio-zpci-invalid-uid-valid-fid", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci-multidomain-many", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci-autogenerate", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci-autogenerate-uids", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci-autogenerate-fids", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-vfio-zpci-uid-set-zero", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci-boundaries", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-vfio-zpci-duplicate", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-vfio-zpci-set-zero", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-vfio-zpci-ccw-memballoon", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("pci-rom");
|
|
DO_TEST_CAPS_LATEST("pci-rom-disabled");
|
|
DO_TEST_CAPS_LATEST("pci-rom-disabled-invalid");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-subsys-mdev-vfio-ccw", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-subsys-mdev-vfio-ccw-boot", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-subsys-mdev-vfio-ccw-duplicate-address", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-subsys-mdev-vfio-ccw-invalid-address", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-subsys-mdev-vfio-ap", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("hostdev-subsys-mdev-vfio-ap-boot-fail", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("restore-v2", "x86_64",
|
|
ARG_MIGRATE_FROM, "exec:cat",
|
|
ARG_MIGRATE_FD, 7);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("restore-v2-fd", "x86_64",
|
|
ARG_MIGRATE_FROM, "stdio",
|
|
ARG_MIGRATE_FD, 7);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("restore-v2-fd", "x86_64",
|
|
ARG_MIGRATE_FROM, "fd:7",
|
|
ARG_MIGRATE_FD, 7,
|
|
ARG_FLAGS, FLAG_ALLOW_DUPLICATE_OUTPUT);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("migrate", "x86_64",
|
|
ARG_MIGRATE_FROM, "tcp:10.0.0.1:5000");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("migrate-numa-unaligned", "x86_64",
|
|
ARG_MIGRATE_FROM, "stdio",
|
|
ARG_MIGRATE_FD, 7);
|
|
|
|
DO_TEST_CAPS_LATEST("qemu-ns");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-no-env");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-alt");
|
|
|
|
DO_TEST_CAPS_LATEST("iothreads-ids");
|
|
DO_TEST_CAPS_LATEST("iothreads-ids-partial");
|
|
DO_TEST_CAPS_LATEST("iothreads-ids-pool-sizes");
|
|
DO_TEST_CAPS_LATEST("iothreads-disk");
|
|
DO_TEST_CAPS_VER("iothreads-virtio-scsi-pci", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("iothreads-virtio-scsi-pci");
|
|
DO_TEST_CAPS_ARCH_LATEST("iothreads-virtio-scsi-ccw", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-topology1");
|
|
DO_TEST_CAPS_LATEST("cpu-topology2");
|
|
DO_TEST_CAPS_LATEST("cpu-topology3");
|
|
DO_TEST_CAPS_LATEST("cpu-topology4");
|
|
DO_TEST_CAPS_ARCH_LATEST("cpu-topology5", "aarch64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-minimum1", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-minimum2", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-exact1", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-exact2", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-exact2-nofallback", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-strict1", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-no-removed-features", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
|
|
/* EPYC-Milan became available in qemu-6.0, use it for the fallback tests */
|
|
DO_TEST_CAPS_VER_FAILURE("cpu-nofallback", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-nofallback", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-fallback", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-fallback", "8.0.0");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-numa1");
|
|
DO_TEST_CAPS_LATEST("cpu-numa-memory-oldstyle");
|
|
DO_TEST_CAPS_LATEST("cpu-numa2");
|
|
DO_TEST_CAPS_LATEST("cpu-numa-no-memory-element");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpu-numa3");
|
|
DO_TEST_CAPS_LATEST("cpu-numa-disjoint");
|
|
DO_TEST_CAPS_LATEST("cpu-numa-memshared");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpu-numa-distance-nonexistent-sibling");
|
|
|
|
/* host-model cpu expansion depends on the cpu reported by qemu and thus
|
|
* we invoke it for all real capability dumps we have */
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "6.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "6.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "6.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "7.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "7.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "7.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-kvm", "8.1.0");
|
|
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "6.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "6.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "6.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "7.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "7.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "7.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-tcg", "8.1.0");
|
|
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "6.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "6.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "6.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "7.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "7.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "7.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-kvm", "8.1.0");
|
|
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "6.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "6.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "6.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "7.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "7.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "7.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-fallback-tcg", "8.1.0");
|
|
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "6.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "6.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "6.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "7.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "7.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "7.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-kvm", "8.1.0");
|
|
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "5.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "6.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "6.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "6.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "7.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "7.1.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "7.2.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "8.0.0");
|
|
DO_TEST_CAPS_VER("cpu-host-model-nofallback-tcg", "8.1.0");
|
|
|
|
/* For this specific test we accept the increased likelihood of changes
|
|
* if qemu updates the CPU model */
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-kvm");
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-fallback-kvm");
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-nofallback-kvm");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-tcg");
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-fallback-tcg");
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-nofallback-tcg");
|
|
|
|
/* this test case uses 'cpu="host-model"', run it with Haswell host cpu to prevent test case churn */
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-host-model-vendor", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_LATEST("cpu-host-passthrough");
|
|
DO_TEST_CAPS_LATEST_FAILURE("cpu-qemu-host-passthrough");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("cpu-s390-zEC12", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("cpu-s390-features", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-Haswell", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-Haswell2", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-Haswell3", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-Haswell-noTSX", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-host-model-cmt", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-tsc-frequency", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-translation");
|
|
|
|
DO_TEST_CAPS_LATEST("memtune");
|
|
DO_TEST_CAPS_LATEST("memtune-unlimited");
|
|
DO_TEST_CAPS_LATEST("blkiotune");
|
|
DO_TEST_CAPS_LATEST("blkiotune-device");
|
|
DO_TEST_CAPS_LATEST("cputune");
|
|
DO_TEST_CAPS_LATEST("cputune-zero-shares");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cputune-iothreadsched-toomuch");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cputune-vcpusched-overlap");
|
|
DO_TEST_CAPS_LATEST("cputune-numatune");
|
|
DO_TEST_CAPS_LATEST("vcpu-placement-static");
|
|
DO_TEST_CAPS_LATEST("cputune-cpuset-big-id");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpuset-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("numatune-memory-invalid-nodeset");
|
|
DO_TEST_CAPS_VER("numatune-memnode", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("numatune-memnode");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("numatune-memnode-invalid-mode");
|
|
DO_TEST_CAPS_LATEST("numatune-memnode-restrictive-mode");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("numatune-memnode-restrictive-mode-err-mixed");
|
|
DO_TEST_CAPS_LATEST("numatune-system-memory");
|
|
|
|
DO_TEST_CAPS_LATEST("numatune-memnode-no-memory");
|
|
|
|
DO_TEST_CAPS_LATEST("numatune-distances");
|
|
DO_TEST_CAPS_LATEST("numatune-no-vcpu");
|
|
DO_TEST_CAPS_LATEST("numatune-hmat");
|
|
DO_TEST_CAPS_LATEST("numatune-hmat-none");
|
|
|
|
DO_TEST_CAPS_LATEST("numatune-auto-nodeset-invalid");
|
|
DO_TEST_CAPS_LATEST("numatune-auto-prefer");
|
|
DO_TEST_CAPS_LATEST_FAILURE("numatune-static-nodeset-exceed-hostnode");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("numatune-memnode-nocpu");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("numatune-memnodes-problematic");
|
|
DO_TEST_CAPS_LATEST_FAILURE("numatune-memnode-unavailable-strict");
|
|
DO_TEST_CAPS_LATEST_FAILURE("numatune-memnode-unavailable-restrictive");
|
|
|
|
DO_TEST_CAPS_LATEST("numad");
|
|
DO_TEST_CAPS_LATEST("numad-auto-vcpu-static-numatune");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("numad-auto-vcpu-static-numatune-no-nodeset");
|
|
DO_TEST_CAPS_LATEST("numad-auto-memory-vcpu-cpuset");
|
|
DO_TEST_CAPS_LATEST("numad-auto-memory-vcpu-no-cpuset-and-placement");
|
|
DO_TEST_CAPS_LATEST("numad-static-memory-auto-vcpu");
|
|
DO_TEST_CAPS_LATEST("blkdeviotune");
|
|
DO_TEST_CAPS_LATEST("blkdeviotune-max");
|
|
DO_TEST_CAPS_LATEST("blkdeviotune-group-num");
|
|
DO_TEST_CAPS_LATEST("blkdeviotune-max-length");
|
|
|
|
DO_TEST_CAPS_LATEST("multifunction-pci-device");
|
|
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic");
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic-baselabel");
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic-override");
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic-labelskip");
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic-relabel");
|
|
DO_TEST_CAPS_LATEST("seclabel-static");
|
|
DO_TEST_CAPS_LATEST("seclabel-static-relabel");
|
|
DO_TEST_CAPS_LATEST("seclabel-static-labelskip");
|
|
DO_TEST_CAPS_LATEST("seclabel-none");
|
|
DO_TEST_CAPS_LATEST("seclabel-dac-none");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("seclabel-multiple");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("seclabel-device-duplicates");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("seclabel-device-relabel-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-basic");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-vio");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-vio-address-clash", "ppc64");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-usb-default");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-usb-multi");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-vio-user-assigned");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-nvram");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-usb-kbd");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-cpu-exact");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-no-parallel", "ppc64");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-cpu-le");
|
|
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_PPC64);
|
|
DO_TEST_CAPS_LATEST_PPC64_HOSTCPU("pseries-cpu-compat",
|
|
QEMU_CPU_DEF_POWER9);
|
|
DO_TEST_CAPS_LATEST_PPC64_HOSTCPU_FAILURE("pseries-cpu-compat-power9",
|
|
QEMU_CPU_DEF_POWER8);
|
|
DO_TEST_CAPS_LATEST_PPC64_HOSTCPU("pseries-cpu-compat-power9",
|
|
QEMU_CPU_DEF_POWER9);
|
|
DO_TEST_CAPS_LATEST_PPC64_HOSTCPU_FAILURE("pseries-cpu-compat-power10",
|
|
QEMU_CPU_DEF_POWER9);
|
|
DO_TEST_CAPS_LATEST_PPC64_HOSTCPU("pseries-cpu-compat-power10",
|
|
QEMU_CPU_DEF_POWER10);
|
|
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_NONE);
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-panic-missing");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-panic-no-address");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-panic-address", "ppc64");
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-phb-simple");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-phb-default-missing");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-phb-numa-node");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-phb-user-alias");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-default-phb-numa-node",
|
|
"ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-phb-invalid-target-index-1", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-phb-invalid-target-index-2", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-phb-invalid-target-index-3", "ppc64");
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-many-devices");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-many-buses-1");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-many-buses-2");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-hostdevs-1");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-hostdevs-2");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-hostdevs-3");
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-features");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pseries-features-invalid-machine");
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-serial-native");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-serial+console-native");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-serial-compat");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-serial-pci");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-serial-usb");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-console-native");
|
|
DO_TEST_CAPS_LATEST_PPC64("pseries-console-virtio");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pseries-serial-invalid-machine");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pseries-spaprvio-invalid", "ppc64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-serial-native", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-serial+console-native", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-serial-compat", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-serial-pci", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-serial-usb", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-console-native", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("mach-virt-console-virtio", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("mach-virt-serial-invalid-machine", "x86_64");
|
|
|
|
DO_TEST_CAPS_LATEST("video-device-pciaddr-default");
|
|
DO_TEST_CAPS_LATEST("video-vga-device");
|
|
DO_TEST_CAPS_LATEST("video-vga-device-vgamem");
|
|
DO_TEST_CAPS_LATEST("video-qxl-device");
|
|
DO_TEST_CAPS_LATEST("video-qxl-device-vgamem");
|
|
DO_TEST_CAPS_LATEST("video-qxl-device-vram64");
|
|
DO_TEST_CAPS_LATEST("video-qxl-sec-device");
|
|
DO_TEST_CAPS_LATEST("video-qxl-sec-device-vgamem");
|
|
DO_TEST_CAPS_LATEST("video-qxl-sec-device-vram64");
|
|
DO_TEST_CAPS_LATEST("video-qxl-heads");
|
|
DO_TEST_CAPS_LATEST("video-vga-qxl-heads");
|
|
DO_TEST_CAPS_LATEST("video-qxl-noheads");
|
|
DO_TEST_CAPS_LATEST("video-qxl-resolution");
|
|
DO_TEST_CAPS_LATEST("video-virtio-gpu-device");
|
|
DO_TEST_CAPS_LATEST("video-virtio-gpu-virgl");
|
|
DO_TEST_CAPS_LATEST("video-virtio-gpu-spice-gl");
|
|
DO_TEST_CAPS_LATEST("video-virtio-gpu-sdl-gl");
|
|
DO_TEST_CAPS_LATEST("video-virtio-gpu-secondary");
|
|
DO_TEST_CAPS_LATEST("video-virtio-vga");
|
|
DO_TEST_CAPS_LATEST("video-virtio-blob-on");
|
|
DO_TEST_CAPS_LATEST("video-virtio-blob-off");
|
|
DO_TEST_CAPS_LATEST("video-virtio-vga-gpu-gl");
|
|
DO_TEST_CAPS_LATEST("video-bochs-display-device");
|
|
DO_TEST_CAPS_LATEST("video-ramfb-display-device");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("video-ramfb-display-device-pci-address");
|
|
DO_TEST_CAPS_LATEST("video-none-device");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("video-invalid-multiple-devices");
|
|
DO_TEST_CAPS_LATEST("default-video-type-x86_64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("default-video-type-aarch64", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("default-video-type-loongarch64", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("default-video-type-ppc64", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("default-video-type-riscv64", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("default-video-type-s390x", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("video-multiple-primaries");
|
|
|
|
DO_TEST_CAPS_LATEST("virtio-rng-default");
|
|
DO_TEST_CAPS_LATEST("virtio-rng-random");
|
|
DO_TEST_CAPS_LATEST("virtio-rng-egd");
|
|
DO_TEST_CAPS_VER("virtio-rng-builtin", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("virtio-rng-builtin");
|
|
DO_TEST_CAPS_VER("virtio-rng-egd-unix", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("virtio-rng-egd-unix");
|
|
DO_TEST_CAPS_LATEST("virtio-rng-multiple");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-rng-egd-crash");
|
|
DO_TEST_CAPS_ARCH_LATEST("virtio-rng-ccw", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-usb-none", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-usb-address", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-usb-model", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-panic-no-address", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("s390-panic-address", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-panic-missing", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("s390-no-parallel", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-serial", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-serial-2", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-serial-console", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc-dtb", "ppc");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppce500-serial", "ppc");
|
|
|
|
DO_TEST_CAPS_LATEST("tpm-passthrough");
|
|
DO_TEST_CAPS_LATEST("tpm-passthrough-crb");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("tpm-no-backend-invalid");
|
|
DO_TEST_CAPS_LATEST("tpm-emulator");
|
|
DO_TEST_CAPS_LATEST("tpm-emulator-tpm2");
|
|
DO_TEST_CAPS_LATEST("tpm-emulator-tpm2-enc");
|
|
DO_TEST_CAPS_LATEST("tpm-emulator-tpm2-pstate");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("aarch64-tpm-wrong-model", "aarch64");
|
|
DO_TEST_CAPS_LATEST("tpm-external");
|
|
|
|
g_setenv(TEST_TPM_ENV_VAR, TPM_VER_2_0, true);
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("tpm-emulator");
|
|
g_setenv(TEST_TPM_ENV_VAR, TPM_VER_1_2, true);
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("tpm-emulator-tpm2");
|
|
unsetenv(TEST_TPM_ENV_VAR);
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-domain-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-bus-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-slot-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-function-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST("pci-bridge");
|
|
DO_TEST_CAPS_LATEST("pci-autoadd-addr");
|
|
DO_TEST_CAPS_LATEST("pci-autoadd-idx");
|
|
DO_TEST_CAPS_LATEST("pci-autofill-addr");
|
|
DO_TEST_CAPS_LATEST("pci-many");
|
|
DO_TEST_CAPS_LATEST("pci-bridge-many-disks");
|
|
DO_TEST_CAPS_LATEST("pcie-root");
|
|
DO_TEST_CAPS_LATEST("q35");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("q35-dmi-bad-address1");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("q35-dmi-bad-address2");
|
|
DO_TEST_CAPS_LATEST("pc-i440fx-acpi-root-hotplug-disable");
|
|
DO_TEST_CAPS_LATEST("pc-i440fx-acpi-root-hotplug-enable");
|
|
DO_TEST_CAPS_LATEST("q35-usb2");
|
|
DO_TEST_CAPS_LATEST("q35-usb2-multi");
|
|
DO_TEST_CAPS_LATEST("q35-usb2-reorder");
|
|
|
|
DO_TEST_CAPS_LATEST("q35-pcie");
|
|
/* same as q35-pcie, but all PCI controllers are added automatically */
|
|
DO_TEST_CAPS_LATEST("q35-pcie-autoadd");
|
|
DO_TEST_CAPS_LATEST("q35-default-devices-only");
|
|
DO_TEST_CAPS_LATEST("q35-multifunction");
|
|
DO_TEST_CAPS_LATEST("q35-virt-manager-basic");
|
|
|
|
/* Test automatic and manual setting of pcie-root-port attributes */
|
|
DO_TEST_CAPS_LATEST("pcie-root-port");
|
|
|
|
/* Make sure the default model for PCIe Root Ports is picked correctly
|
|
* based on QEMU binary capabilities. We use x86/q35 for the test, but
|
|
* any PCIe machine type (such as aarch64/virt) will behave the same */
|
|
DO_TEST_CAPS_LATEST("pcie-root-port-model-generic");
|
|
DO_TEST_CAPS_LATEST("pcie-root-port-model-ioh3420");
|
|
DO_TEST_CAPS_LATEST("pcie-root-port-nohotplug");
|
|
|
|
DO_TEST_CAPS_LATEST("autoindex");
|
|
/* Make sure the user can always override libvirt's default device
|
|
* placement policy by providing an explicit PCI address */
|
|
DO_TEST_CAPS_LATEST("q35-pci-force-address");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("q35-wrong-root");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("440fx-wrong-root");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("440fx-ide-address-conflict");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pcie-root-port-too-many");
|
|
|
|
DO_TEST_CAPS_LATEST("pcie-switch-upstream-port");
|
|
DO_TEST_CAPS_LATEST("pcie-switch-downstream-port");
|
|
|
|
DO_TEST_CAPS_LATEST("pci-expander-bus");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-expander-bus-bad-node");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-expander-bus-bad-machine");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-expander-bus-bad-bus");
|
|
|
|
DO_TEST_CAPS_LATEST("pcie-expander-bus");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pcie-expander-bus-bad-machine");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pcie-expander-bus-bad-bus");
|
|
DO_TEST_CAPS_ARCH_LATEST("pcie-expander-bus-aarch64", "aarch64");
|
|
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-lsi");
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-virtio-scsi");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("hostdev-scsi-vhost-scsi-ccw", "s390x");
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-vhost-scsi-pci");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-scsi-vhost-scsi-pci-boot-fail");
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-vhost-scsi-pcie");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-scsi-duplicate");
|
|
|
|
DO_TEST_CAPS_LATEST("mlock-on");
|
|
DO_TEST_CAPS_LATEST("mlock-off");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-bridge-negative-index-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-bridge-duplicate-index");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-root-nonzero-index");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("pci-root-address");
|
|
|
|
DO_TEST_CAPS_LATEST("hotplug-base");
|
|
|
|
DO_TEST_CAPS_LATEST("pcihole64");
|
|
DO_TEST_CAPS_LATEST("pcihole64-q35");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("arm-vexpressa9-nodevs", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("arm-vexpressa9-basic", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("arm-vexpressa9-virtio", "aarch64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-virtio", "aarch64");
|
|
|
|
/* Example of using virtio-pci with no explicit PCI controller
|
|
but with manual PCI addresses */
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virtio-pci-manual-addresses", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-video-virtio-gpu-pci", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-video-default", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-default-nic", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-cpu-passthrough", "aarch64");
|
|
DO_TEST_GIC("aarch64-gic-none", "latest", GIC_NONE);
|
|
DO_TEST_GIC("aarch64-gic-none-v2", "latest", GIC_V2);
|
|
DO_TEST_GIC("aarch64-gic-none-v3", "latest", GIC_V3);
|
|
DO_TEST_GIC("aarch64-gic-none-both", "latest", GIC_BOTH);
|
|
DO_TEST_CAPS_ARCH_VER_FULL("aarch64-gic-none-tcg", "aarch64", "latest",
|
|
ARG_GIC, GIC_BOTH,
|
|
ARG_QEMU_CAPS_DEL, QEMU_CAPS_KVM, QEMU_CAPS_LAST,
|
|
ARG_END);
|
|
DO_TEST_GIC("aarch64-gic-default", "latest", GIC_NONE);
|
|
DO_TEST_GIC("aarch64-gic-default-v2", "latest", GIC_V2);
|
|
DO_TEST_GIC("aarch64-gic-default-v3", "latest", GIC_V3);
|
|
DO_TEST_GIC("aarch64-gic-default-both", "latest", GIC_BOTH);
|
|
DO_TEST_GIC("aarch64-gic-v2", "latest", GIC_NONE);
|
|
DO_TEST_GIC("aarch64-gic-v2", "latest", GIC_V2);
|
|
DO_TEST_GIC("aarch64-gic-v2", "latest", GIC_V3);
|
|
DO_TEST_GIC("aarch64-gic-v2", "latest", GIC_BOTH);
|
|
DO_TEST_GIC("aarch64-gic-v3", "latest", GIC_NONE);
|
|
DO_TEST_GIC("aarch64-gic-v3", "latest", GIC_V2);
|
|
DO_TEST_GIC("aarch64-gic-v3", "latest", GIC_V3);
|
|
DO_TEST_GIC("aarch64-gic-v3", "latest", GIC_BOTH);
|
|
DO_TEST_GIC("aarch64-gic-host", "latest", GIC_NONE);
|
|
DO_TEST_GIC("aarch64-gic-host", "latest", GIC_V2);
|
|
DO_TEST_GIC("aarch64-gic-host", "latest", GIC_V3);
|
|
DO_TEST_GIC("aarch64-gic-host", "latest", GIC_BOTH);
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("aarch64-gic-invalid", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("aarch64-gic-not-virt", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("aarch64-gic-not-arm", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-kvm-32-on-64", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-pci-serial", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-traditional-pci", "aarch64");
|
|
|
|
/* aarch64 doesn't support the same CPU features as x86 */
|
|
DO_TEST_CAPS_ARCH_LATEST_FAILURE("aarch64-features-wrong", "aarch64");
|
|
/* Can't enable vector lengths when SVE is overall disabled */
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("aarch64-features-sve-disabled", "aarch64");
|
|
/* SVE aarch64 CPU features work on modern QEMU */
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-features-sve", "aarch64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-features-ras", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-features-pauth", "aarch64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("clock-timer-armvtimer", "aarch64");
|
|
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_NONE);
|
|
|
|
DO_TEST_CAPS_LATEST("kvm-pit-delay");
|
|
DO_TEST_CAPS_LATEST("kvm-pit-discard");
|
|
|
|
DO_TEST_CAPS_LATEST("panic");
|
|
DO_TEST_CAPS_LATEST("panic-double");
|
|
DO_TEST_CAPS_LATEST("panic-no-address");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("riscv64-panic-no-model", "riscv64");
|
|
|
|
DO_TEST_CAPS_LATEST("pvpanic-pci-x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("pvpanic-pci-aarch64", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("pvpanic-pci-invalid-address-aarch64", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("pvpanic-pci-no-address-aarch64", "aarch64");
|
|
|
|
DO_TEST_CAPS_LATEST("fips-enabled");
|
|
|
|
DO_TEST_CAPS_LATEST("shmem-plain-doorbell");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("shmem-invalid-size");
|
|
DO_TEST_CAPS_LATEST_FAILURE("shmem-invalid-address");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("shmem-small-size");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("shmem-msi-only");
|
|
DO_TEST_CAPS_LATEST("cpu-host-passthrough-features");
|
|
|
|
DO_TEST_CAPS_LATEST_FAILURE("memory-align-fail");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("memory-hotplug-nonuma");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("memory-hotplug-invalid-targetnode");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-dimm");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-dimm-addr");
|
|
DO_TEST_CAPS_ARCH_LATEST("memory-hotplug-ppc64-nonuma", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("memory-hotplug-ppc64-nonuma", "ppc64");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm-access");
|
|
DO_TEST_CAPS_VER("memory-hotplug-nvdimm-label", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm-label");
|
|
DO_TEST_CAPS_VER("memory-hotplug-nvdimm-align", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm-align");
|
|
DO_TEST_CAPS_VER("memory-hotplug-nvdimm-pmem", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm-pmem");
|
|
DO_TEST_CAPS_VER("memory-hotplug-nvdimm-readonly", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm-readonly");
|
|
DO_TEST_CAPS_ARCH_LATEST("memory-hotplug-nvdimm-ppc64", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE("memory-hotplug-nvdimm-ppc64", "ppc64");
|
|
DO_TEST_CAPS_VER("memory-hotplug-virtio-pmem", "5.2.0");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-virtio-pmem");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-virtio-mem");
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-multiple");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("memory-hotplug-virtio-mem-overlap-address");
|
|
/* Test whether overlap calculation done in
|
|
* virDomainMemoryDefCheckConflict() works for NVDIMMs which are special
|
|
* than other memory devices because of how they handle <labelsize/> */
|
|
DO_TEST_CAPS_LATEST("memory-hotplug-nvdimm-overlap");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-aeskeywrap-on-caps", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-aeskeywrap-on-cap", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-aeskeywrap-off-caps", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-aeskeywrap-off-cap", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-deakeywrap-on-caps", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-deakeywrap-on-cap", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-deakeywrap-off-caps", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-deakeywrap-off-cap", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-keywrap-none-caps", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-keywrap-none", "s390x");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-loadparm-s390", "s390x");
|
|
DO_TEST_CAPS_ARCH_VER("machine-loadparm-s390", "s390x", "9.1.0");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-loadparm-net-s390", "s390x");
|
|
DO_TEST_CAPS_ARCH_VER("machine-loadparm-net-s390", "s390x", "9.1.0");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-loadparm-hostdev", "s390x");
|
|
DO_TEST_CAPS_ARCH_VER("machine-loadparm-hostdev", "s390x", "9.1.0");
|
|
DO_TEST_CAPS_ARCH_LATEST("machine-loadparm-multiple-disks-nets-s390", "s390x");
|
|
DO_TEST_CAPS_ARCH_VER("machine-loadparm-multiple-disks-nets-s390", "s390x", "9.1.0");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("machine-loadparm-s390-char-invalid");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("machine-loadparm-s390-len-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST("qemu-ns-domain-ns0");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-domain-commandline");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-domain-commandline-ns0");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-commandline");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-commandline-ns0");
|
|
DO_TEST_CAPS_LATEST("qemu-ns-commandline-ns1");
|
|
|
|
DO_TEST_CAPS_LATEST("virtio-input");
|
|
DO_TEST_CAPS_LATEST("virtio-input-passthrough");
|
|
|
|
DO_TEST_CAPS_LATEST("input-linux");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("ppc64-tpmproxy-double", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("ppc64-tpm-double", "ppc64");
|
|
|
|
DO_TEST_CAPS_LATEST_PPC64("ppc64-tpmproxy-single");
|
|
DO_TEST_CAPS_LATEST_PPC64("ppc64-tpmproxy-with-tpm");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-usb-controller", "aarch64");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("sparc-minimal", "sparc");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("missing-machine");
|
|
|
|
DO_TEST_CAPS_LATEST("name-escape");
|
|
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("usb-too-long-port-path-invalid");
|
|
|
|
DO_TEST_CAPS_LATEST("acpi-table");
|
|
|
|
DO_TEST_CAPS_LATEST("intel-iommu");
|
|
DO_TEST_CAPS_LATEST("intel-iommu-caching-mode");
|
|
DO_TEST_CAPS_LATEST("intel-iommu-eim");
|
|
DO_TEST_CAPS_LATEST("intel-iommu-device-iotlb");
|
|
DO_TEST_CAPS_LATEST("intel-iommu-aw-bits");
|
|
DO_TEST_CAPS_LATEST("intel-iommu-dma-translation");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("intel-iommu-wrong-machine");
|
|
DO_TEST_CAPS_LATEST_ABI_UPDATE("intel-iommu-eim-autoadd");
|
|
DO_TEST_CAPS_ARCH_LATEST("iommu-smmuv3", "aarch64");
|
|
DO_TEST_CAPS_LATEST("virtio-iommu-x86_64");
|
|
DO_TEST_CAPS_VER_PARSE_ERROR("virtio-iommu-x86_64", "6.1.0");
|
|
DO_TEST_CAPS_ARCH_LATEST("virtio-iommu-aarch64", "aarch64");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-iommu-wrong-machine");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-iommu-no-acpi");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-iommu-invalid-address-type");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-iommu-invalid-address");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-iommu-dma-translation");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-hotplug-startup");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("cpu-hotplug-granularity", "ppc64");
|
|
|
|
DO_TEST_CAPS_LATEST("virtio-options");
|
|
DO_TEST_CAPS_LATEST("virtio-options-controller-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-disk-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-fs-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-input-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-memballoon-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-net-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-rng-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-video-iommu");
|
|
DO_TEST_CAPS_LATEST("virtio-options-controller-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-disk-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-fs-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-input-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-memballoon-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-net-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-rng-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-video-ats");
|
|
DO_TEST_CAPS_LATEST("virtio-options-controller-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-disk-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-fs-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-input-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-memballoon-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-memballoon-freepage-reporting");
|
|
DO_TEST_CAPS_LATEST("virtio-options-net-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-rng-packed");
|
|
DO_TEST_CAPS_LATEST("virtio-options-video-packed");
|
|
|
|
DO_TEST_CAPS_LATEST("fd-memory-numa-topology");
|
|
DO_TEST_CAPS_LATEST("fd-memory-numa-topology2");
|
|
DO_TEST_CAPS_LATEST("fd-memory-numa-topology3");
|
|
DO_TEST_CAPS_LATEST("fd-memory-numa-topology4");
|
|
|
|
DO_TEST_CAPS_LATEST("fd-memory-no-numa-topology");
|
|
|
|
DO_TEST_CAPS_LATEST("memfd-memory-numa");
|
|
DO_TEST_CAPS_LATEST("memfd-memory-default-hugepage");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-check-none");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-check-partial", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_LATEST("cpu-check-full");
|
|
DO_TEST_CAPS_LATEST("cpu-check-default-none");
|
|
DO_TEST_CAPS_LATEST("cpu-check-default-none2");
|
|
/* this test case uses 'cpu="host-model"', run it with Haswell host cpu to prevent test case churn */
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-check-default-partial", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-check-default-partial2", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-cache-disable");
|
|
/* this test case uses 'cpu="host-model"', run it with Haswell host cpu to prevent test case churn */
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-cache-disable3", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_LATEST("cpu-cache-passthrough");
|
|
DO_TEST_CAPS_LATEST("cpu-cache-emulate-l3");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpu-cache-emulate-l2");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpu-cache-passthrough3");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpu-cache-passthrough-l3");
|
|
DO_TEST_CAPS_LATEST("vmcoreinfo");
|
|
|
|
DO_TEST_CAPS_LATEST("user-aliases");
|
|
DO_TEST_CAPS_LATEST("user-aliases2");
|
|
DO_TEST_CAPS_LATEST("user-aliases-usb");
|
|
|
|
DO_TEST_CAPS_LATEST("tseg-explicit-size");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("tseg-i440fx");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("tseg-invalid-size");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("video-virtio-gpu-ccw", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("input-virtio-ccw", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("vhost-vsock");
|
|
DO_TEST_CAPS_LATEST("vhost-vsock-auto");
|
|
DO_TEST_CAPS_ARCH_LATEST("vhost-vsock-ccw", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("vhost-vsock-ccw-auto", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("vhost-vsock-ccw-iommu", "s390x");
|
|
|
|
DO_TEST_CAPS_VER("launch-security-sev", "6.0.0");
|
|
DO_TEST_CAPS_VER("launch-security-sev-missing-platform-info", "6.0.0");
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("launch-security-sev-direct",
|
|
"x86_64",
|
|
ARG_QEMU_CAPS,
|
|
QEMU_CAPS_SEV_GUEST,
|
|
QEMU_CAPS_LAST);
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("launch-security-sev-snp",
|
|
"x86_64",
|
|
ARG_QEMU_CAPS,
|
|
QEMU_CAPS_SEV_SNP_GUEST,
|
|
QEMU_CAPS_LAST);
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("launch-security-s390-pv", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("vhost-user-fs-fd-memory");
|
|
DO_TEST_CAPS_LATEST("vhost-user-fs-fd-openfiles");
|
|
DO_TEST_CAPS_LATEST("vhost-user-fs-hugepages");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("vhost-user-fs-readonly");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("vhost-user-fs-ccw", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST_PARSE_ERROR("vhost-user-fs-ccw-bootindex", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("virtio-transitional");
|
|
DO_TEST_CAPS_LATEST("virtio-non-transitional");
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("virtio-transitional-not-supported");
|
|
|
|
/* Simple headless guests for various architectures */
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-headless", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-headless-mmio", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("loongarch64-virt-headless", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-pseries-headless", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("riscv64-virt-headless", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("riscv64-virt-headless-mmio", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390x-ccw-headless", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-pc-headless", "x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-q35-headless", "x86_64");
|
|
|
|
/* Simple guests with graphics for various architectures */
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-virt-graphics", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("loongarch64-virt-graphics", "loongarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-pseries-graphics", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("riscv64-virt-graphics", "riscv64");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390x-ccw-graphics", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-pc-graphics", "x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-q35-graphics", "x86_64");
|
|
|
|
DO_TEST_CAPS_LATEST("vhost-user-vga");
|
|
DO_TEST_CAPS_LATEST("vhost-user-gpu-secondary");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-Icelake-Server-pconfig");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-default-cpu-kvm-virt-4.2", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("aarch64-default-cpu-tcg-virt-4.2", "aarch64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-default-cpu-kvm-pseries-2.7", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-default-cpu-tcg-pseries-2.7", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-default-cpu-kvm-pseries-3.1", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-default-cpu-tcg-pseries-3.1", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-default-cpu-kvm-pseries-4.2", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("ppc64-default-cpu-tcg-pseries-4.2", "ppc64");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-default-cpu-kvm-ccw-virtio-2.7", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-default-cpu-tcg-ccw-virtio-2.7", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-default-cpu-kvm-ccw-virtio-4.2", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-default-cpu-tcg-ccw-virtio-4.2", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-default-cpu-kvm-pc-4.2", "x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-default-cpu-tcg-pc-4.2", "x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-default-cpu-kvm-q35-4.2", "x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-default-cpu-tcg-q35-4.2", "x86_64");
|
|
DO_TEST_CAPS_ARCH_LATEST("x86_64-default-cpu-tcg-features", "x86_64");
|
|
|
|
DO_TEST_CAPS_LATEST("virtio-9p-multidevs");
|
|
DO_TEST_CAPS_LATEST("virtio-9p-createmode");
|
|
|
|
DO_TEST_CAPS_LATEST("devices-acpi-index");
|
|
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("hvf-x86_64-q35-headless", "x86_64", ARG_CAPS_VARIANT, "+hvf", ARG_END);
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("hvf-aarch64-virt-headless", "aarch64", ARG_CAPS_VARIANT, "+hvf", ARG_END);
|
|
/* HVF guests should not work on Linux with KVM */
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hvf-x86_64-q35-headless");
|
|
|
|
DO_TEST_CAPS_LATEST("cpu-phys-bits-passthrough");
|
|
DO_TEST_CAPS_LATEST("cpu-phys-bits-emulate");
|
|
/* this test case uses 'cpu="host"', run it with Haswell host cpu to prevent test case churn */
|
|
DO_TEST_CAPS_ARCH_LATEST_FULL("cpu-phys-bits-emulate2", "x86_64", ARG_CAPS_HOST_CPU_MODEL, QEMU_CPU_DEF_HASWELL);
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("cpu-phys-bits-passthrough2");
|
|
DO_TEST_CAPS_LATEST("cpu-phys-bits-limit");
|
|
DO_TEST_CAPS_LATEST("cpu-phys-bits-emulate-bare");
|
|
|
|
DO_TEST_CAPS_VER("sgx-epc", "7.0.0");
|
|
|
|
DO_TEST_CAPS_LATEST("crypto-builtin");
|
|
|
|
DO_TEST_CAPS_LATEST("async-teardown");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-async-teardown", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-async-teardown-no-attrib", "s390x");
|
|
DO_TEST_CAPS_ARCH_VER_PARSE_ERROR("s390-async-teardown", "s390x", "6.0.0");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-async-teardown-disabled", "s390x");
|
|
DO_TEST_CAPS_ARCH_VER("s390-async-teardown-disabled", "s390x", "6.0.0");
|
|
|
|
DO_TEST_CAPS_LATEST("boot-menu-disable-with-timeout");
|
|
DO_TEST_CAPS_LATEST("channel-unix-source-path");
|
|
DO_TEST_CAPS_LATEST("chardev-label");
|
|
DO_TEST_CAPS_LATEST("console-compat2");
|
|
DO_TEST_CAPS_LATEST("cpu-empty");
|
|
DO_TEST_CAPS_LATEST("cpu-host-model-features");
|
|
DO_TEST_CAPS_LATEST("cpu-numa-disordered");
|
|
DO_TEST_CAPS_LATEST("disk-active-commit");
|
|
DO_TEST_CAPS_LATEST("disk-mirror-old");
|
|
DO_TEST_CAPS_LATEST("disk-mirror");
|
|
DO_TEST_CAPS_LATEST("downscript");
|
|
DO_TEST_CAPS_LATEST("hostdev-mdev-display");
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-autogen-address");
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-large-unit");
|
|
DO_TEST_CAPS_LATEST("hostdev-scsi-shareable");
|
|
DO_TEST_CAPS_LATEST("lease");
|
|
DO_TEST_CAPS_LATEST("memorybacking-set");
|
|
DO_TEST_CAPS_LATEST("memorybacking-unset");
|
|
DO_TEST_CAPS_LATEST("metadata-duplicate");
|
|
DO_TEST_CAPS_LATEST("metadata");
|
|
DO_TEST_CAPS_LATEST("net-midonet");
|
|
DO_TEST_CAPS_LATEST("numad-auto-vcpu-no-numatune");
|
|
DO_TEST_CAPS_LATEST("numad-static-vcpu-no-numatune");
|
|
DO_TEST_CAPS_LATEST("numavcpus-topology-mismatch");
|
|
DO_TEST_CAPS_ARCH_LATEST("panic-pseries", "ppc64");
|
|
DO_TEST_CAPS_LATEST("pcihole64-gib");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-defaultconsole", "s390x");
|
|
DO_TEST_CAPS_ARCH_LATEST("s390-panic", "s390x");
|
|
DO_TEST_CAPS_LATEST("seclabel-device-multiple");
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic-none-relabel");
|
|
DO_TEST_CAPS_LATEST("seclabel-dynamic-none");
|
|
DO_TEST_CAPS_LATEST("serial-target-port-auto");
|
|
DO_TEST_CAPS_LATEST("vhost-user-fs-sock");
|
|
DO_TEST_CAPS_ARCH_LATEST("video-virtio-gpu-ccw-auto", "s390x");
|
|
|
|
DO_TEST_CAPS_LATEST("graphics-listen-network");
|
|
DO_TEST_CAPS_LATEST("net-bandwidth");
|
|
DO_TEST_CAPS_LATEST("net-bandwidth2");
|
|
DO_TEST_CAPS_LATEST("net-coalesce");
|
|
DO_TEST_CAPS_LATEST("net-isolated-port");
|
|
DO_TEST_CAPS_LATEST("net-mtu");
|
|
DO_TEST_CAPS_LATEST("net-openvswitch");
|
|
DO_TEST_CAPS_LATEST("net-virtio-network-portgroup");
|
|
DO_TEST_CAPS_LATEST("net-virtio-teaming-network");
|
|
DO_TEST_CAPS_LATEST("tap-vhost-incorrect");
|
|
DO_TEST_CAPS_LATEST("tap-vhost");
|
|
|
|
DO_TEST_CAPS_LATEST("mtp-usb-device")
|
|
DO_TEST_CAPS_LATEST("net-usb")
|
|
DO_TEST_CAPS_LATEST("sound-device-virtio")
|
|
DO_TEST_CAPS_LATEST("pstore-acpi-erst")
|
|
|
|
DO_TEST_CAPS_LATEST_FAILURE("disk-network-iscsi-zero-hosts-invalid")
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-scsi-vhost-rawio-invalid")
|
|
DO_TEST_CAPS_LATEST_PARSE_ERROR("hostdev-scsi-vhost-sgio-invalid")
|
|
DO_TEST_CAPS_LATEST("disk-startuppolicy-optional-drop")
|
|
|
|
/* check that all input files were actually used here */
|
|
if (testConfXMLCheck(existingTestCases) < 0)
|
|
ret = -1;
|
|
|
|
qemuTestDriverFree(&driver);
|
|
virFileWrapperClearPrefixes();
|
|
|
|
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
}
|
|
|
|
VIR_TEST_MAIN_PRELOAD(mymain,
|
|
VIR_TEST_MOCK("qemuxml2argv"),
|
|
VIR_TEST_MOCK("domaincaps"),
|
|
VIR_TEST_MOCK("virrandom"),
|
|
VIR_TEST_MOCK("qemucpu"),
|
|
VIR_TEST_MOCK("virpci"),
|
|
VIR_TEST_MOCK("virnuma"))
|
|
|
|
#else
|
|
|
|
int main(void)
|
|
{
|
|
return EXIT_AM_SKIP;
|
|
}
|
|
|
|
#endif /* WITH_QEMU */
|