Merge "Further robustification of format_inspector"

This commit is contained in:
Zuul 2023-02-15 23:34:08 +00:00 committed by Gerrit Code Review
commit 81da9ccbde
2 changed files with 43 additions and 4 deletions

View File

@ -584,15 +584,23 @@ class ImageProxy(glance.domain.proxy.Image):
self._upload_to_store(data, verifier, backend, size) self._upload_to_store(data, verifier, backend, size)
if fmt and fmt.format_match and fmt.virtual_size: virtual_size = 0
self.image.virtual_size = fmt.virtual_size if fmt and fmt.format_match:
try:
virtual_size = fmt.virtual_size
LOG.info('Image format matched and virtual size computed: %i', LOG.info('Image format matched and virtual size computed: %i',
self.image.virtual_size) virtual_size)
except Exception as e:
LOG.error(_LE('Unable to determine virtual_size because: %s'),
e)
elif fmt: elif fmt:
LOG.warning('Image format %s did not match; ' LOG.warning('Image format %s did not match; '
'unable to calculate virtual size', 'unable to calculate virtual size',
self.image.disk_format) self.image.disk_format)
if virtual_size:
self.image.virtual_size = fmt.virtual_size
if set_active and self.image.status != 'active': if set_active and self.image.status != 'active':
self.image.status = 'active' self.image.status = 'active'

View File

@ -283,6 +283,37 @@ class TestStoreImage(utils.BaseTestCase):
self.assertEqual('active', image.status) self.assertEqual('active', image.status)
self.assertEqual(0, image.virtual_size) self.assertEqual(0, image.virtual_size)
@mock.patch('glance.common.format_inspector.QcowInspector.virtual_size',
new_callable=mock.PropertyMock)
@mock.patch('glance.common.format_inspector.QcowInspector.format_match',
new_callable=mock.PropertyMock)
def test_image_set_data_inspector_virtual_size_failure(self, mock_fm,
mock_vs):
# Force our format to match
mock_fm.return_value = True
# Make virtual_size fail in some unexpected way
mock_vs.side_effect = ValueError('some error')
context = glance.context.RequestContext(user=USER1)
image_stub = ImageStub(UUID2, status='queued', locations=[])
image_stub.disk_format = 'qcow2'
# We are going to pass an iterable data source, so use the
# FakeStoreAPIReader that actually reads from that data
store_api = unit_test_utils.FakeStoreAPIReader()
image = glance.location.ImageProxy(image_stub, context,
store_api, self.store_utils)
# Make sure set_data proceeds even though the format clearly
# does not match
image.set_data(iter(['YYYY']), 4)
self.assertEqual(4, image.size)
# NOTE(markwash): FakeStore returns image_id for location
self.assertEqual(UUID2, image.locations[0]['url'])
self.assertEqual('Z', image.checksum)
self.assertEqual('active', image.status)
self.assertEqual(0, image.virtual_size)
@mock.patch('glance.common.format_inspector.get_inspector') @mock.patch('glance.common.format_inspector.get_inspector')
def test_image_set_data_inspector_not_needed(self, mock_gi): def test_image_set_data_inspector_not_needed(self, mock_gi):
context = glance.context.RequestContext(user=USER1) context = glance.context.RequestContext(user=USER1)