Merge "libvirt: Pass instance to connect_volume and disconnect_volume"

This commit is contained in:
Jenkins 2017-03-23 12:40:39 +00:00 committed by Gerrit Code Review
commit b9d4bc94ab
17 changed files with 90 additions and 75 deletions

View File

@ -6266,7 +6266,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
test.MatchType(objects.ImageMeta), test.MatchType(objects.ImageMeta),
bdm) bdm)
mock_connect_volume.assert_called_with( mock_connect_volume.assert_called_with(
connection_info, disk_info) connection_info, disk_info, instance)
mock_get_volume_config.assert_called_with( mock_get_volume_config.assert_called_with(
connection_info, disk_info) connection_info, disk_info)
mock_set_cache_mode.assert_called_with(mock_conf) mock_set_cache_mode.assert_called_with(mock_conf)
@ -6320,7 +6320,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
</disk> </disk>
""", flags=flags) """, flags=flags)
mock_disconnect_volume.assert_called_with( mock_disconnect_volume.assert_called_with(
connection_info, 'vdc') connection_info, 'vdc', instance)
@mock.patch('nova.virt.libvirt.host.Host.get_domain') @mock.patch('nova.virt.libvirt.host.Host.get_domain')
def test_detach_volume_disk_not_found(self, mock_get_domain): def test_detach_volume_disk_not_found(self, mock_get_domain):
@ -6376,7 +6376,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
mock_order.assert_has_calls([ mock_order.assert_has_calls([
mock.call.detach_volume(), mock.call.detach_volume(),
mock.call.detach_encryptor(**encryption), mock.call.detach_encryptor(**encryption),
mock.call.disconnect_volume(connection_info, 'vdc')]) mock.call.disconnect_volume(connection_info, 'vdc', instance)])
def test_multi_nic(self): def test_multi_nic(self):
network_info = _fake_network_info(self, 2) network_info = _fake_network_info(self, 2)
@ -9551,8 +9551,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
'dev': v['mount_device'].rpartition("/")[2], 'dev': v['mount_device'].rpartition("/")[2],
'type': "disk" 'type': "disk"
} }
drvr._connect_volume(v['connection_info'], drvr._connect_volume(v['connection_info'], disk_info, instance)
disk_info)
self.mox.StubOutWithMock(drvr, 'plug_vifs') self.mox.StubOutWithMock(drvr, 'plug_vifs')
drvr.plug_vifs(mox.IsA(instance), nw_info) drvr.plug_vifs(mox.IsA(instance), nw_info)
@ -9689,8 +9688,8 @@ class LibvirtConnTestCase(test.NoDBTestCase):
'dev': v['mount_device'].rpartition("/")[2], 'dev': v['mount_device'].rpartition("/")[2],
'type': "disk" 'type': "disk"
} }
drvr._connect_volume(v['connection_info'], drvr._connect_volume(v['connection_info'], disk_info,
disk_info) inst_ref)
self.mox.StubOutWithMock(drvr, 'plug_vifs') self.mox.StubOutWithMock(drvr, 'plug_vifs')
drvr.plug_vifs(mox.IsA(inst_ref), nw_info) drvr.plug_vifs(mox.IsA(inst_ref), nw_info)
self.mox.ReplayAll() self.mox.ReplayAll()
@ -10037,8 +10036,9 @@ class LibvirtConnTestCase(test.NoDBTestCase):
get_volume_connector.assert_has_calls([ get_volume_connector.assert_has_calls([
mock.call(inst_ref)]) mock.call(inst_ref)])
_disconnect_volume.assert_has_calls([ _disconnect_volume.assert_has_calls([
mock.call({'data': {'multipath_id': 'dummy1'}}, 'sda'), mock.call({'data': {'multipath_id': 'dummy1'}}, 'sda',
mock.call({'data': {}}, 'sdb')]) inst_ref),
mock.call({'data': {}}, 'sdb', inst_ref)])
def test_get_instance_disk_info_excludes_volumes(self): def test_get_instance_disk_info_excludes_volumes(self):
# Test data # Test data
@ -10396,7 +10396,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
'delete_on_termination': False 'delete_on_termination': False
} }
def _connect_volume_side_effect(connection_info, disk_info): def _connect_volume_side_effect(connection_info, disk_info, instance):
bdm['connection_info']['data']['device_path'] = '/dev/path/to/dev' bdm['connection_info']['data']['device_path'] = '/dev/path/to/dev'
def _get(key, opt=None): def _get(key, opt=None):
@ -14066,7 +14066,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
drvr.detach_volume(connection_info, instance, '/dev/sda') drvr.detach_volume(connection_info, instance, '/dev/sda')
_get_domain.assert_called_once_with(instance) _get_domain.assert_called_once_with(instance)
_disconnect_volume.assert_called_once_with(connection_info, _disconnect_volume.assert_called_once_with(connection_info,
'sda') 'sda', instance)
def _test_attach_detach_interface_get_config(self, method_name): def _test_attach_detach_interface_get_config(self, method_name):
"""Tests that the get_config() method is properly called in """Tests that the get_config() method is properly called in
@ -14614,7 +14614,7 @@ class LibvirtConnTestCase(test.NoDBTestCase):
self.assertEqual('/dev/vdb', instance.default_ephemeral_device) self.assertEqual('/dev/vdb', instance.default_ephemeral_device)
self.assertIsNone(instance.default_swap_device) self.assertIsNone(instance.default_swap_device)
connect_volume.assert_called_with(bdm['connection_info'], connect_volume.assert_called_with(bdm['connection_info'],
{'bus': 'virtio', 'type': 'disk', 'dev': 'vdc'}) {'bus': 'virtio', 'type': 'disk', 'dev': 'vdc'}, instance)
get_volume_config.assert_called_with(bdm['connection_info'], get_volume_config.assert_called_with(bdm['connection_info'],
{'bus': 'virtio', 'type': 'disk', 'dev': 'vdc'}) {'bus': 'virtio', 'type': 'disk', 'dev': 'vdc'})
volume_save.assert_called_once_with() volume_save.assert_called_once_with()
@ -14767,11 +14767,13 @@ class LibvirtConnTestCase(test.NoDBTestCase):
'/dev/vdb', 1) '/dev/vdb', 1)
get_guest.assert_called_once_with(instance) get_guest.assert_called_once_with(instance)
connect_volume.assert_called_once_with(new_connection_info, disk_info) connect_volume.assert_called_once_with(new_connection_info, disk_info,
instance)
swap_volume.assert_called_once_with(guest, 'vdb', swap_volume.assert_called_once_with(guest, 'vdb',
'/fake-new-volume', 1) '/fake-new-volume', 1)
disconnect_volume.assert_called_once_with(old_connection_info, 'vdb') disconnect_volume.assert_called_once_with(old_connection_info, 'vdb',
instance)
def test_swap_volume_driver_source_is_volume(self): def test_swap_volume_driver_source_is_volume(self):
self._test_swap_volume_driver(source_type='volume') self._test_swap_volume_driver(source_type='volume')
@ -15560,7 +15562,7 @@ class LibvirtDriverTestCase(test.NoDBTestCase):
'flavor': {'root_gb': 10, 'flavor': {'root_gb': 10,
'ephemeral_gb': 0}}) 'ephemeral_gb': 0}})
disconnect_volume.assert_called_with( disconnect_volume.assert_called_with(
mock.sentinel.conn_info_vda, 'vda') mock.sentinel.conn_info_vda, 'vda', mock.ANY)
@mock.patch('nova.virt.libvirt.driver.LibvirtDriver._disconnect_volume') @mock.patch('nova.virt.libvirt.driver.LibvirtDriver._disconnect_volume')
def test_migrate_disk_and_power_off_boot_from_volume_backed_snapshot( def test_migrate_disk_and_power_off_boot_from_volume_backed_snapshot(
@ -15586,7 +15588,7 @@ class LibvirtDriverTestCase(test.NoDBTestCase):
'flavor': {'root_gb': 10, 'flavor': {'root_gb': 10,
'ephemeral_gb': 0}}) 'ephemeral_gb': 0}})
disconnect_volume.assert_called_with( disconnect_volume.assert_called_with(
mock.sentinel.conn_info_vda, 'vda') mock.sentinel.conn_info_vda, 'vda', mock.ANY)
@mock.patch('nova.utils.execute') @mock.patch('nova.utils.execute')
@mock.patch('nova.virt.libvirt.utils.copy_image') @mock.patch('nova.virt.libvirt.utils.copy_image')

View File

@ -39,7 +39,7 @@ class LibvirtDISCOVolumeDriverTestCase(
with mock.patch.object(dcon.connector, with mock.patch.object(dcon.connector,
'connect_volume', 'connect_volume',
return_value={'path': '/dev/dms1234567'}): return_value={'path': '/dev/dms1234567'}):
dcon.connect_volume(conn, None) dcon.connect_volume(conn, None, mock.sentinel.instance)
self.assertEqual('/dev/dms1234567', self.assertEqual('/dev/dms1234567',
conn['data']['device_path']) conn['data']['device_path'])
@ -62,6 +62,6 @@ class LibvirtDISCOVolumeDriverTestCase(
'type': 'raw', 'dev': 'vda1', 'bus': 'pci0', 'type': 'raw', 'dev': 'vda1', 'bus': 'pci0',
'device_path': '/dev/dms123456'} 'device_path': '/dev/dms123456'}
conn = {'data': disk_info} conn = {'data': disk_info}
dcon.disconnect_volume(conn, disk_info) dcon.disconnect_volume(conn, disk_info, mock.sentinel.instance)
dcon.connector.disconnect_volume.assert_called_once_with( dcon.connector.disconnect_volume.assert_called_once_with(
disk_info, None) disk_info, None)

View File

@ -38,7 +38,7 @@ class LibvirtHGSTVolumeDriverTestCase(test_volume.LibvirtVolumeBaseTestCase):
drvr.connector.connect_volume = brick_conn_vol drvr.connector.connect_volume = brick_conn_vol
di = {'path': '/dev/space01', 'name': 'space01'} di = {'path': '/dev/space01', 'name': 'space01'}
ci = {'data': di} ci = {'data': di}
drvr.connect_volume(ci, None) drvr.connect_volume(ci, None, mock.sentinel.instance)
self.assertEqual('/dev/space01', self.assertEqual('/dev/space01',
ci['data']['device_path']) ci['data']['device_path'])
@ -57,6 +57,6 @@ class LibvirtHGSTVolumeDriverTestCase(test_volume.LibvirtVolumeBaseTestCase):
di = {'path': '/dev/space01', 'name': 'space01', 'type': 'raw', di = {'path': '/dev/space01', 'name': 'space01', 'type': 'raw',
'dev': 'vda1', 'bus': 'pci0', 'device_path': '/dev/space01'} 'dev': 'vda1', 'bus': 'pci0', 'device_path': '/dev/space01'}
ci = {'data': di} ci = {'data': di}
drvr.disconnect_volume(ci, di) drvr.disconnect_volume(ci, di, mock.sentinel.instance)
drvr.connector.disconnect_volume.assert_called_once_with( drvr.connector.disconnect_volume.assert_called_once_with(
di, None) di, None)

View File

@ -75,7 +75,8 @@ Setting up iSCSI targets: unused
libvirt_driver.connector.disconnect_volume = mock.MagicMock( libvirt_driver.connector.disconnect_volume = mock.MagicMock(
side_effect=os_brick_exception.VolumeDeviceNotFound( side_effect=os_brick_exception.VolumeDeviceNotFound(
device=device_path)) device=device_path))
libvirt_driver.disconnect_volume(connection_info, device_path) libvirt_driver.disconnect_volume(connection_info, device_path,
mock.sentinel.instance)
msg = mock_LOG_warning.call_args_list[0] msg = mock_LOG_warning.call_args_list[0]
self.assertIn('Ignoring VolumeDeviceNotFound', msg[0][0]) self.assertIn('Ignoring VolumeDeviceNotFound', msg[0][0])

View File

@ -52,7 +52,8 @@ class LibvirtNetVolumeDriverTestCase(
self.assertEqual('network', tree.get('type')) self.assertEqual('network', tree.get('type'))
self.assertEqual('sheepdog', tree.find('./source').get('protocol')) self.assertEqual('sheepdog', tree.find('./source').get('protocol'))
self.assertEqual(self.name, tree.find('./source').get('name')) self.assertEqual(self.name, tree.find('./source').get('name'))
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
def rbd_connection(self, volume): def rbd_connection(self, volume):
return { return {
@ -79,7 +80,8 @@ class LibvirtNetVolumeDriverTestCase(
self.assertIsNone(tree.find('./source/auth')) self.assertIsNone(tree.find('./source/auth'))
self.assertEqual('1048576', tree.find('./iotune/total_bytes_sec').text) self.assertEqual('1048576', tree.find('./iotune/total_bytes_sec').text)
self.assertEqual('500', tree.find('./iotune/read_iops_sec').text) self.assertEqual('500', tree.find('./iotune/read_iops_sec').text)
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
def test_libvirt_rbd_driver_hosts(self): def test_libvirt_rbd_driver_hosts(self):
libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host) libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host)
@ -95,7 +97,8 @@ class LibvirtNetVolumeDriverTestCase(
found_hosts = tree.findall('./source/host') found_hosts = tree.findall('./source/host')
self.assertEqual(hosts, [host.get('name') for host in found_hosts]) self.assertEqual(hosts, [host.get('name') for host in found_hosts])
self.assertEqual(ports, [host.get('port') for host in found_hosts]) self.assertEqual(ports, [host.get('port') for host in found_hosts])
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
def test_libvirt_rbd_driver_auth_enabled(self): def test_libvirt_rbd_driver_auth_enabled(self):
libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host) libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host)
@ -112,7 +115,8 @@ class LibvirtNetVolumeDriverTestCase(
self.assertEqual(self.user, tree.find('./auth').get('username')) self.assertEqual(self.user, tree.find('./auth').get('username'))
self.assertEqual(secret_type, tree.find('./auth/secret').get('type')) self.assertEqual(secret_type, tree.find('./auth/secret').get('type'))
self.assertEqual(self.uuid, tree.find('./auth/secret').get('uuid')) self.assertEqual(self.uuid, tree.find('./auth/secret').get('uuid'))
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
def test_libvirt_rbd_driver_auth_enabled_flags(self): def test_libvirt_rbd_driver_auth_enabled_flags(self):
# The values from the cinder connection_info take precedence over # The values from the cinder connection_info take precedence over
@ -137,7 +141,8 @@ class LibvirtNetVolumeDriverTestCase(
self.assertEqual(self.user, tree.find('./auth').get('username')) self.assertEqual(self.user, tree.find('./auth').get('username'))
self.assertEqual(secret_type, tree.find('./auth/secret').get('type')) self.assertEqual(secret_type, tree.find('./auth/secret').get('type'))
self.assertEqual(self.uuid, tree.find('./auth/secret').get('uuid')) self.assertEqual(self.uuid, tree.find('./auth/secret').get('uuid'))
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
def test_libvirt_rbd_driver_auth_disabled(self): def test_libvirt_rbd_driver_auth_disabled(self):
libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host) libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host)
@ -152,7 +157,8 @@ class LibvirtNetVolumeDriverTestCase(
tree = conf.format_dom() tree = conf.format_dom()
self._assertNetworkAndProtocolEquals(tree) self._assertNetworkAndProtocolEquals(tree)
self.assertIsNone(tree.find('./auth')) self.assertIsNone(tree.find('./auth'))
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
def test_libvirt_rbd_driver_auth_disabled_flags_override(self): def test_libvirt_rbd_driver_auth_disabled_flags_override(self):
libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host) libvirt_driver = net.LibvirtNetVolumeDriver(self.fake_host)
@ -177,7 +183,8 @@ class LibvirtNetVolumeDriverTestCase(
self.assertEqual(flags_user, tree.find('./auth').get('username')) self.assertEqual(flags_user, tree.find('./auth').get('username'))
self.assertEqual(secret_type, tree.find('./auth/secret').get('type')) self.assertEqual(secret_type, tree.find('./auth/secret').get('type'))
self.assertEqual(flags_uuid, tree.find('./auth/secret').get('uuid')) self.assertEqual(flags_uuid, tree.find('./auth/secret').get('uuid'))
libvirt_driver.disconnect_volume(connection_info, "vde") libvirt_driver.disconnect_volume(connection_info, "vde",
mock.sentinel.instance)
@mock.patch.object(host.Host, 'find_secret') @mock.patch.object(host.Host, 'find_secret')
@mock.patch.object(host.Host, 'create_secret') @mock.patch.object(host.Host, 'create_secret')
@ -198,4 +205,5 @@ class LibvirtNetVolumeDriverTestCase(
self.assertEqual(secret_type, tree.find('./auth/secret').get('type')) self.assertEqual(secret_type, tree.find('./auth/secret').get('type'))
self.assertEqual(test_volume.SECRET_UUID, self.assertEqual(test_volume.SECRET_UUID,
tree.find('./auth/secret').get('uuid')) tree.find('./auth/secret').get('uuid'))
libvirt_driver.disconnect_volume(connection_info, 'vde') libvirt_driver.disconnect_volume(connection_info, 'vde',
mock.sentinel.instance)

View File

@ -38,7 +38,7 @@ class LibvirtScaleIOVolumeDriverTestCase(
sio.connector.connect_volume = brick_conn_vol sio.connector.connect_volume = brick_conn_vol
disk_info = {'path': '/dev/vol01', 'name': 'vol01'} disk_info = {'path': '/dev/vol01', 'name': 'vol01'}
conn = {'data': disk_info} conn = {'data': disk_info}
sio.connect_volume(conn, None) sio.connect_volume(conn, None, mock.sentinel.instance)
self.assertEqual('/dev/vol01', self.assertEqual('/dev/vol01',
conn['data']['device_path']) conn['data']['device_path'])
@ -57,6 +57,6 @@ class LibvirtScaleIOVolumeDriverTestCase(
disk_info = {'path': '/dev/vol01', 'name': 'vol01', 'type': 'raw', disk_info = {'path': '/dev/vol01', 'name': 'vol01', 'type': 'raw',
'dev': 'vda1', 'bus': 'pci0', 'device_path': '/dev/vol01'} 'dev': 'vda1', 'bus': 'pci0', 'device_path': '/dev/vol01'}
conn = {'data': disk_info} conn = {'data': disk_info}
sio.disconnect_volume(conn, disk_info) sio.disconnect_volume(conn, disk_info, mock.sentinel.instance)
sio.connector.disconnect_volume.assert_called_once_with( sio.connector.disconnect_volume.assert_called_once_with(
disk_info, None) disk_info, None)

View File

@ -64,7 +64,8 @@ class LibvirtVZStorageTestCase(test_volume.LibvirtVolumeBaseTestCase):
err_pattern, err_pattern,
drv.connect_volume, drv.connect_volume,
connection_info, connection_info,
self.disk_info) self.disk_info,
mock.sentinel.instance)
def test_libvirt_vzstorage_driver_connect(self): def test_libvirt_vzstorage_driver_connect(self):
def brick_conn_vol(data): def brick_conn_vol(data):
@ -77,7 +78,8 @@ class LibvirtVZStorageTestCase(test_volume.LibvirtVolumeBaseTestCase):
connection_info = {'data': {'export': export_string, connection_info = {'data': {'export': export_string,
'name': self.name}} 'name': self.name}}
drv.connect_volume(connection_info, self.disk_info) drv.connect_volume(connection_info, self.disk_info,
mock.sentinel.instance)
self.assertEqual('vstorage://testcluster', self.assertEqual('vstorage://testcluster',
connection_info['data']['device_path']) connection_info['data']['device_path'])
self.assertEqual('-u stack -g qemu -m 0770 ' self.assertEqual('-u stack -g qemu -m 0770 '
@ -89,7 +91,7 @@ class LibvirtVZStorageTestCase(test_volume.LibvirtVolumeBaseTestCase):
drv = vzstorage.LibvirtVZStorageVolumeDriver(self.fake_host) drv = vzstorage.LibvirtVZStorageVolumeDriver(self.fake_host)
drv.connector.disconnect_volume = mock.MagicMock() drv.connector.disconnect_volume = mock.MagicMock()
conn = {'data': self.disk_info} conn = {'data': self.disk_info}
drv.disconnect_volume(conn, self.disk_info) drv.disconnect_volume(conn, self.disk_info, mock.sentinel.instance)
drv.connector.disconnect_volume.assert_called_once_with( drv.connector.disconnect_volume.assert_called_once_with(
self.disk_info, None) self.disk_info, None)

View File

@ -973,7 +973,7 @@ class LibvirtDriver(driver.ComputeDriver):
encryptor.detach_volume(**encryption) encryptor.detach_volume(**encryption)
try: try:
self._disconnect_volume(connection_info, disk_dev) self._disconnect_volume(connection_info, disk_dev, instance)
except Exception as exc: except Exception as exc:
with excutils.save_and_reraise_exception() as ctxt: with excutils.save_and_reraise_exception() as ctxt:
if destroy_disks: if destroy_disks:
@ -1140,13 +1140,13 @@ class LibvirtDriver(driver.ComputeDriver):
raise exception.VolumeDriverNotFound(driver_type=driver_type) raise exception.VolumeDriverNotFound(driver_type=driver_type)
return self.volume_drivers[driver_type] return self.volume_drivers[driver_type]
def _connect_volume(self, connection_info, disk_info): def _connect_volume(self, connection_info, disk_info, instance):
vol_driver = self._get_volume_driver(connection_info) vol_driver = self._get_volume_driver(connection_info)
vol_driver.connect_volume(connection_info, disk_info) vol_driver.connect_volume(connection_info, disk_info, instance)
def _disconnect_volume(self, connection_info, disk_dev): def _disconnect_volume(self, connection_info, disk_dev, instance):
vol_driver = self._get_volume_driver(connection_info) vol_driver = self._get_volume_driver(connection_info)
vol_driver.disconnect_volume(connection_info, disk_dev) vol_driver.disconnect_volume(connection_info, disk_dev, instance)
def _get_volume_config(self, connection_info, disk_info): def _get_volume_config(self, connection_info, disk_info):
vol_driver = self._get_volume_driver(connection_info) vol_driver = self._get_volume_driver(connection_info)
@ -1201,7 +1201,7 @@ class LibvirtDriver(driver.ComputeDriver):
disk_info = blockinfo.get_info_from_bdm( disk_info = blockinfo.get_info_from_bdm(
instance, CONF.libvirt.virt_type, instance.image_meta, bdm) instance, CONF.libvirt.virt_type, instance.image_meta, bdm)
self._connect_volume(connection_info, disk_info) self._connect_volume(connection_info, disk_info, instance)
conf = self._get_volume_config(connection_info, disk_info) conf = self._get_volume_config(connection_info, disk_info)
self._set_cache_mode(conf) self._set_cache_mode(conf)
@ -1223,11 +1223,12 @@ class LibvirtDriver(driver.ComputeDriver):
if isinstance(ex, libvirt.libvirtError): if isinstance(ex, libvirt.libvirtError):
errcode = ex.get_error_code() errcode = ex.get_error_code()
if errcode == libvirt.VIR_ERR_OPERATION_FAILED: if errcode == libvirt.VIR_ERR_OPERATION_FAILED:
self._disconnect_volume(connection_info, disk_dev) self._disconnect_volume(connection_info, disk_dev,
instance)
raise exception.DeviceIsBusy(device=disk_dev) raise exception.DeviceIsBusy(device=disk_dev)
with excutils.save_and_reraise_exception(): with excutils.save_and_reraise_exception():
self._disconnect_volume(connection_info, disk_dev) self._disconnect_volume(connection_info, disk_dev, instance)
def _swap_volume(self, guest, disk_path, new_path, resize_to): def _swap_volume(self, guest, disk_path, new_path, resize_to):
"""Swap existing disk with a new block device.""" """Swap existing disk with a new block device."""
@ -1291,14 +1292,14 @@ class LibvirtDriver(driver.ComputeDriver):
# LibvirtConfigGuestDisk object it returns. We do not explicitly save # LibvirtConfigGuestDisk object it returns. We do not explicitly save
# this to the BDM here as the upper compute swap_volume method will # this to the BDM here as the upper compute swap_volume method will
# eventually do this for us. # eventually do this for us.
self._connect_volume(new_connection_info, disk_info) self._connect_volume(new_connection_info, disk_info, instance)
conf = self._get_volume_config(new_connection_info, disk_info) conf = self._get_volume_config(new_connection_info, disk_info)
if not conf.source_path: if not conf.source_path:
self._disconnect_volume(new_connection_info, disk_dev) self._disconnect_volume(new_connection_info, disk_dev, instance)
raise NotImplementedError(_("Swap only supports host devices")) raise NotImplementedError(_("Swap only supports host devices"))
self._swap_volume(guest, disk_dev, conf.source_path, resize_to) self._swap_volume(guest, disk_dev, conf.source_path, resize_to)
self._disconnect_volume(old_connection_info, disk_dev) self._disconnect_volume(old_connection_info, disk_dev, instance)
def _get_existing_domain_xml(self, instance, network_info, def _get_existing_domain_xml(self, instance, network_info,
block_device_info=None): block_device_info=None):
@ -1359,7 +1360,7 @@ class LibvirtDriver(driver.ComputeDriver):
else: else:
raise raise
self._disconnect_volume(connection_info, disk_dev) self._disconnect_volume(connection_info, disk_dev, instance)
def attach_interface(self, context, instance, image_meta, vif): def attach_interface(self, context, instance, image_meta, vif):
guest = self._host.get_guest(instance) guest = self._host.get_guest(instance)
@ -3622,7 +3623,7 @@ class LibvirtDriver(driver.ComputeDriver):
connection_info = vol['connection_info'] connection_info = vol['connection_info']
vol_dev = block_device.prepend_dev(vol['mount_device']) vol_dev = block_device.prepend_dev(vol['mount_device'])
info = disk_mapping[vol_dev] info = disk_mapping[vol_dev]
self._connect_volume(connection_info, info) self._connect_volume(connection_info, info, instance)
cfg = self._get_volume_config(connection_info, info) cfg = self._get_volume_config(connection_info, info)
devices.append(cfg) devices.append(cfg)
vol['connection_info'] = connection_info vol['connection_info'] = connection_info
@ -4885,7 +4886,8 @@ class LibvirtDriver(driver.ComputeDriver):
if root_disk: if root_disk:
disk_info = blockinfo.get_info_from_bdm( disk_info = blockinfo.get_info_from_bdm(
instance, CONF.libvirt.virt_type, image_meta, root_disk) instance, CONF.libvirt.virt_type, image_meta, root_disk)
self._connect_volume(root_disk['connection_info'], disk_info) self._connect_volume(root_disk['connection_info'], disk_info,
instance)
disk_path = root_disk['connection_info']['data']['device_path'] disk_path = root_disk['connection_info']['data']['device_path']
# NOTE(apmelton) - Even though the instance is being booted from a # NOTE(apmelton) - Even though the instance is being booted from a
@ -6675,7 +6677,7 @@ class LibvirtDriver(driver.ComputeDriver):
disk_info = blockinfo.get_info_from_bdm( disk_info = blockinfo.get_info_from_bdm(
instance, CONF.libvirt.virt_type, instance, CONF.libvirt.virt_type,
instance.image_meta, bdm) instance.image_meta, bdm)
self._connect_volume(connection_info, disk_info) self._connect_volume(connection_info, disk_info, instance)
# We call plug_vifs before the compute manager calls # We call plug_vifs before the compute manager calls
# ensure_filtering_rules_for_instance, to ensure bridge is set up # ensure_filtering_rules_for_instance, to ensure bridge is set up
@ -6866,7 +6868,7 @@ class LibvirtDriver(driver.ComputeDriver):
connection_info['data']['multipath_id'] = multipath_id connection_info['data']['multipath_id'] = multipath_id
disk_dev = vol['mount_device'].rpartition("/")[2] disk_dev = vol['mount_device'].rpartition("/")[2]
self._disconnect_volume(connection_info, disk_dev) self._disconnect_volume(connection_info, disk_dev, instance)
def post_live_migration_at_source(self, context, instance, network_info): def post_live_migration_at_source(self, context, instance, network_info):
"""Unplug VIFs from networks at source. """Unplug VIFs from networks at source.
@ -7229,7 +7231,7 @@ class LibvirtDriver(driver.ComputeDriver):
for vol in block_device_mapping: for vol in block_device_mapping:
connection_info = vol['connection_info'] connection_info = vol['connection_info']
disk_dev = vol['mount_device'].rpartition("/")[2] disk_dev = vol['mount_device'].rpartition("/")[2]
self._disconnect_volume(connection_info, disk_dev) self._disconnect_volume(connection_info, disk_dev, instance)
disk_info_text = self.get_instance_disk_info( disk_info_text = self.get_instance_disk_info(
instance, block_device_info=block_device_info) instance, block_device_info=block_device_info)

View File

@ -43,14 +43,14 @@ class LibvirtAOEVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
conf.source_path = connection_info['data']['device_path'] conf.source_path = connection_info['data']['device_path']
return conf return conf
def connect_volume(self, connection_info, mount_device): def connect_volume(self, connection_info, disk_info, instance):
LOG.debug("Calling os-brick to attach AoE Volume") LOG.debug("Calling os-brick to attach AoE Volume")
device_info = self.connector.connect_volume(connection_info['data']) device_info = self.connector.connect_volume(connection_info['data'])
LOG.debug("Attached AoE volume %s", device_info) LOG.debug("Attached AoE volume %s", device_info)
connection_info['data']['device_path'] = device_info['path'] connection_info['data']['device_path'] = device_info['path']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Detach the volume from instance_name.""" """Detach the volume from instance_name."""
LOG.debug("calling os-brick to detach AoE Volume %s", LOG.debug("calling os-brick to detach AoE Volume %s",
@ -59,4 +59,4 @@ class LibvirtAOEVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
LOG.debug("Disconnected AoE Volume %s", disk_dev) LOG.debug("Disconnected AoE Volume %s", disk_dev)
super(LibvirtAOEVolumeDriver, super(LibvirtAOEVolumeDriver,
self).disconnect_volume(connection_info, disk_dev) self).disconnect_volume(connection_info, disk_dev, instance)

View File

@ -49,13 +49,13 @@ class LibvirtDISCOVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
conf.source_type = 'file' conf.source_type = 'file'
return conf return conf
def connect_volume(self, connection_info, disk_info): def connect_volume(self, connection_info, disk_info, instance):
"""Connect a DISCO volume to a compute node.""" """Connect a DISCO volume to a compute node."""
device_info = self.connector.connect_volume(connection_info['data']) device_info = self.connector.connect_volume(connection_info['data'])
connection_info['data']['device_path'] = device_info['path'] connection_info['data']['device_path'] = device_info['path']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Disconnect a DISCO volume of a compute node.""" """Disconnect a DISCO volume of a compute node."""
self.connector.disconnect_volume(connection_info['data'], None) self.connector.disconnect_volume(connection_info['data'], None)
super(LibvirtDISCOVolumeDriver, self).disconnect_volume( super(LibvirtDISCOVolumeDriver, self).disconnect_volume(
connection_info, disk_dev) connection_info, disk_dev, instance)

View File

@ -46,7 +46,7 @@ class LibvirtFibreChannelVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
conf.driver_io = "native" conf.driver_io = "native"
return conf return conf
def connect_volume(self, connection_info, disk_info): def connect_volume(self, connection_info, disk_info, instance):
"""Attach the volume to instance_name.""" """Attach the volume to instance_name."""
LOG.debug("Calling os-brick to attach FC Volume") LOG.debug("Calling os-brick to attach FC Volume")
@ -58,7 +58,7 @@ class LibvirtFibreChannelVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
connection_info['data']['multipath_id'] = \ connection_info['data']['multipath_id'] = \
device_info['multipath_id'] device_info['multipath_id']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Detach the volume from instance_name.""" """Detach the volume from instance_name."""
LOG.debug("calling os-brick to detach FC Volume") LOG.debug("calling os-brick to detach FC Volume")
@ -72,4 +72,4 @@ class LibvirtFibreChannelVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
LOG.debug("Disconnected FC Volume %s", disk_dev) LOG.debug("Disconnected FC Volume %s", disk_dev)
super(LibvirtFibreChannelVolumeDriver, super(LibvirtFibreChannelVolumeDriver,
self).disconnect_volume(connection_info, disk_dev) self).disconnect_volume(connection_info, disk_dev, instance)

View File

@ -41,11 +41,11 @@ class LibvirtHGSTVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
conf.source_path = connection_info['data']['device_path'] conf.source_path = connection_info['data']['device_path']
return conf return conf
def connect_volume(self, connection_info, mount_device): def connect_volume(self, connection_info, disk_info, instance):
device_info = self.connector.connect_volume(connection_info['data']) device_info = self.connector.connect_volume(connection_info['data'])
connection_info['data']['device_path'] = device_info['path'] connection_info['data']['device_path'] = device_info['path']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
self.connector.disconnect_volume(connection_info['data'], None) self.connector.disconnect_volume(connection_info['data'], None)
super(LibvirtHGSTVolumeDriver, super(LibvirtHGSTVolumeDriver,
self).disconnect_volume(connection_info, disk_dev) self).disconnect_volume(connection_info, disk_dev, instance)

View File

@ -57,7 +57,7 @@ class LibvirtISCSIVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
conf.driver_io = "native" conf.driver_io = "native"
return conf return conf
def connect_volume(self, connection_info, disk_info): def connect_volume(self, connection_info, disk_info, instance):
"""Attach the volume to instance_name.""" """Attach the volume to instance_name."""
LOG.debug("Calling os-brick to attach iSCSI Volume") LOG.debug("Calling os-brick to attach iSCSI Volume")
@ -66,7 +66,7 @@ class LibvirtISCSIVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
connection_info['data']['device_path'] = device_info['path'] connection_info['data']['device_path'] = device_info['path']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Detach the volume from instance_name.""" """Detach the volume from instance_name."""
LOG.debug("calling os-brick to detach iSCSI Volume") LOG.debug("calling os-brick to detach iSCSI Volume")
@ -78,4 +78,4 @@ class LibvirtISCSIVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
LOG.debug("Disconnected iSCSI Volume %s", disk_dev) LOG.debug("Disconnected iSCSI Volume %s", disk_dev)
super(LibvirtISCSIVolumeDriver, super(LibvirtISCSIVolumeDriver,
self).disconnect_volume(connection_info, disk_dev) self).disconnect_volume(connection_info, disk_dev, instance)

View File

@ -115,8 +115,8 @@ class LibvirtNetVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
self._set_auth_config_iscsi(conf, netdisk_properties) self._set_auth_config_iscsi(conf, netdisk_properties)
return conf return conf
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Detach the volume from instance_name.""" """Detach the volume from instance_name."""
super(LibvirtNetVolumeDriver, super(LibvirtNetVolumeDriver,
self).disconnect_volume(connection_info, disk_dev) self).disconnect_volume(connection_info, disk_dev, instance)
self._delete_secret_by_name(connection_info) self._delete_secret_by_name(connection_info)

View File

@ -48,14 +48,14 @@ class LibvirtScaleIOVolumeDriver(libvirt_volume.LibvirtBaseVolumeDriver):
conf.source_path = connection_info['data']['device_path'] conf.source_path = connection_info['data']['device_path']
return conf return conf
def connect_volume(self, connection_info, disk_info): def connect_volume(self, connection_info, disk_info, instance):
device_info = self.connector.connect_volume(connection_info['data']) device_info = self.connector.connect_volume(connection_info['data'])
LOG.debug("Attached ScaleIO volume %s.", device_info) LOG.debug("Attached ScaleIO volume %s.", device_info)
connection_info['data']['device_path'] = device_info['path'] connection_info['data']['device_path'] = device_info['path']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
self.connector.disconnect_volume(connection_info['data'], None) self.connector.disconnect_volume(connection_info['data'], None)
LOG.debug("Disconnected volume %s.", disk_dev) LOG.debug("Disconnected volume %s.", disk_dev)
super(LibvirtScaleIOVolumeDriver, self).disconnect_volume( super(LibvirtScaleIOVolumeDriver, self).disconnect_volume(
connection_info, disk_dev) connection_info, disk_dev, instance)

View File

@ -97,11 +97,11 @@ class LibvirtBaseVolumeDriver(object):
return conf return conf
def connect_volume(self, connection_info, disk_info): def connect_volume(self, connection_info, disk_info, instance):
"""Connect the volume.""" """Connect the volume."""
pass pass
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Disconnect the volume.""" """Disconnect the volume."""
pass pass

View File

@ -108,7 +108,7 @@ class LibvirtVZStorageVolumeDriver(fs.LibvirtBaseFileSystemVolumeDriver):
return ' '.join(mount_opts) return ' '.join(mount_opts)
def connect_volume(self, connection_info, disk_info): def connect_volume(self, connection_info, disk_info, instance):
"""Attach the volume to instance_name.""" """Attach the volume to instance_name."""
LOG.debug("Calling os-brick to mount vzstorage") LOG.debug("Calling os-brick to mount vzstorage")
@ -119,7 +119,7 @@ class LibvirtVZStorageVolumeDriver(fs.LibvirtBaseFileSystemVolumeDriver):
connection_info['data']['device_path'] = device_info['path'] connection_info['data']['device_path'] = device_info['path']
def disconnect_volume(self, connection_info, disk_dev): def disconnect_volume(self, connection_info, disk_dev, instance):
"""Detach the volume from instance_name.""" """Detach the volume from instance_name."""
LOG.debug("calling os-brick to detach Vzstorage Volume") LOG.debug("calling os-brick to detach Vzstorage Volume")