Merge "Fix outputs validation place in Stack.validate"

This commit is contained in:
Jenkins 2014-12-02 10:16:00 +00:00 committed by Gerrit Code Review
commit 2ed4b0cbfc
2 changed files with 50 additions and 15 deletions

View File

@ -480,22 +480,22 @@ class Stack(collections.Mapping):
if result: if result:
raise exception.StackValidationFailed(message=result) raise exception.StackValidationFailed(message=result)
for val in self.outputs.values(): for val in self.outputs.values():
try: try:
if not val or not val.get('Value'): if not val or not val.get('Value'):
message = _('Each Output must contain ' message = _('Each Output must contain '
'a Value key.') 'a Value key.')
raise exception.StackValidationFailed(message=message)
function.validate(val.get('Value'))
except AttributeError:
message = _('Output validation error: '
'Outputs must contain Output. '
'Found a [%s] instead') % type(val)
raise exception.StackValidationFailed(message=message) raise exception.StackValidationFailed(message=message)
except Exception as ex: function.validate(val.get('Value'))
reason = _('Output validation error: ' except AttributeError:
'%s') % six.text_type(ex) message = _('Output validation error: '
raise exception.StackValidationFailed(message=reason) 'Outputs must contain Output. '
'Found a [%s] instead') % type(val)
raise exception.StackValidationFailed(message=message)
except Exception as ex:
reason = _('Output validation error: '
'%s') % six.text_type(ex)
raise exception.StackValidationFailed(message=reason)
def requires_deferred_auth(self): def requires_deferred_auth(self):
''' '''

View File

@ -4268,6 +4268,41 @@ class StackTest(common.HeatTestCase):
'(AResource Bar) is incorrect.', '(AResource Bar) is incorrect.',
six.text_type(ex)) six.text_type(ex))
def test_incorrect_outputs_cfn_incorrect_reference(self):
tmpl = template_format.parse("""
HeatTemplateFormatVersion: '2012-12-12'
Outputs:
Output:
Value:
Fn::GetAtt:
- Resource
- Foo
""")
self.stack = parser.Stack(self.ctx, 'stack_with_incorrect_outputs',
template.Template(tmpl))
ex = self.assertRaises(exception.StackValidationFailed,
self.stack.validate)
self.assertIn('The specified reference "Resource" '
'(in unknown) is incorrect.', six.text_type(ex))
def test_incorrect_outputs_incorrect_reference(self):
tmpl = template_format.parse("""
heat_template_version: 2013-05-23
outputs:
output:
value: { get_attr: [resource, foo] }
""")
self.stack = parser.Stack(self.ctx, 'stack_with_incorrect_outputs',
template.Template(tmpl))
ex = self.assertRaises(exception.StackValidationFailed,
self.stack.validate)
self.assertIn('The specified reference "resource" '
'(in unknown) is incorrect.', six.text_type(ex))
def test_incorrect_outputs_cfn_empty_output(self): def test_incorrect_outputs_cfn_empty_output(self):
tmpl = template_format.parse(""" tmpl = template_format.parse("""
HeatTemplateFormatVersion: '2012-12-12' HeatTemplateFormatVersion: '2012-12-12'