Merge "Provides mount point as cinder requires it to attach volume"

This commit is contained in:
Zuul 2019-02-04 16:39:36 +00:00 committed by Gerrit Code Review
commit d9ed28b596
3 changed files with 21 additions and 10 deletions

View File

@ -307,10 +307,10 @@ def attach_volumes(task, volume_list, connector):
# database record to indicate that the attachment has
# been completed, which moves the volume to the
# 'attached' state. This action also sets a mountpoint
# for the volume, if known. In our use case, there is
# no way for us to know what the mountpoint is inside of
# the operating system, thus we send None.
client.volumes.attach(volume_id, instance_uuid, None)
# for the volume, as cinder requires a mointpoint to
# attach the volume, thus we send 'mount_volume'.
client.volumes.attach(volume_id, instance_uuid,
'ironic_mountpoint')
except cinder_exceptions.ClientException as e:
msg = (_('Failed to inform cinder that the attachment for volume '

View File

@ -195,6 +195,7 @@ class TestCinderActions(db_base.DbTestCase):
self.node = object_utils.create_test_node(
self.context,
instance_uuid=uuidutils.generate_uuid())
self.mount_point = 'ironic_mountpoint'
@mock.patch.object(cinderclient.volumes.VolumeManager, 'attach',
autospec=True)
@ -239,7 +240,8 @@ class TestCinderActions(db_base.DbTestCase):
mock_reserve.assert_called_once_with(mock.ANY, volume_id)
mock_init.assert_called_once_with(mock.ANY, volume_id, connector)
mock_attach.assert_called_once_with(mock.ANY, volume_id,
self.node.instance_uuid, None)
self.node.instance_uuid,
self.mount_point)
mock_set_meta.assert_called_once_with(mock.ANY, volume_id,
{'bar': 'baz'})
mock_get.assert_called_once_with(mock.ANY, volume_id)
@ -271,7 +273,6 @@ class TestCinderActions(db_base.DbTestCase):
'ironic_volume_uuid': '000-001'}}]
volumes = [volume_id, 'already_attached']
connector = {'foo': 'bar'}
mock_create_meta.return_value = {'bar': 'baz'}
mock_get.side_effect = [
@ -294,7 +295,8 @@ class TestCinderActions(db_base.DbTestCase):
mock_reserve.assert_called_once_with(mock.ANY, volume_id)
mock_init.assert_called_once_with(mock.ANY, volume_id, connector)
mock_attach.assert_called_once_with(mock.ANY, volume_id,
self.node.instance_uuid, None)
self.node.instance_uuid,
self.mount_point)
mock_set_meta.assert_called_once_with(mock.ANY, volume_id,
{'bar': 'baz'})
@ -355,7 +357,7 @@ class TestCinderActions(db_base.DbTestCase):
mock.ANY, '111111111-0000-0000-0000-000000000003', connector)
mock_attach.assert_called_once_with(
mock.ANY, '111111111-0000-0000-0000-000000000003',
self.node.instance_uuid, None)
self.node.instance_uuid, self.mount_point)
mock_set_meta.assert_called_once_with(
mock.ANY, '111111111-0000-0000-0000-000000000003', {'bar': 'baz'})
@ -446,7 +448,8 @@ class TestCinderActions(db_base.DbTestCase):
mock_reserve.assert_called_once_with(mock.ANY, volume_id)
mock_init.assert_called_once_with(mock.ANY, volume_id, connector)
mock_attach.assert_called_once_with(mock.ANY, volume_id,
self.node.instance_uuid, None)
self.node.instance_uuid,
self.mount_point)
mock_get.assert_called_once_with(mock.ANY, volume_id)
mock_is_attached.assert_called_once_with(mock.ANY,
mock_get.return_value)
@ -496,7 +499,8 @@ class TestCinderActions(db_base.DbTestCase):
mock_reserve.assert_called_once_with(mock.ANY, volume_id)
mock_init.assert_called_once_with(mock.ANY, volume_id, connector)
mock_attach.assert_called_once_with(mock.ANY, volume_id,
self.node.instance_uuid, None)
self.node.instance_uuid,
self.mount_point)
mock_set_meta.assert_called_once_with(mock.ANY, volume_id,
{'bar': 'baz'})
mock_get.assert_called_once_with(mock.ANY, volume_id)

View File

@ -0,0 +1,7 @@
---
fixes:
- |
Fixes a bug where cinder block storage service volumes volume fail to attach expecting a
mountpoint to be a valid string. See `story 2004864
<https://storyboard.openstack.org/#!/story/2004864>`_ for additional
information.