Refactor: untie IloVendor from validate_image_properties
The function does more than just validating that the image exists. This change simplifies further refactoring of image validation. Change-Id: I9a3dc7ddabde38faa77a2c4bc7bf5db750a7f4d8
This commit is contained in:
parent
d7a5b3469c
commit
4dc1920154
@ -513,6 +513,30 @@ def validate_capabilities(node):
|
||||
'value': value, 'valid_values': ', '.join(valid_values)})
|
||||
|
||||
|
||||
def get_image_properties(ctx, image_href):
|
||||
"""Get properties of the image.
|
||||
|
||||
:param ctx: security context
|
||||
:param image_href: reference to the image
|
||||
:return: properties as a dictionary
|
||||
:raises: InvalidParameterValue if the image cannot be accessed
|
||||
"""
|
||||
try:
|
||||
img_service = image_service.get_image_service(image_href, context=ctx)
|
||||
return img_service.show(image_href)['properties']
|
||||
except (exception.GlanceConnectionFailed,
|
||||
exception.ImageNotAuthorized,
|
||||
exception.Invalid):
|
||||
raise exception.InvalidParameterValue(_(
|
||||
"Failed to connect to Glance to get the properties "
|
||||
"of the image %s") % image_href)
|
||||
except exception.ImageNotFound:
|
||||
raise exception.InvalidParameterValue(_(
|
||||
"Image %s can not be found.") % image_href)
|
||||
except exception.ImageRefValidationFailed as e:
|
||||
raise exception.InvalidParameterValue(err=e)
|
||||
|
||||
|
||||
def validate_image_properties(ctx, deploy_info, properties):
|
||||
"""Validate the image.
|
||||
|
||||
@ -540,20 +564,8 @@ def validate_image_properties(ctx, deploy_info, properties):
|
||||
"specified at the same time."))
|
||||
if not image_href:
|
||||
image_href = boot_iso
|
||||
try:
|
||||
img_service = image_service.get_image_service(image_href, context=ctx)
|
||||
image_props = img_service.show(image_href)['properties']
|
||||
except (exception.GlanceConnectionFailed,
|
||||
exception.ImageNotAuthorized,
|
||||
exception.Invalid):
|
||||
raise exception.InvalidParameterValue(_(
|
||||
"Failed to connect to Glance to get the properties "
|
||||
"of the image %s") % image_href)
|
||||
except exception.ImageNotFound:
|
||||
raise exception.InvalidParameterValue(_(
|
||||
"Image %s can not be found.") % image_href)
|
||||
except exception.ImageRefValidationFailed as e:
|
||||
raise exception.InvalidParameterValue(err=e)
|
||||
|
||||
image_props = get_image_properties(ctx, image_href)
|
||||
|
||||
missing_props = []
|
||||
for prop in properties:
|
||||
|
@ -66,12 +66,13 @@ class VendorPassthru(base.VendorInterface):
|
||||
{'node_uuid': task.node.uuid,
|
||||
'state': states.MANAGEABLE})
|
||||
raise exception.InvalidStateRequested(msg)
|
||||
d_info = {'boot_iso_href': kwargs.get('boot_iso_href')}
|
||||
boot_iso = kwargs.get('boot_iso_href')
|
||||
d_info = {'boot_iso_href': boot_iso}
|
||||
error_msg = _("Error validating input for boot_into_iso vendor "
|
||||
"passthru. Some parameters were not provided: ")
|
||||
deploy_utils.check_for_missing_params(d_info, error_msg)
|
||||
deploy_utils.validate_image_properties(
|
||||
task.context, {'image_source': kwargs.get('boot_iso_href')}, [])
|
||||
# Validate that the image exists
|
||||
deploy_utils.get_image_properties(task.context, boot_iso)
|
||||
|
||||
@METRICS.timer('IloVendorPassthru.boot_into_iso')
|
||||
@base.passthru(['POST'],
|
||||
|
@ -71,7 +71,7 @@ class VendorPassthruTestCase(test_common.BaseIloTest):
|
||||
task.driver.vendor._validate_boot_into_iso,
|
||||
task, {})
|
||||
|
||||
@mock.patch.object(deploy_utils, 'validate_image_properties',
|
||||
@mock.patch.object(deploy_utils, 'get_image_properties',
|
||||
spec_set=True, autospec=True)
|
||||
def test__validate_boot_into_iso_manage(self, validate_image_prop_mock):
|
||||
with task_manager.acquire(self.context, self.node.uuid,
|
||||
@ -81,9 +81,9 @@ class VendorPassthruTestCase(test_common.BaseIloTest):
|
||||
task.driver.vendor._validate_boot_into_iso(
|
||||
task, info)
|
||||
validate_image_prop_mock.assert_called_once_with(
|
||||
task.context, {'image_source': 'foo'}, [])
|
||||
task.context, 'foo')
|
||||
|
||||
@mock.patch.object(deploy_utils, 'validate_image_properties',
|
||||
@mock.patch.object(deploy_utils, 'get_image_properties',
|
||||
spec_set=True, autospec=True)
|
||||
def test__validate_boot_into_iso_maintenance(
|
||||
self, validate_image_prop_mock):
|
||||
@ -94,4 +94,4 @@ class VendorPassthruTestCase(test_common.BaseIloTest):
|
||||
task.driver.vendor._validate_boot_into_iso(
|
||||
task, info)
|
||||
validate_image_prop_mock.assert_called_once_with(
|
||||
task.context, {'image_source': 'foo'}, [])
|
||||
task.context, 'foo')
|
||||
|
Loading…
x
Reference in New Issue
Block a user