Merge "Fix: Roll back volume status during reimage failure"

This commit is contained in:
Zuul 2024-01-04 19:24:05 +00:00 committed by Gerrit Code Review
commit 9dd6dd7b90
3 changed files with 38 additions and 1 deletions

View File

@ -108,6 +108,22 @@ class VolumeReimageTestCase(base.BaseVolumeTestCase):
mock_reimage.assert_called_once_with(self.context, volume, mock_reimage.assert_called_once_with(self.context, volume,
self.image_meta) self.image_meta)
@mock.patch('cinder.volume.volume_utils.check_image_metadata')
@mock.patch('cinder.volume.rpcapi.VolumeAPI.reimage')
@ddt.data('available', 'error')
def test_volume_reimage_check_meta_exception(self, status, mock_reimage,
mock_check):
volume = tests_utils.create_volume(self.context)
volume.status = status
volume.save()
self.assertEqual(volume.status, status)
mock_check.side_effect = exception.ImageUnacceptable(
image_id=self.image_meta['id'], reason='')
# The available or error volume can be reimaged directly
self.assertRaises(exception.ImageUnacceptable, self.volume_api.reimage,
self.context, volume, self.image_meta['id'])
self.assertEqual(status, volume.status)
@mock.patch('cinder.volume.volume_utils.check_image_metadata') @mock.patch('cinder.volume.volume_utils.check_image_metadata')
@mock.patch('cinder.volume.rpcapi.VolumeAPI.reimage') @mock.patch('cinder.volume.rpcapi.VolumeAPI.reimage')
def test_volume_reimage_api_with_reimage_reserved(self, mock_reimage, def test_volume_reimage_api_with_reimage_reserved(self, mock_reimage,

View File

@ -2675,7 +2675,22 @@ class API(base.Base):
'status': volume.status}) 'status': volume.status})
raise exception.InvalidVolume(reason=msg) raise exception.InvalidVolume(reason=msg)
image_meta = self.image_service.show(context, image_id) image_meta = self.image_service.show(context, image_id)
try:
volume_utils.check_image_metadata(image_meta, volume['size']) volume_utils.check_image_metadata(image_meta, volume['size'])
# Currently we only raise InvalidInput and ImageUnacceptable
# exceptions in the check_image_metadata call but having Exception
# here makes it more generic since we want to roll back to original
# state in any case and we re-raise anyway.
# Also this helps makes adding new exceptions easier in the future.
except Exception:
with excutils.save_and_reraise_exception():
LOG.exception("Failed to reimage volume %(volume_id)s with "
"image %(image_id)s",
{'volume_id': volume.id, 'image_id': image_id})
volume.conditional_update(
{'status': volume.model.previous_status,
'previous_status': None},
{'status': 'downloading'})
self.volume_rpcapi.reimage(context, self.volume_rpcapi.reimage(context,
volume, volume,
image_meta) image_meta)

View File

@ -0,0 +1,6 @@
---
fixes:
- |
`Bug #2036994 <https://bugs.launchpad.net/cinder/+bug/2036994>`_: Fixed
rollback of volume status if the reimage operation fails while
checking image metadata.