mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-22 17:34:18 +03:00
bhyve: improve bhyve_command.c testability
* bhyve_command.c (bhyveBuildNetArgStr, virBhyveProcessBuildBhyveCmd): add dryRun mode which doesn't create any devices when enabled * bhyve_command.c (virBhyveProcessBuildBhyveCmd, virBhyveProcessBuildDestroyCmd, virBhyveProcessBuildLoadCmd): accept virDomainDefPtr instead of virDomainObjPtr.
This commit is contained in:
parent
a65871aaae
commit
07e371fc36
@ -39,7 +39,7 @@
|
||||
VIR_LOG_INIT("bhyve.bhyve_command");
|
||||
|
||||
static int
|
||||
bhyveBuildNetArgStr(const virDomainDef *def, virCommandPtr cmd)
|
||||
bhyveBuildNetArgStr(const virDomainDef *def, virCommandPtr cmd, bool dryRun)
|
||||
{
|
||||
virDomainNetDefPtr net = NULL;
|
||||
char *brname = NULL;
|
||||
@ -78,35 +78,42 @@ bhyveBuildNetArgStr(const virDomainDef *def, virCommandPtr cmd)
|
||||
}
|
||||
}
|
||||
|
||||
if (virNetDevTapCreateInBridgePort(brname, &net->ifname, &net->mac,
|
||||
def->uuid, tapfd, 1,
|
||||
virDomainNetGetActualVirtPortProfile(net),
|
||||
virDomainNetGetActualVlan(net),
|
||||
VIR_NETDEV_TAP_CREATE_IFUP | VIR_NETDEV_TAP_CREATE_PERSIST) < 0) {
|
||||
if (!dryRun)
|
||||
if (virNetDevTapCreateInBridgePort(brname, &net->ifname, &net->mac,
|
||||
def->uuid, tapfd, 1,
|
||||
virDomainNetGetActualVirtPortProfile(net),
|
||||
virDomainNetGetActualVlan(net),
|
||||
VIR_NETDEV_TAP_CREATE_IFUP | VIR_NETDEV_TAP_CREATE_PERSIST) < 0) {
|
||||
VIR_FREE(net->ifname);
|
||||
VIR_FREE(brname);
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
if (!dryRun) {
|
||||
realifname = virNetDevTapGetRealDeviceName(net->ifname);
|
||||
|
||||
if (realifname == NULL) {
|
||||
VIR_FREE(net->ifname);
|
||||
VIR_FREE(brname);
|
||||
return -1;
|
||||
}
|
||||
|
||||
VIR_DEBUG("%s -> %s", net->ifname, realifname);
|
||||
/* hack on top of other hack: we need to set
|
||||
* interface to 'UP' again after re-opening to find its
|
||||
* name
|
||||
*/
|
||||
if (virNetDevSetOnline(net->ifname, true) != 0) {
|
||||
VIR_FREE(net->ifname);
|
||||
VIR_FREE(brname);
|
||||
return -1;
|
||||
}
|
||||
} else {
|
||||
if (VIR_STRDUP(realifname, "tap0") < 0)
|
||||
return -1;
|
||||
}
|
||||
|
||||
realifname = virNetDevTapGetRealDeviceName(net->ifname);
|
||||
|
||||
if (realifname == NULL) {
|
||||
VIR_FREE(net->ifname);
|
||||
VIR_FREE(brname);
|
||||
return -1;
|
||||
}
|
||||
|
||||
VIR_DEBUG("%s -> %s", net->ifname, realifname);
|
||||
/* hack on top of other hack: we need to set
|
||||
* interface to 'UP' again after re-opening to find its
|
||||
* name
|
||||
*/
|
||||
if (virNetDevSetOnline(net->ifname, true) != 0) {
|
||||
VIR_FREE(net->ifname);
|
||||
VIR_FREE(brname);
|
||||
return -1;
|
||||
}
|
||||
|
||||
virCommandAddArg(cmd, "-s");
|
||||
virCommandAddArgFormat(cmd, "1:0,virtio-net,%s,mac=%s",
|
||||
@ -195,7 +202,7 @@ bhyveBuildDiskArgStr(const virDomainDef *def, virCommandPtr cmd)
|
||||
|
||||
virCommandPtr
|
||||
virBhyveProcessBuildBhyveCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
virDomainObjPtr vm)
|
||||
virDomainDefPtr def, bool dryRun)
|
||||
{
|
||||
/*
|
||||
* /usr/sbin/bhyve -c 2 -m 256 -AI -H -P \
|
||||
@ -209,17 +216,17 @@ virBhyveProcessBuildBhyveCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
|
||||
/* CPUs */
|
||||
virCommandAddArg(cmd, "-c");
|
||||
virCommandAddArgFormat(cmd, "%d", vm->def->vcpus);
|
||||
virCommandAddArgFormat(cmd, "%d", def->vcpus);
|
||||
|
||||
/* Memory */
|
||||
virCommandAddArg(cmd, "-m");
|
||||
virCommandAddArgFormat(cmd, "%llu",
|
||||
VIR_DIV_UP(vm->def->mem.max_balloon, 1024));
|
||||
VIR_DIV_UP(def->mem.max_balloon, 1024));
|
||||
|
||||
/* Options */
|
||||
if (vm->def->features[VIR_DOMAIN_FEATURE_ACPI] == VIR_DOMAIN_FEATURE_STATE_ON)
|
||||
if (def->features[VIR_DOMAIN_FEATURE_ACPI] == VIR_DOMAIN_FEATURE_STATE_ON)
|
||||
virCommandAddArg(cmd, "-A"); /* Create an ACPI table */
|
||||
if (vm->def->features[VIR_DOMAIN_FEATURE_APIC] == VIR_DOMAIN_FEATURE_STATE_ON)
|
||||
if (def->features[VIR_DOMAIN_FEATURE_APIC] == VIR_DOMAIN_FEATURE_STATE_ON)
|
||||
virCommandAddArg(cmd, "-I"); /* Present ioapic to the guest */
|
||||
|
||||
/* Clarification about -H and -P flags from Peter Grehan:
|
||||
@ -238,13 +245,13 @@ virBhyveProcessBuildBhyveCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
|
||||
virCommandAddArgList(cmd, "-s", "0:0,hostbridge", NULL);
|
||||
/* Devices */
|
||||
if (bhyveBuildNetArgStr(vm->def, cmd) < 0)
|
||||
if (bhyveBuildNetArgStr(def, cmd, dryRun) < 0)
|
||||
goto error;
|
||||
if (bhyveBuildDiskArgStr(vm->def, cmd) < 0)
|
||||
if (bhyveBuildDiskArgStr(def, cmd) < 0)
|
||||
goto error;
|
||||
if (bhyveBuildConsoleArgStr(vm->def, cmd) < 0)
|
||||
if (bhyveBuildConsoleArgStr(def, cmd) < 0)
|
||||
goto error;
|
||||
virCommandAddArg(cmd, vm->def->name);
|
||||
virCommandAddArg(cmd, def->name);
|
||||
|
||||
return cmd;
|
||||
|
||||
@ -255,30 +262,30 @@ virBhyveProcessBuildBhyveCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
|
||||
virCommandPtr
|
||||
virBhyveProcessBuildDestroyCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
virDomainObjPtr vm)
|
||||
virDomainDefPtr def)
|
||||
{
|
||||
virCommandPtr cmd = virCommandNew(BHYVECTL);
|
||||
|
||||
virCommandAddArg(cmd, "--destroy");
|
||||
virCommandAddArgPair(cmd, "--vm", vm->def->name);
|
||||
virCommandAddArgPair(cmd, "--vm", def->name);
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
virCommandPtr
|
||||
virBhyveProcessBuildLoadCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
virDomainObjPtr vm)
|
||||
virDomainDefPtr def)
|
||||
{
|
||||
virCommandPtr cmd;
|
||||
virDomainDiskDefPtr disk;
|
||||
|
||||
if (vm->def->ndisks != 1) {
|
||||
if (def->ndisks != 1) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||
_("domain should have one and only one disk defined"));
|
||||
return NULL;
|
||||
}
|
||||
|
||||
disk = vm->def->disks[0];
|
||||
disk = def->disks[0];
|
||||
|
||||
if (disk->device != VIR_DOMAIN_DISK_DEVICE_DISK) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||
@ -297,14 +304,14 @@ virBhyveProcessBuildLoadCmd(bhyveConnPtr driver ATTRIBUTE_UNUSED,
|
||||
/* Memory */
|
||||
virCommandAddArg(cmd, "-m");
|
||||
virCommandAddArgFormat(cmd, "%llu",
|
||||
VIR_DIV_UP(vm->def->mem.max_balloon, 1024));
|
||||
VIR_DIV_UP(def->mem.max_balloon, 1024));
|
||||
|
||||
/* Image path */
|
||||
virCommandAddArg(cmd, "-d");
|
||||
virCommandAddArg(cmd, virDomainDiskGetSource(disk));
|
||||
|
||||
/* VM name */
|
||||
virCommandAddArg(cmd, vm->def->name);
|
||||
virCommandAddArg(cmd, def->name);
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
@ -28,14 +28,14 @@
|
||||
# include "vircommand.h"
|
||||
|
||||
virCommandPtr virBhyveProcessBuildBhyveCmd(bhyveConnPtr,
|
||||
virDomainObjPtr vm);
|
||||
virDomainDefPtr def, bool dryRun);
|
||||
|
||||
virCommandPtr
|
||||
virBhyveProcessBuildDestroyCmd(bhyveConnPtr driver,
|
||||
virDomainObjPtr vm);
|
||||
virDomainDefPtr def);
|
||||
|
||||
virCommandPtr
|
||||
virBhyveProcessBuildLoadCmd(bhyveConnPtr driver,
|
||||
virDomainObjPtr vm);
|
||||
virDomainDefPtr def);
|
||||
|
||||
#endif /* __BHYVE_COMMAND_H__ */
|
||||
|
@ -128,7 +128,8 @@ virBhyveProcessStart(virConnectPtr conn,
|
||||
|
||||
/* Call bhyve to start the VM */
|
||||
if (!(cmd = virBhyveProcessBuildBhyveCmd(driver,
|
||||
vm)))
|
||||
vm->def,
|
||||
false)))
|
||||
goto cleanup;
|
||||
|
||||
virCommandSetOutputFD(cmd, &logfd);
|
||||
@ -140,7 +141,7 @@ virBhyveProcessStart(virConnectPtr conn,
|
||||
/* Now bhyve command is constructed, meaning the
|
||||
* domain is ready to be started, so we can build
|
||||
* and execute bhyveload command */
|
||||
if (!(load_cmd = virBhyveProcessBuildLoadCmd(driver, vm)))
|
||||
if (!(load_cmd = virBhyveProcessBuildLoadCmd(driver, vm->def)))
|
||||
goto cleanup;
|
||||
virCommandSetOutputFD(load_cmd, &logfd);
|
||||
virCommandSetErrorFD(load_cmd, &logfd);
|
||||
@ -179,7 +180,8 @@ virBhyveProcessStart(virConnectPtr conn,
|
||||
cleanup:
|
||||
if (ret < 0) {
|
||||
virCommandPtr destroy_cmd;
|
||||
if ((destroy_cmd = virBhyveProcessBuildDestroyCmd(driver, vm)) != NULL) {
|
||||
if ((destroy_cmd = virBhyveProcessBuildDestroyCmd(driver,
|
||||
vm->def)) != NULL) {
|
||||
virCommandSetOutputFD(load_cmd, &logfd);
|
||||
virCommandSetErrorFD(load_cmd, &logfd);
|
||||
ignore_value(virCommandRun(destroy_cmd, NULL));
|
||||
@ -227,7 +229,7 @@ virBhyveProcessStop(bhyveConnPtr driver,
|
||||
|
||||
/* No matter if shutdown was successful or not, we
|
||||
* need to unload the VM */
|
||||
if (!(cmd = virBhyveProcessBuildDestroyCmd(driver, vm)))
|
||||
if (!(cmd = virBhyveProcessBuildDestroyCmd(driver, vm->def)))
|
||||
goto cleanup;
|
||||
|
||||
if (virCommandRun(cmd, NULL) < 0)
|
||||
|
@ -33,7 +33,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
||||
|
||||
vm.def = vmdef;
|
||||
|
||||
if (!(cmd = virBhyveProcessBuildBhyveCmd(&driver, &vm)))
|
||||
if (!(cmd = virBhyveProcessBuildBhyveCmd(&driver, vmdef, false)))
|
||||
goto out;
|
||||
|
||||
if (!(actualargv = virCommandToString(cmd)))
|
||||
|
Loading…
Reference in New Issue
Block a user