Fixes rename bug for linked clones in VirtualBox.

This commit is contained in:
grossmj 2015-03-08 12:32:36 -06:00
parent 2b34e35027
commit c3014632a4
3 changed files with 12 additions and 17 deletions

View File

@ -19,8 +19,6 @@ from ...web.route import Route
from ...config import Config from ...config import Config
from aiohttp.web import HTTPForbidden from aiohttp.web import HTTPForbidden
import asyncio
class ConfigHandler: class ConfigHandler:

View File

@ -121,6 +121,11 @@ class VirtualBoxHandler:
vbox_manager = VirtualBox.instance() vbox_manager = VirtualBox.instance()
vm = vbox_manager.get_vm(request.match_info["vm_id"], project_id=request.match_info["project_id"]) vm = vbox_manager.get_vm(request.match_info["vm_id"], project_id=request.match_info["project_id"])
if "vmname" in request.json:
vmname = request.json.pop("vmname")
if vmname != vm.vmname:
yield from vm.set_vmname(vmname)
if "enable_remote_console" in request.json: if "enable_remote_console" in request.json:
yield from vm.set_enable_remote_console(request.json.pop("enable_remote_console")) yield from vm.set_enable_remote_console(request.json.pop("enable_remote_console"))
@ -132,8 +137,6 @@ class VirtualBoxHandler:
for name, value in request.json.items(): for name, value in request.json.items():
if hasattr(vm, name) and getattr(vm, name) != value: if hasattr(vm, name) and getattr(vm, name) != value:
setattr(vm, name, value) setattr(vm, name, value)
if name == "vmname":
yield from vm.rename_in_virtualbox()
response.json(vm) response.json(vm)

View File

@ -410,33 +410,27 @@ class VirtualBoxVM(BaseVM):
@property @property
def vmname(self): def vmname(self):
""" """
Returns the VM name associated with this VirtualBox VM. Returns the VirtualBox VM name.
:returns: VirtualBox VM name :returns: VirtualBox VM name
""" """
return self._vmname return self._vmname
@vmname.setter @asyncio.coroutine
def vmname(self, vmname): def set_vmname(self, vmname):
""" """
Sets the VM name associated with this VirtualBox VM. Renames the VirtualBox VM.
:param vmname: VirtualBox VM name :param vmname: VirtualBox VM name
""" """
if self._linked_clone:
yield from self._modify_vm('--name "{}"'.format(vmname))
log.info("VirtualBox VM '{name}' [{id}] has set the VM name to '{vmname}'".format(name=self.name, id=self.id, vmname=vmname)) log.info("VirtualBox VM '{name}' [{id}] has set the VM name to '{vmname}'".format(name=self.name, id=self.id, vmname=vmname))
self._vmname = vmname self._vmname = vmname
@asyncio.coroutine
def rename_in_virtualbox(self):
"""
Renames the VirtualBox VM.
"""
if self._linked_clone:
yield from self._modify_vm('--name "{}"'.format(self._vmname))
@property @property
def adapters(self): def adapters(self):
""" """