Remove mox in unit/virt/xenapi/test_vmops.py

Replace mox with mock in
nova/tests/unit/virt/xenapi/test_vmops.py.

The 'stubout_session' will be modified
at the same time when nova/tests/unit/virt/xenapi/stubs.by
is modified in another patch.

Change-Id: I192a67585d81cc76980139ee8f8f046d4029ecfe
Implements: blueprint mox-removal
This commit is contained in:
Takashi NATSUME 2018-04-17 18:11:12 +09:00
parent dd2232c446
commit b20682f913
2 changed files with 380 additions and 253 deletions

View File

@ -23,6 +23,7 @@ except ImportError:
import six.moves.xmlrpc_client as xmlrpclib import six.moves.xmlrpc_client as xmlrpclib
from eventlet import greenthread from eventlet import greenthread
import fixtures
import mock import mock
from os_xenapi.client import host_xenstore from os_xenapi.client import host_xenstore
import six import six
@ -297,46 +298,95 @@ class GetConsoleOutputTestCase(VMOpsTestBase):
class SpawnTestCase(VMOpsTestBase): class SpawnTestCase(VMOpsTestBase):
def _stub_out_common(self): def _stub_out_common(self):
self.mox.StubOutWithMock(self.vmops, '_ensure_instance_name_unique') self.mock_ensure_instance_name_unique = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_ensure_enough_free_mem') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, '_update_instance_progress') self.vmops, '_ensure_instance_name_unique')).mock
self.mox.StubOutWithMock(vm_utils, 'determine_disk_image_type') self.mock_ensure_enough_free_mem = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_get_vdis_for_instance') fixtures.MockPatchObject(
self.mox.StubOutWithMock(vm_utils, 'safe_destroy_vdis') self.vmops, '_ensure_enough_free_mem')).mock
self.mox.StubOutWithMock(self.vmops._volumeops, self.mock_update_instance_progress = self.useFixture(
'safe_cleanup_from_vdis') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, '_resize_up_vdis') self.vmops, '_update_instance_progress')).mock
self.mox.StubOutWithMock(vm_utils, self.mock_determine_disk_image_type = self.useFixture(
'create_kernel_and_ramdisk') fixtures.MockPatchObject(
self.mox.StubOutWithMock(vm_utils, 'destroy_kernel_ramdisk') vm_utils, 'determine_disk_image_type')).mock
self.mox.StubOutWithMock(self.vmops, '_create_vm_record') self.mock_get_vdis_for_instance = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_destroy') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, '_attach_disks') self.vmops, '_get_vdis_for_instance')).mock
self.mox.StubOutWithMock(self.vmops, '_save_device_metadata') self.mock_safe_destroy_vdis = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_prepare_disk_metadata') fixtures.MockPatchObject(
self.mox.StubOutWithMock(pci_manager, 'get_instance_pci_devs') vm_utils, 'safe_destroy_vdis')).mock
self.mox.StubOutWithMock(vm_utils, 'set_other_config_pci') self.mock_safe_cleanup_from_vdis = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_attach_orig_disks') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, 'inject_network_info') self.vmops._volumeops, 'safe_cleanup_from_vdis')).mock
self.mox.StubOutWithMock(self.vmops, '_inject_hostname') self.mock_resize_up_vdis = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_inject_instance_metadata') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, '_inject_auto_disk_config') self.vmops, '_resize_up_vdis')).mock
self.mox.StubOutWithMock(self.vmops, '_file_inject_vm_settings') self.mock_create_kernel_and_ramdisk = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_create_vifs') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops.firewall_driver, vm_utils, 'create_kernel_and_ramdisk')).mock
'setup_basic_filtering') self.mock_destroy_kernel_ramdisk = self.useFixture(
self.mox.StubOutWithMock(self.vmops.firewall_driver, fixtures.MockPatchObject(
'prepare_instance_filter') vm_utils, 'destroy_kernel_ramdisk')).mock
self.mox.StubOutWithMock(self.vmops, '_start') self.mock_create_vm_record = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_wait_for_instance_to_start') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, self.vmops, '_create_vm_record')).mock
'_configure_new_instance_with_agent') self.mock_destroy = self.useFixture(
self.mox.StubOutWithMock(self.vmops, '_remove_hostname') fixtures.MockPatchObject(self.vmops, '_destroy')).mock
self.mox.StubOutWithMock(self.vmops.firewall_driver, self.mock_attach_disks = self.useFixture(
'apply_instance_filter') fixtures.MockPatchObject(self.vmops, '_attach_disks')).mock
self.mox.StubOutWithMock(self.vmops, '_update_last_dom_id') self.mock_save_device_metadata = self.useFixture(
self.mox.StubOutWithMock(self.vmops._session, 'call_xenapi') fixtures.MockPatchObject(
self.mox.StubOutWithMock(self.vmops, '_attach_vgpu') self.vmops, '_save_device_metadata')).mock
self.mock_get_instance_pci_devs = self.useFixture(
fixtures.MockPatchObject(
pci_manager, 'get_instance_pci_devs')).mock
self.mock_set_other_config_pci = self.useFixture(
fixtures.MockPatchObject(
vm_utils, 'set_other_config_pci')).mock
self.mock_attach_orig_disks = self.useFixture(
fixtures.MockPatchObject(
self.vmops, '_attach_orig_disks')).mock
self.mock_inject_network_info = self.useFixture(
fixtures.MockPatchObject(self.vmops, 'inject_network_info')).mock
self.mock_inject_hostname = self.useFixture(
fixtures.MockPatchObject(self.vmops, '_inject_hostname')).mock
self.mock_inject_instance_metadata = self.useFixture(
fixtures.MockPatchObject(
self.vmops, '_inject_instance_metadata')).mock
self.mock_inject_auto_disk_config = self.useFixture(
fixtures.MockPatchObject(
self.vmops, '_inject_auto_disk_config')).mock
self.mock_file_inject_vm_settings = self.useFixture(
fixtures.MockPatchObject(
self.vmops, '_file_inject_vm_settings')).mock
self.mock_create_vifs = self.useFixture(
fixtures.MockPatchObject(self.vmops, '_create_vifs')).mock
self.mock_setup_basic_filtering = self.useFixture(
fixtures.MockPatchObject(
self.vmops.firewall_driver, 'setup_basic_filtering')).mock
self.mock_prepare_instance_filter = self.useFixture(
fixtures.MockPatchObject(
self.vmops.firewall_driver, 'prepare_instance_filter')).mock
self.mock_start = self.useFixture(
fixtures.MockPatchObject(self.vmops, '_start')).mock
self.mock_wait_for_instance_to_start = self.useFixture(
fixtures.MockPatchObject(
self.vmops, '_wait_for_instance_to_start')).mock
self.mock_configure_new_instance_w_agent = self.useFixture(
fixtures.MockPatchObject(
self.vmops, '_configure_new_instance_with_agent')).mock
self.mock_remove_hostname = self.useFixture(
fixtures.MockPatchObject(self.vmops, '_remove_hostname')).mock
self.mock_apply_instance_filter = self.useFixture(
fixtures.MockPatchObject(
self.vmops.firewall_driver, 'apply_instance_filter')).mock
self.mock_update_last_dom_id = self.useFixture(
fixtures.MockPatchObject(self.vmops, '_update_last_dom_id')).mock
self.mock_call_xenapi = self.useFixture(
fixtures.MockPatchObject(self.vmops._session, 'call_xenapi')).mock
self.mock_attach_vgpu = self.useFixture(
fixtures.MockPatchObject(self.vmops, '_attach_vgpu')).mock
@staticmethod @staticmethod
def _new_instance(obj): def _new_instance(obj):
@ -375,40 +425,35 @@ class SpawnTestCase(VMOpsTestBase):
self.vmops.default_root_dev self.vmops.default_root_dev
di_type = "di_type" di_type = "di_type"
vm_utils.determine_disk_image_type(image_meta).AndReturn(di_type) self.mock_determine_disk_image_type.return_value = di_type
expected_update_instance_progress_calls = []
step = 1 step = 1
self.vmops._update_instance_progress(context, instance, step, steps) expected_update_instance_progress_calls.append(
mock.call(context, instance, step, steps))
vdis = {"other": {"ref": "fake_ref_2", "osvol": True}} vdis = {"other": {"ref": "fake_ref_2", "osvol": True}}
if include_root_vdi: if include_root_vdi:
vdis["root"] = {"ref": "fake_ref"} vdis["root"] = {"ref": "fake_ref"}
self.vmops._get_vdis_for_instance(context, instance, self.mock_get_vdis_for_instance.return_value = vdis
name_label, image_meta, di_type,
block_device_info).AndReturn(vdis)
self.vmops._resize_up_vdis(instance, vdis)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, step, steps) expected_update_instance_progress_calls.append(
mock.call(context, instance, step, steps))
kernel_file = "kernel" kernel_file = "kernel"
ramdisk_file = "ramdisk" ramdisk_file = "ramdisk"
vm_utils.create_kernel_and_ramdisk(context, session, self.mock_create_kernel_and_ramdisk.return_value = (kernel_file,
instance, name_label).AndReturn((kernel_file, ramdisk_file)) ramdisk_file)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, step, steps) expected_update_instance_progress_calls.append(
mock.call(context, instance, step, steps))
vm_ref = "fake_vm_ref" vm_ref = "fake_vm_ref"
self.vmops._ensure_instance_name_unique(name_label) self.mock_create_vm_record.return_value = vm_ref
self.vmops._ensure_enough_free_mem(instance)
self.vmops._create_vm_record(context, instance, name_label,
di_type, kernel_file,
ramdisk_file, image_meta, rescue).AndReturn(vm_ref)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, step, steps) expected_update_instance_progress_calls.append(
mock.call(context, instance, step, steps))
self.vmops._save_device_metadata(context, instance, block_device_info)
self.vmops._attach_disks(context, instance, image_meta, vm_ref,
name_label, vdis, di_type, network_info, rescue,
admin_password, injected_files)
if attach_pci_dev: if attach_pci_dev:
fake_dev = { fake_dev = {
'created_at': None, 'created_at': None,
@ -427,87 +472,138 @@ class SpawnTestCase(VMOpsTestBase):
'instance_uuid': None, 'instance_uuid': None,
'extra_info': '{}', 'extra_info': '{}',
} }
pci_manager.get_instance_pci_devs(instance).AndReturn([fake_dev]) self.mock_get_instance_pci_devs.return_value = [fake_dev]
vm_utils.set_other_config_pci(self.vmops._session,
vm_ref,
"0/0000:00:00.0")
else: else:
pci_manager.get_instance_pci_devs(instance).AndReturn([]) self.mock_get_instance_pci_devs.return_value = []
self.vmops._attach_vgpu(vm_ref, vgpu_info, instance)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, step, steps) expected_update_instance_progress_calls.append(
mock.call(context, instance, step, steps))
self.vmops._inject_instance_metadata(instance, vm_ref)
self.vmops._inject_auto_disk_config(instance, vm_ref)
self.vmops._inject_hostname(instance, vm_ref, rescue)
self.vmops._file_inject_vm_settings(instance, vm_ref, vdis,
network_info)
self.vmops.inject_network_info(instance, network_info, vm_ref)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, step, steps) expected_update_instance_progress_calls.append(
mock.call(context, instance, step, steps))
if neutron_exception: if neutron_exception:
events = [('network-vif-plugged', 1)] events = [('network-vif-plugged', 1)]
self.vmops._get_neutron_events(network_info, self.stub_out('nova.virt.xenapi.vmops.VMOps.'
True, True, False).AndReturn(events) '_neutron_failed_callback',
self.mox.StubOutWithMock(self.vmops, '_neutron_failed_callback') lambda event_name, instance: None)
self.mox.StubOutWithMock(self.vmops._virtapi, self.stub_out('nova.virt.xenapi.vmops.VMOps.'
'wait_for_instance_event') 'wait_for_instance_event',
self.vmops._virtapi.wait_for_instance_event(instance, events, lambda instance, event_names,
deadline=300, deadline, error_callback: None)
error_callback=self.vmops._neutron_failed_callback).\ mock_wait_for_instance_event = self.useFixture(
AndRaise(exception.VirtualInterfaceCreateException) fixtures.MockPatchObject(
self.vmops._virtapi, 'wait_for_instance_event',
side_effect=(
exception.VirtualInterfaceCreateException))).mock
else: else:
self.vmops._create_vifs(instance, vm_ref, network_info) self.mock_setup_basic_filtering.side_effect = NotImplementedError
self.vmops.firewall_driver.setup_basic_filtering(instance,
network_info).AndRaise(NotImplementedError)
self.vmops.firewall_driver.prepare_instance_filter(instance,
network_info)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, expected_update_instance_progress_calls.append(
step, steps) mock.call(context, instance, step, steps))
if rescue: if rescue:
self.vmops._attach_orig_disks(instance, vm_ref)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, step, expected_update_instance_progress_calls.append(
steps) mock.call(context, instance, step, steps))
start_pause = True start_pause = True
self.vmops._start(instance, vm_ref, start_pause=start_pause)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, expected_update_instance_progress_calls.append(
step, steps) mock.call(context, instance, step, steps))
self.vmops.firewall_driver.apply_instance_filter(instance,
network_info)
step += 1 step += 1
self.vmops._update_instance_progress(context, instance, expected_update_instance_progress_calls.append(
step, steps) mock.call(context, instance, step, steps))
self.vmops._session.call_xenapi('VM.unpause', vm_ref)
self.vmops._wait_for_instance_to_start(instance, vm_ref)
self.vmops._update_last_dom_id(vm_ref)
self.vmops._configure_new_instance_with_agent(instance, vm_ref,
injected_files, admin_password)
self.vmops._remove_hostname(instance, vm_ref)
step += 1 step += 1
last_call = self.vmops._update_instance_progress(context, instance, expected_update_instance_progress_calls.append(
step, steps) mock.call(context, instance, step, steps))
if throw_exception: if throw_exception:
last_call.AndRaise(throw_exception) self.mock_update_instance_progress.side_effect = [
if throw_exception or neutron_exception: None, None, None, None, None, None, None, None, None,
self.vmops._destroy(instance, vm_ref, network_info=network_info) throw_exception]
vm_utils.destroy_kernel_ramdisk(self.vmops._session, instance,
kernel_file, ramdisk_file)
vm_utils.safe_destroy_vdis(self.vmops._session, ["fake_ref"])
self.vmops._volumeops.safe_cleanup_from_vdis(["fake_ref_2"])
self.mox.ReplayAll()
self.vmops.spawn(context, instance, image_meta, injected_files, self.vmops.spawn(context, instance, image_meta, injected_files,
admin_password, network_info, block_device_info_param, admin_password, network_info, block_device_info_param,
vgpu_info, name_label_param, rescue) vgpu_info, name_label_param, rescue)
self.mock_ensure_instance_name_unique.assert_called_once_with(
name_label)
self.mock_ensure_enough_free_mem.assert_called_once_with(instance)
self.mock_update_instance_progress.assert_has_calls(
expected_update_instance_progress_calls)
self.mock_determine_disk_image_type.assert_called_once_with(image_meta)
self.mock_get_vdis_for_instance.assert_called_once_with(
context, instance, name_label, image_meta, di_type,
block_device_info)
self.mock_resize_up_vdis.assert_called_once_with(instance, vdis)
self.mock_create_kernel_and_ramdisk.assert_called_once_with(
context, session, instance, name_label)
self.mock_create_vm_record.assert_called_once_with(
context, instance, name_label, di_type, kernel_file, ramdisk_file,
image_meta, rescue)
self.mock_attach_disks.assert_called_once_with(
context, instance, image_meta, vm_ref, name_label, vdis, di_type,
network_info, rescue, admin_password, injected_files)
self.mock_save_device_metadata.assert_called_once_with(
context, instance, block_device_info)
self.mock_get_instance_pci_devs.assert_called_once_with(instance)
self.mock_inject_network_info.assert_called_once_with(
instance, network_info, vm_ref)
self.mock_inject_hostname.assert_called_once_with(instance, vm_ref,
rescue)
self.mock_inject_instance_metadata.assert_called_once_with(instance,
vm_ref)
self.mock_inject_auto_disk_config.assert_called_once_with(instance,
vm_ref)
self.mock_file_inject_vm_settings.assert_called_once_with(
instance, vm_ref, vdis, network_info)
self.mock_start.assert_called_once_with(instance, vm_ref,
start_pause=start_pause)
self.mock_attach_vgpu.assert_called_once_with(vm_ref, vgpu_info,
instance)
if throw_exception or neutron_exception:
self.mock_safe_destroy_vdis.assert_called_once_with(
self.vmops._session, ["fake_ref"])
self.mock_safe_cleanup_from_vdis.assert_called_once_with(
["fake_ref_2"])
self.mock_destroy_kernel_ramdisk.assert_called_once_with(
self.vmops._session, instance, kernel_file, ramdisk_file)
self.mock_destroy.assert_called_once_with(
instance, vm_ref, network_info=network_info)
if attach_pci_dev:
self.mock_set_other_config_pci.assert_called_once_with(
self.vmops._session, vm_ref, "0/0000:00:00.0")
if neutron_exception:
mock_wait_for_instance_event.assert_called_once_with(
instance, events, deadline=300,
error_callback=self.vmops._neutron_failed_callback)
else:
self.mock_create_vifs.assert_called_once_with(instance, vm_ref,
network_info)
self.mock_setup_basic_filtering.assert_called_once_with(
instance, network_info)
self.mock_prepare_instance_filter.assert_called_once_with(
instance, network_info)
self.mock_wait_for_instance_to_start.assert_called_once_with(
instance, vm_ref)
self.mock_configure_new_instance_w_agent.assert_called_once_with(
instance, vm_ref, injected_files, admin_password)
self.mock_remove_hostname.assert_called_once_with(
instance, vm_ref)
self.mock_apply_instance_filter.assert_called_once_with(
instance, network_info)
self.mock_update_last_dom_id.assert_called_once_with(vm_ref)
self.mock_call_xenapi.assert_called_once_with('VM.unpause', vm_ref)
if rescue:
self.mock_attach_orig_disks.assert_called_once_with(instance,
vm_ref)
def test_spawn(self): def test_spawn(self):
self._test_spawn() self._test_spawn()
@ -528,17 +624,20 @@ class SpawnTestCase(VMOpsTestBase):
self.assertRaises(test.TestingException, self._test_spawn, self.assertRaises(test.TestingException, self._test_spawn,
throw_exception=test.TestingException()) throw_exception=test.TestingException())
def test_spawn_with_neutron(self): @mock.patch.object(vmops.VMOps, '_get_neutron_events',
return_value=[('network-vif-plugged', 1)])
def test_spawn_with_neutron(self, mock_get_neutron_events):
self.flags(use_neutron=True) self.flags(use_neutron=True)
self.mox.StubOutWithMock(self.vmops, '_get_neutron_events')
events = [('network-vif-plugged', 1)]
network_info = [{'id': 1, 'active': True}] network_info = [{'id': 1, 'active': True}]
self.vmops._get_neutron_events(network_info, self.stub_out('nova.virt.xenapi.vmops.VMOps.'
True, True, False).AndReturn(events) '_neutron_failed_callback',
self.mox.StubOutWithMock(self.vmops, lambda event_name, instance: None)
'_neutron_failed_callback')
self._test_spawn(network_info=network_info) self._test_spawn(network_info=network_info)
mock_get_neutron_events.assert_called_once_with(
network_info, True, True, False)
@staticmethod @staticmethod
def _dev_mock(obj): def _dev_mock(obj):
dev = mock.MagicMock(**obj) dev = mock.MagicMock(**obj)
@ -658,18 +757,24 @@ class SpawnTestCase(VMOpsTestBase):
mock_get_bdms.assert_not_called() mock_get_bdms.assert_not_called()
mock_prepare_disk_metadata.assert_not_called() mock_prepare_disk_metadata.assert_not_called()
def test_spawn_with_neutron_exception(self): @mock.patch.object(vmops.VMOps, '_get_neutron_events')
self.mox.StubOutWithMock(self.vmops, '_get_neutron_events') def test_spawn_with_neutron_exception(self, mock_get_neutron_events):
mock_get_neutron_events.return_value = [('network-vif-plugged', 1)]
self.assertRaises(exception.VirtualInterfaceCreateException, self.assertRaises(exception.VirtualInterfaceCreateException,
self._test_spawn, neutron_exception=True) self._test_spawn, neutron_exception=True)
mock_get_neutron_events.assert_called_once_with(
[], True, True, False)
def _test_finish_migration(self, power_on=True, resize_instance=True, @mock.patch.object(vmops.VMOps, '_attach_mapped_block_devices')
@mock.patch.object(vm_utils, 'import_all_migrated_disks')
@mock.patch.object(volumeops.VolumeOps, 'connect_volume')
def _test_finish_migration(self, mock_connect_volume,
mock_import_all_migrated_disks,
mock_attach_mapped_block_devices,
power_on=True, resize_instance=True,
throw_exception=None, booted_from_volume=False, throw_exception=None, booted_from_volume=False,
vgpu_info=None): vgpu_info=None):
self._stub_out_common() self._stub_out_common()
self.mox.StubOutWithMock(volumeops.VolumeOps, "connect_volume")
self.mox.StubOutWithMock(vm_utils, "import_all_migrated_disks")
self.mox.StubOutWithMock(self.vmops, "_attach_mapped_block_devices")
context = "context" context = "context"
migration = {} migration = {}
@ -681,88 +786,115 @@ class SpawnTestCase(VMOpsTestBase):
image_meta = objects.ImageMeta.from_dict({"id": uuids.image_id}) image_meta = objects.ImageMeta.from_dict({"id": uuids.image_id})
block_device_info = {} block_device_info = {}
import_root = True import_root = True
expected_call_xenapi = []
if booted_from_volume: if booted_from_volume:
block_device_info = {'block_device_mapping': [ block_device_info = {'block_device_mapping': [
{'mount_device': '/dev/xvda', {'mount_device': '/dev/xvda',
'connection_info': {'data': 'fake-data'}}]} 'connection_info': {'data': 'fake-data'}}]}
import_root = False import_root = False
volumeops.VolumeOps.connect_volume( mock_connect_volume.return_value = ('sr', 'vol-vdi-uuid')
{'data': 'fake-data'}).AndReturn(('sr', 'vol-vdi-uuid')) expected_call_xenapi.append(mock.call('VDI.get_by_uuid',
self.vmops._session.call_xenapi('VDI.get_by_uuid', 'vol-vdi-uuid'))
'vol-vdi-uuid').AndReturn('vol-vdi-ref') self.mock_call_xenapi.return_value = 'vol-vdi-ref'
session = self.vmops._session session = self.vmops._session
self.vmops._ensure_instance_name_unique(name_label)
self.vmops._ensure_enough_free_mem(instance)
di_type = "di_type" di_type = "di_type"
vm_utils.determine_disk_image_type(image_meta).AndReturn(di_type) self.mock_determine_disk_image_type.return_value = di_type
root_vdi = {"ref": "fake_ref"} root_vdi = {"ref": "fake_ref"}
ephemeral_vdi = {"ref": "fake_ref_e"} ephemeral_vdi = {"ref": "fake_ref_e"}
vdis = {"root": root_vdi, "ephemerals": {4: ephemeral_vdi}} vdis = {"root": root_vdi, "ephemerals": {4: ephemeral_vdi}}
vm_utils.import_all_migrated_disks(self.vmops._session, instance, mock_import_all_migrated_disks.return_value = vdis
import_root=import_root).AndReturn(vdis)
kernel_file = "kernel" kernel_file = "kernel"
ramdisk_file = "ramdisk" ramdisk_file = "ramdisk"
vm_utils.create_kernel_and_ramdisk(context, session, self.mock_create_kernel_and_ramdisk.return_value = (kernel_file,
instance, name_label).AndReturn((kernel_file, ramdisk_file)) ramdisk_file)
vm_ref = "fake_vm_ref" vm_ref = "fake_vm_ref"
rescue = False rescue = False
self.vmops._create_vm_record(context, instance, name_label, self.mock_create_vm_record.return_value = vm_ref
di_type, kernel_file, self.mock_get_instance_pci_devs.return_value = []
ramdisk_file, image_meta, rescue).AndReturn(vm_ref) self.mock_setup_basic_filtering.side_effect = NotImplementedError
if resize_instance:
self.vmops._resize_up_vdis(instance, vdis)
self.vmops._save_device_metadata(context, instance, block_device_info)
self.vmops._attach_disks(context, instance, image_meta, vm_ref,
name_label, vdis, di_type, network_info, False,
None, None)
self.vmops._attach_mapped_block_devices(instance, block_device_info)
pci_manager.get_instance_pci_devs(instance).AndReturn([])
self.vmops._attach_vgpu(vm_ref, vgpu_info, instance)
self.vmops._inject_instance_metadata(instance, vm_ref)
self.vmops._inject_auto_disk_config(instance, vm_ref)
self.vmops._file_inject_vm_settings(instance, vm_ref, vdis,
network_info)
self.vmops.inject_network_info(instance, network_info, vm_ref)
self.vmops._create_vifs(instance, vm_ref, network_info)
self.vmops.firewall_driver.setup_basic_filtering(instance,
network_info).AndRaise(NotImplementedError)
self.vmops.firewall_driver.prepare_instance_filter(instance,
network_info)
if power_on: if power_on:
self.vmops._start(instance, vm_ref, start_pause=True) expected_call_xenapi.append(mock.call('VM.unpause', vm_ref))
self.vmops.firewall_driver.apply_instance_filter(instance,
network_info)
if power_on:
self.vmops._session.call_xenapi('VM.unpause', vm_ref)
self.vmops._wait_for_instance_to_start(instance, vm_ref)
self.vmops._update_last_dom_id(vm_ref)
last_call = self.vmops._update_instance_progress(context, instance,
step=5, total_steps=5)
if throw_exception: if throw_exception:
last_call.AndRaise(throw_exception) self.mock_update_instance_progress.side_effect = throw_exception
self.vmops._destroy(instance, vm_ref, network_info=network_info)
vm_utils.destroy_kernel_ramdisk(self.vmops._session, instance,
kernel_file, ramdisk_file)
vm_utils.safe_destroy_vdis(self.vmops._session,
["fake_ref_e", "fake_ref"])
self.mox.ReplayAll()
self.vmops.finish_migration(context, migration, instance, disk_info, self.vmops.finish_migration(context, migration, instance, disk_info,
network_info, image_meta, resize_instance, network_info, image_meta, resize_instance,
block_device_info, power_on) block_device_info, power_on)
self.mock_ensure_instance_name_unique.assert_called_once_with(
name_label)
self.mock_ensure_enough_free_mem.assert_called_once_with(instance)
self.mock_update_instance_progress.assert_called_once_with(
context, instance, step=5, total_steps=5)
self.mock_determine_disk_image_type.assert_called_once_with(image_meta)
self.mock_create_kernel_and_ramdisk.assert_called_once_with(
context, session, instance, name_label)
self.mock_create_vm_record.assert_called_once_with(
context, instance, name_label, di_type, kernel_file, ramdisk_file,
image_meta, rescue)
self.mock_attach_disks.assert_called_once_with(
context, instance, image_meta, vm_ref, name_label, vdis, di_type,
network_info, False, None, None)
self.mock_save_device_metadata.assert_called_once_with(
context, instance, block_device_info)
self.mock_get_instance_pci_devs.assert_called_once_with(instance)
self.mock_inject_network_info.assert_called_once_with(
instance, network_info, vm_ref)
self.mock_inject_instance_metadata.assert_called_once_with(instance,
vm_ref)
self.mock_inject_auto_disk_config.assert_called_once_with(instance,
vm_ref)
self.mock_file_inject_vm_settings.assert_called_once_with(
instance, vm_ref, vdis, network_info)
self.mock_create_vifs.assert_called_once_with(
instance, vm_ref, network_info)
self.mock_setup_basic_filtering.assert_called_once_with(instance,
network_info)
self.mock_prepare_instance_filter.assert_called_once_with(
instance, network_info)
self.mock_apply_instance_filter.assert_called_once_with(
instance, network_info)
self.mock_attach_vgpu.assert_called_once_with(vm_ref, vgpu_info,
instance)
mock_import_all_migrated_disks.assert_called_once_with(
self.vmops._session, instance, import_root=import_root)
mock_attach_mapped_block_devices.assert_called_once_with(
instance, block_device_info)
if resize_instance:
self.mock_resize_up_vdis.assert_called_once_with(
instance, vdis)
if throw_exception:
self.mock_safe_destroy_vdis.assert_called_once_with(
self.vmops._session, ["fake_ref_e", "fake_ref"])
self.mock_destroy_kernel_ramdisk.assert_called_once_with(
self.vmops._session, instance, kernel_file, ramdisk_file)
self.mock_destroy.assert_called_once_with(
instance, vm_ref, network_info=network_info)
if power_on:
self.mock_start.assert_called_once_with(instance, vm_ref,
start_pause=True)
self.mock_wait_for_instance_to_start.assert_called_once_with(
instance, vm_ref)
self.mock_update_last_dom_id.assert_called_once_with(vm_ref)
if expected_call_xenapi:
self.mock_call_xenapi.assert_has_calls(expected_call_xenapi)
else:
self.mock_call_xenapi.assert_not_called()
if booted_from_volume:
mock_connect_volume.assert_called_once_with({'data': 'fake-data'})
def test_finish_migration(self): def test_finish_migration(self):
self._test_finish_migration() self._test_finish_migration()
@ -777,91 +909,84 @@ class SpawnTestCase(VMOpsTestBase):
power_on=False, resize_instance=False, power_on=False, resize_instance=False,
throw_exception=test.TestingException()) throw_exception=test.TestingException())
def test_remove_hostname(self): @mock.patch.object(xenapi_fake.SessionBase, 'call_xenapi')
def test_remove_hostname(self, mock_call_xenapi):
vm, vm_ref = self.create_vm("dummy") vm, vm_ref = self.create_vm("dummy")
instance = {"name": "dummy", "uuid": "1234", "auto_disk_config": None} instance = {"name": "dummy", "uuid": "1234", "auto_disk_config": None}
self.mox.StubOutWithMock(self._session, 'call_xenapi')
self._session.call_xenapi("VM.remove_from_xenstore_data", vm_ref,
"vm-data/hostname")
self.mox.ReplayAll()
self.vmops._remove_hostname(instance, vm_ref) self.vmops._remove_hostname(instance, vm_ref)
self.mox.VerifyAll()
def test_reset_network(self): mock_call_xenapi.assert_called_once_with(
class mock_agent(object): "VM.remove_from_xenstore_data", vm_ref, "vm-data/hostname")
def __init__(self):
self.called = False
def resetnetwork(self):
self.called = True
@mock.patch.object(vmops.VMOps, '_remove_hostname')
@mock.patch.object(vmops.VMOps, '_inject_hostname')
@mock.patch.object(vmops.VMOps, '_get_agent')
@mock.patch.object(vmops.VMOps, 'agent_enabled', return_value=True)
def test_reset_network(self, mock_agent_enabled, mock_get_agent,
mock_inject_hostname, mock_remove_hostname):
vm, vm_ref = self.create_vm("dummy") vm, vm_ref = self.create_vm("dummy")
instance = {"name": "dummy", "uuid": "1234", "auto_disk_config": None} instance = {"name": "dummy", "uuid": "1234", "auto_disk_config": None}
agent = mock_agent() agent = mock.Mock()
mock_get_agent.return_value = agent
self.mox.StubOutWithMock(self.vmops, 'agent_enabled')
self.mox.StubOutWithMock(self.vmops, '_get_agent')
self.mox.StubOutWithMock(self.vmops, '_inject_hostname')
self.mox.StubOutWithMock(self.vmops, '_remove_hostname')
self.vmops.agent_enabled(instance).AndReturn(True)
self.vmops._get_agent(instance, vm_ref).AndReturn(agent)
self.vmops._inject_hostname(instance, vm_ref, False)
self.vmops._remove_hostname(instance, vm_ref)
self.mox.ReplayAll()
self.vmops.reset_network(instance) self.vmops.reset_network(instance)
self.assertTrue(agent.called)
self.mox.VerifyAll()
def test_inject_hostname(self): agent.resetnetwork.assert_called_once_with()
mock_agent_enabled.assert_called_once_with(instance)
mock_get_agent.assert_called_once_with(instance, vm_ref)
mock_inject_hostname.assert_called_once_with(instance, vm_ref, False)
mock_remove_hostname.assert_called_once_with(instance, vm_ref)
@mock.patch.object(vmops.VMOps, '_add_to_param_xenstore')
def test_inject_hostname(self, mock_add_to_param_xenstore):
instance = {"hostname": "dummy", "os_type": "fake", "uuid": "uuid"} instance = {"hostname": "dummy", "os_type": "fake", "uuid": "uuid"}
vm_ref = "vm_ref" vm_ref = "vm_ref"
self.mox.StubOutWithMock(self.vmops, '_add_to_param_xenstore')
self.vmops._add_to_param_xenstore(vm_ref, 'vm-data/hostname', 'dummy')
self.mox.ReplayAll()
self.vmops._inject_hostname(instance, vm_ref, rescue=False) self.vmops._inject_hostname(instance, vm_ref, rescue=False)
def test_inject_hostname_with_rescue_prefix(self): mock_add_to_param_xenstore.assert_called_once_with(
vm_ref, 'vm-data/hostname', 'dummy')
@mock.patch.object(vmops.VMOps, '_add_to_param_xenstore')
def test_inject_hostname_with_rescue_prefix(
self, mock_add_to_param_xenstore):
instance = {"hostname": "dummy", "os_type": "fake", "uuid": "uuid"} instance = {"hostname": "dummy", "os_type": "fake", "uuid": "uuid"}
vm_ref = "vm_ref" vm_ref = "vm_ref"
self.mox.StubOutWithMock(self.vmops, '_add_to_param_xenstore')
self.vmops._add_to_param_xenstore(vm_ref, 'vm-data/hostname',
'RESCUE-dummy')
self.mox.ReplayAll()
self.vmops._inject_hostname(instance, vm_ref, rescue=True) self.vmops._inject_hostname(instance, vm_ref, rescue=True)
def test_inject_hostname_with_windows_name_truncation(self): mock_add_to_param_xenstore.assert_called_once_with(
vm_ref, 'vm-data/hostname', 'RESCUE-dummy')
@mock.patch.object(vmops.VMOps, '_add_to_param_xenstore')
def test_inject_hostname_with_windows_name_truncation(
self, mock_add_to_param_xenstore):
instance = {"hostname": "dummydummydummydummydummy", instance = {"hostname": "dummydummydummydummydummy",
"os_type": "windows", "uuid": "uuid"} "os_type": "windows", "uuid": "uuid"}
vm_ref = "vm_ref" vm_ref = "vm_ref"
self.mox.StubOutWithMock(self.vmops, '_add_to_param_xenstore')
self.vmops._add_to_param_xenstore(vm_ref, 'vm-data/hostname',
'RESCUE-dummydum')
self.mox.ReplayAll()
self.vmops._inject_hostname(instance, vm_ref, rescue=True) self.vmops._inject_hostname(instance, vm_ref, rescue=True)
def test_wait_for_instance_to_start(self): mock_add_to_param_xenstore.assert_called_once_with(
vm_ref, 'vm-data/hostname', 'RESCUE-dummydum')
@mock.patch.object(greenthread, 'sleep')
@mock.patch.object(vm_utils, 'get_power_state',
side_effect=[power_state.SHUTDOWN,
power_state.RUNNING])
def test_wait_for_instance_to_start(self, mock_get_power_state,
mock_sleep):
instance = {"uuid": "uuid"} instance = {"uuid": "uuid"}
vm_ref = "vm_ref" vm_ref = "vm_ref"
self.mox.StubOutWithMock(vm_utils, 'get_power_state')
self.mox.StubOutWithMock(greenthread, 'sleep')
vm_utils.get_power_state(self._session, vm_ref).AndReturn(
power_state.SHUTDOWN)
greenthread.sleep(0.5)
vm_utils.get_power_state(self._session, vm_ref).AndReturn(
power_state.RUNNING)
self.mox.ReplayAll()
self.vmops._wait_for_instance_to_start(instance, vm_ref) self.vmops._wait_for_instance_to_start(instance, vm_ref)
mock_get_power_state.assert_has_calls(
[mock.call(self._session, vm_ref),
mock.call(self._session, vm_ref)])
mock_sleep.assert_called_once_with(0.5)
@mock.patch.object(vm_utils, 'lookup', return_value='ref') @mock.patch.object(vm_utils, 'lookup', return_value='ref')
@mock.patch.object(vm_utils, 'create_vbd') @mock.patch.object(vm_utils, 'create_vbd')
def test_attach_orig_disks(self, mock_create_vbd, mock_lookup): def test_attach_orig_disks(self, mock_create_vbd, mock_lookup):
@ -878,30 +1003,33 @@ class SpawnTestCase(VMOpsTestBase):
self.vmops._session, vm_ref, 'vdi_ref', vmops.DEVICE_RESCUE, self.vmops._session, vm_ref, 'vdi_ref', vmops.DEVICE_RESCUE,
bootable=False) bootable=False)
def test_agent_update_setup(self): @mock.patch.object(xenapi_agent.XenAPIBasedAgent, 'update_if_needed')
@mock.patch.object(xenapi_agent.XenAPIBasedAgent, 'resetnetwork')
@mock.patch.object(xenapi_agent.XenAPIBasedAgent, 'get_version',
return_value='1.2.3')
@mock.patch.object(vmops.VMOps, '_get_agent')
@mock.patch.object(xenapi_agent, 'should_use_agent',
return_value=True)
def test_agent_update_setup(self, mock_should_use_agent, mock_get_agent,
mock_get_version, mock_resetnetwork,
mock_update_if_needed):
# agent updates need to occur after networking is configured # agent updates need to occur after networking is configured
instance = {'name': 'betelgeuse', instance = {'name': 'betelgeuse',
'uuid': '1-2-3-4-5-6'} 'uuid': '1-2-3-4-5-6'}
vm_ref = 'vm_ref' vm_ref = 'vm_ref'
agent = xenapi_agent.XenAPIBasedAgent(self.vmops._session, agent = xenapi_agent.XenAPIBasedAgent(self.vmops._session,
self.vmops._virtapi, instance, vm_ref) self.vmops._virtapi, instance, vm_ref)
mock_get_agent.return_value = agent
self.mox.StubOutWithMock(xenapi_agent, 'should_use_agent')
self.mox.StubOutWithMock(self.vmops, '_get_agent')
self.mox.StubOutWithMock(agent, 'get_version')
self.mox.StubOutWithMock(agent, 'resetnetwork')
self.mox.StubOutWithMock(agent, 'update_if_needed')
xenapi_agent.should_use_agent(instance).AndReturn(True)
self.vmops._get_agent(instance, vm_ref).AndReturn(agent)
agent.get_version().AndReturn('1.2.3')
agent.resetnetwork()
agent.update_if_needed('1.2.3')
self.mox.ReplayAll()
self.vmops._configure_new_instance_with_agent(instance, vm_ref, self.vmops._configure_new_instance_with_agent(instance, vm_ref,
None, None) None, None)
mock_should_use_agent.assert_called_once_with(instance)
mock_get_agent.assert_called_once_with(instance, vm_ref)
mock_get_version.assert_called_once_with()
mock_resetnetwork.assert_called_once_with()
mock_update_if_needed.assert_called_once_with('1.2.3')
@mock.patch.object(utils, 'is_neutron', return_value=True) @mock.patch.object(utils, 'is_neutron', return_value=True)
def test_get_neutron_event(self, mock_is_neutron): def test_get_neutron_event(self, mock_is_neutron):
network_info = [{"active": False, "id": 1}, network_info = [{"active": False, "id": 1},

View File

@ -3,6 +3,5 @@
# careful before you re-enable them # careful before you re-enable them
########################################################################## ##########################################################################
nova.tests.unit.virt.xenapi.test_vmops.BootableTestCase nova.tests.unit.virt.xenapi.test_vmops.BootableTestCase
nova.tests.unit.virt.xenapi.test_vmops.SpawnTestCase
nova.tests.unit.virt.xenapi.test_volumeops.VolumeDetachTestCase nova.tests.unit.virt.xenapi.test_volumeops.VolumeDetachTestCase
nova.tests.unit.virt.xenapi.test_xenapi.XenAPIMigrateInstance nova.tests.unit.virt.xenapi.test_xenapi.XenAPIMigrateInstance