Merge "libvirt: Pass instance to connect_volume and disconnect_volume"
This commit is contained in:
commit
b9d4bc94ab
@ -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')
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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])
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user