Adds ignore_errors for template_validate REST API

Adds additional parameter ignore_errors to ignore set
of errors during the template valation in API.

APIImpact

implements blueprint heat-template-validate-improvements

Change-Id: Ib8a6d6be4509857bbc90c8f604a882b7a706da10
This commit is contained in:
Kanagaraj Manickam 2015-11-18 16:02:00 +05:30
parent 29e5d96d50
commit 692059eeb0
6 changed files with 37 additions and 20 deletions

View File

@ -560,7 +560,8 @@ class StackController(object):
data = InstantiationData(body) data = InstantiationData(body)
whitelist = {'show_nested': util.PARAM_TYPE_SINGLE} whitelist = {'show_nested': util.PARAM_TYPE_SINGLE,
'ignore_errors': util.PARAM_TYPE_SINGLE}
params = util.get_allowed_params(req.params, whitelist) params = util.get_allowed_params(req.params, whitelist)
show_nested = False show_nested = False
@ -569,13 +570,19 @@ class StackController(object):
params[p_name] = self._extract_bool_param(p_name, params[p_name]) params[p_name] = self._extract_bool_param(p_name, params[p_name])
show_nested = params[p_name] show_nested = params[p_name]
if rpc_api.PARAM_IGNORE_ERRORS in params:
ignorable_errors = params[rpc_api.PARAM_IGNORE_ERRORS].split(',')
else:
ignorable_errors = None
result = self.rpc_client.validate_template( result = self.rpc_client.validate_template(
req.context, req.context,
data.template(), data.template(),
data.environment(), data.environment(),
files=data.files(), files=data.files(),
environment_files=data.environment_files(), environment_files=data.environment_files(),
show_nested=show_nested) show_nested=show_nested,
ignorable_errors=ignorable_errors)
if 'Error' in result: if 'Error' in result:
raise exc.HTTPBadRequest(result['Error']) raise exc.HTTPBadRequest(result['Error'])

View File

@ -20,14 +20,14 @@ PARAM_KEYS = (
PARAM_CLEAR_PARAMETERS, PARAM_GLOBAL_TENANT, PARAM_LIMIT, PARAM_CLEAR_PARAMETERS, PARAM_GLOBAL_TENANT, PARAM_LIMIT,
PARAM_NESTED_DEPTH, PARAM_TAGS, PARAM_SHOW_HIDDEN, PARAM_TAGS_ANY, PARAM_NESTED_DEPTH, PARAM_TAGS, PARAM_SHOW_HIDDEN, PARAM_TAGS_ANY,
PARAM_NOT_TAGS, PARAM_NOT_TAGS_ANY, TEMPLATE_TYPE, PARAM_WITH_DETAIL, PARAM_NOT_TAGS, PARAM_NOT_TAGS_ANY, TEMPLATE_TYPE, PARAM_WITH_DETAIL,
RESOLVE_OUTPUTS RESOLVE_OUTPUTS, PARAM_IGNORE_ERRORS
) = ( ) = (
'timeout_mins', 'disable_rollback', 'adopt_stack_data', 'timeout_mins', 'disable_rollback', 'adopt_stack_data',
'show_deleted', 'show_nested', 'existing', 'show_deleted', 'show_nested', 'existing',
'clear_parameters', 'global_tenant', 'limit', 'clear_parameters', 'global_tenant', 'limit',
'nested_depth', 'tags', 'show_hidden', 'tags_any', 'nested_depth', 'tags', 'show_hidden', 'tags_any',
'not_tags', 'not_tags_any', 'template_type', 'with_detail', 'not_tags', 'not_tags_any', 'template_type', 'with_detail',
'resolve_outputs', 'resolve_outputs', 'ignore_errors'
) )
STACK_KEYS = ( STACK_KEYS = (

View File

@ -42,6 +42,7 @@ class EngineClient(object):
1.21 - Add deployment_id to create_software_deployment 1.21 - Add deployment_id to create_software_deployment
1.22 - Add support for stack export 1.22 - Add support for stack export
1.23 - Add environment_files to create/update/preview/validate 1.23 - Add environment_files to create/update/preview/validate
1.24 - Adds ignorable_errors to validate_template
""" """
BASE_RPC_API_VERSION = '1.0' BASE_RPC_API_VERSION = '1.0'
@ -318,7 +319,8 @@ class EngineClient(object):
version='1.23') version='1.23')
def validate_template(self, ctxt, template, params=None, files=None, def validate_template(self, ctxt, template, params=None, files=None,
environment_files=None, show_nested=False): environment_files=None, show_nested=False,
ignorable_errors=None):
"""Uses the stack parser to check the validity of a template. """Uses the stack parser to check the validity of a template.
:param ctxt: RPC context. :param ctxt: RPC context.
@ -328,15 +330,18 @@ class EngineClient(object):
:param environment_files: ordered list of environment file names :param environment_files: ordered list of environment file names
included in the files dict included in the files dict
:param show_nested: if True nested templates will be validated :param show_nested: if True nested templates will be validated
:param ignorable_errors: List of error_code to be ignored as part of
validation
""" """
return self.call(ctxt, return self.call(ctxt, self.make_msg(
self.make_msg('validate_template', 'validate_template',
template=template, template=template,
params=params, params=params,
files=files, files=files,
environment_files=environment_files, show_nested=show_nested,
show_nested=show_nested), environment_files=environment_files,
version='1.23') ignorable_errors=ignorable_errors),
version='1.24')
def authenticated_to_backend(self, ctxt): def authenticated_to_backend(self, ctxt):
"""Validate the credentials in the RPC context. """Validate the credentials in the RPC context.

View File

@ -1100,8 +1100,9 @@ class CfnStackControllerTest(common.HeatTestCase):
dummy_req.context, dummy_req.context,
('validate_template', {'template': json_template, 'params': None, ('validate_template', {'template': json_template, 'params': None,
'files': None, 'environment_files': None, 'files': None, 'environment_files': None,
'show_nested': False}), 'show_nested': False,
version='1.23' 'ignorable_errors': None}),
version='1.24'
).AndReturn(response) ).AndReturn(response)
self.m.ReplayAll() self.m.ReplayAll()

View File

@ -2248,8 +2248,9 @@ class StackControllerTest(tools.ControllerTest, common.HeatTestCase):
'resource_registry': {}}, 'resource_registry': {}},
'files': {}, 'files': {},
'environment_files': None, 'environment_files': None,
'show_nested': False}), 'show_nested': False,
version='1.23' 'ignorable_errors': None}),
version='1.24'
).AndReturn(engine_response) ).AndReturn(engine_response)
self.m.ReplayAll() self.m.ReplayAll()
@ -2278,8 +2279,9 @@ class StackControllerTest(tools.ControllerTest, common.HeatTestCase):
'resource_registry': {}}, 'resource_registry': {}},
'files': {}, 'files': {},
'environment_files': None, 'environment_files': None,
'show_nested': False}), 'show_nested': False,
version='1.23' 'ignorable_errors': None}),
version='1.24'
).AndReturn({'Error': 'fubar'}) ).AndReturn({'Error': 'fubar'})
self.m.ReplayAll() self.m.ReplayAll()

View File

@ -204,7 +204,9 @@ class EngineRpcAPITestCase(common.HeatTestCase):
params={u'Egg': u'spam'}, params={u'Egg': u'spam'},
files=None, files=None,
environment_files=['foo.yaml'], environment_files=['foo.yaml'],
show_nested=False) ignorable_errors=None,
show_nested=False,
version='1.24')
def test_list_resource_types(self): def test_list_resource_types(self):
self._test_engine_api('list_resource_types', self._test_engine_api('list_resource_types',