Fixes LP878319
* Adds lookup of host version in XenAPI session * Add call to determine function name of resize Change-Id: I797ff2ea34a3b3fde1091efba803a4572aaf1ede
This commit is contained in:
parent
7a2e8a1d67
commit
bee61b3242
@ -789,6 +789,23 @@ class XenAPIMigrateInstance(test.TestCase):
|
|||||||
stubs.stubout_get_this_vm_uuid(self.stubs)
|
stubs.stubout_get_this_vm_uuid(self.stubs)
|
||||||
glance_stubs.stubout_glance_client(self.stubs)
|
glance_stubs.stubout_glance_client(self.stubs)
|
||||||
|
|
||||||
|
def test_resize_xenserver_6(self):
|
||||||
|
instance = db.instance_create(self.context, self.instance_values)
|
||||||
|
called = {'resize': False}
|
||||||
|
|
||||||
|
def fake_vdi_resize(*args, **kwargs):
|
||||||
|
called['resize'] = True
|
||||||
|
|
||||||
|
self.stubs.Set(stubs.FakeSessionForMigrationTests,
|
||||||
|
"VDI_resize", fake_vdi_resize)
|
||||||
|
stubs.stubout_session(self.stubs,
|
||||||
|
stubs.FakeSessionForMigrationTests,
|
||||||
|
product_version=(6, 0, 0))
|
||||||
|
stubs.stubout_loopingcall_start(self.stubs)
|
||||||
|
conn = xenapi_conn.get_connection(False)
|
||||||
|
conn._vmops.resize_instance(instance, '')
|
||||||
|
self.assertEqual(called['resize'], True)
|
||||||
|
|
||||||
def test_migrate_disk_and_power_off(self):
|
def test_migrate_disk_and_power_off(self):
|
||||||
instance = db.instance_create(self.context, self.instance_values)
|
instance = db.instance_create(self.context, self.instance_values)
|
||||||
stubs.stubout_session(self.stubs, stubs.FakeSessionForMigrationTests)
|
stubs.stubout_session(self.stubs, stubs.FakeSessionForMigrationTests)
|
||||||
|
@ -57,8 +57,8 @@ def stubout_instance_snapshot(stubs):
|
|||||||
stubs.Set(vm_utils, 'wait_for_vhd_coalesce', fake_wait_for_vhd_coalesce)
|
stubs.Set(vm_utils, 'wait_for_vhd_coalesce', fake_wait_for_vhd_coalesce)
|
||||||
|
|
||||||
|
|
||||||
def stubout_session(stubs, cls):
|
def stubout_session(stubs, cls, product_version=None):
|
||||||
"""Stubs out two methods from XenAPISession"""
|
"""Stubs out three methods from XenAPISession"""
|
||||||
def fake_import(self):
|
def fake_import(self):
|
||||||
"""Stubs out get_imported_xenapi of XenAPISession"""
|
"""Stubs out get_imported_xenapi of XenAPISession"""
|
||||||
fake_module = 'nova.virt.xenapi.fake'
|
fake_module = 'nova.virt.xenapi.fake'
|
||||||
@ -69,6 +69,10 @@ def stubout_session(stubs, cls):
|
|||||||
lambda s, url: cls(url))
|
lambda s, url: cls(url))
|
||||||
stubs.Set(xenapi_conn.XenAPISession, 'get_imported_xenapi',
|
stubs.Set(xenapi_conn.XenAPISession, 'get_imported_xenapi',
|
||||||
fake_import)
|
fake_import)
|
||||||
|
if product_version is None:
|
||||||
|
product_version = (5, 6, 2)
|
||||||
|
stubs.Set(xenapi_conn.XenAPISession, 'get_product_version',
|
||||||
|
lambda s: product_version)
|
||||||
|
|
||||||
|
|
||||||
def stub_out_get_target(stubs):
|
def stub_out_get_target(stubs):
|
||||||
|
@ -441,6 +441,8 @@ class SessionBase(object):
|
|||||||
def VDI_resize_online(self, *args):
|
def VDI_resize_online(self, *args):
|
||||||
return 'derp'
|
return 'derp'
|
||||||
|
|
||||||
|
VDI_resize = VDI_resize_online
|
||||||
|
|
||||||
def VM_clean_reboot(self, *args):
|
def VM_clean_reboot(self, *args):
|
||||||
return 'burp'
|
return 'burp'
|
||||||
|
|
||||||
|
@ -85,13 +85,14 @@ class VMOps(object):
|
|||||||
"""
|
"""
|
||||||
Management class for VM-related tasks
|
Management class for VM-related tasks
|
||||||
"""
|
"""
|
||||||
def __init__(self, session):
|
def __init__(self, session, product_version):
|
||||||
self.XenAPI = session.get_imported_xenapi()
|
self.XenAPI = session.get_imported_xenapi()
|
||||||
self.compute_api = compute.API()
|
self.compute_api = compute.API()
|
||||||
self._session = session
|
self._session = session
|
||||||
self.poll_rescue_last_ran = None
|
self.poll_rescue_last_ran = None
|
||||||
VMHelper.XenAPI = self.XenAPI
|
VMHelper.XenAPI = self.XenAPI
|
||||||
self.vif_driver = utils.import_object(FLAGS.xenapi_vif_driver)
|
self.vif_driver = utils.import_object(FLAGS.xenapi_vif_driver)
|
||||||
|
self._product_version = product_version
|
||||||
|
|
||||||
def list_instances(self):
|
def list_instances(self):
|
||||||
"""List VM instances."""
|
"""List VM instances."""
|
||||||
@ -768,7 +769,11 @@ class VMOps(object):
|
|||||||
" GB") % locals())
|
" GB") % locals())
|
||||||
vdi_ref = self._session.call_xenapi('VDI.get_by_uuid', vdi_uuid)
|
vdi_ref = self._session.call_xenapi('VDI.get_by_uuid', vdi_uuid)
|
||||||
# for an instance with no local storage
|
# for an instance with no local storage
|
||||||
self._session.call_xenapi('VDI.resize_online', vdi_ref,
|
if self._product_version[0] > 5:
|
||||||
|
resize_func_name = 'VDI.resize'
|
||||||
|
else:
|
||||||
|
resize_func_name = 'VDI.resize_online'
|
||||||
|
self._session.call_xenapi(resize_func_name, vdi_ref,
|
||||||
str(new_disk_size))
|
str(new_disk_size))
|
||||||
LOG.debug(_("Resize instance %s complete") % (instance.name))
|
LOG.debug(_("Resize instance %s complete") % (instance.name))
|
||||||
|
|
||||||
|
@ -169,9 +169,10 @@ class XenAPIConnection(driver.ComputeDriver):
|
|||||||
def __init__(self, url, user, pw):
|
def __init__(self, url, user, pw):
|
||||||
super(XenAPIConnection, self).__init__()
|
super(XenAPIConnection, self).__init__()
|
||||||
self._session = XenAPISession(url, user, pw)
|
self._session = XenAPISession(url, user, pw)
|
||||||
self._vmops = VMOps(self._session)
|
|
||||||
self._volumeops = VolumeOps(self._session)
|
self._volumeops = VolumeOps(self._session)
|
||||||
self._host_state = None
|
self._host_state = None
|
||||||
|
self._product_version = self._session.get_product_version()
|
||||||
|
self._vmops = VMOps(self._session, self._product_version)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def host_state(self):
|
def host_state(self):
|
||||||
@ -455,6 +456,14 @@ class XenAPISession(object):
|
|||||||
session.login_with_password(user, pw)
|
session.login_with_password(user, pw)
|
||||||
self._sessions.put(session)
|
self._sessions.put(session)
|
||||||
|
|
||||||
|
def get_product_version(self):
|
||||||
|
"""Return a tuple of (major, minor, rev) for the host version"""
|
||||||
|
host = self.get_xenapi_host()
|
||||||
|
software_version = self.call_xenapi('host.get_software_version',
|
||||||
|
host)
|
||||||
|
product_version = software_version['product_version']
|
||||||
|
return tuple(int(part) for part in product_version.split('.'))
|
||||||
|
|
||||||
def get_imported_xenapi(self):
|
def get_imported_xenapi(self):
|
||||||
"""Stubout point. This can be replaced with a mock xenapi module."""
|
"""Stubout point. This can be replaced with a mock xenapi module."""
|
||||||
return __import__('XenAPI')
|
return __import__('XenAPI')
|
||||||
|
Loading…
Reference in New Issue
Block a user