Fix error msg invalid stack or res name
If template contains resource with name like 'res/name', we will get traceback instead of correct error message. The same situation with stack name: if it's incorrect, we will get traceback. Change-Id: I4a0e51ff649aaaad5f18f52383dab186dab54230 Closes-bug: #1397313
This commit is contained in:
parent
951841adbf
commit
9c877f3172
@ -155,9 +155,13 @@ class Resource(object):
|
||||
return super(Resource, cls).__new__(ResourceClass)
|
||||
|
||||
def __init__(self, name, definition, stack):
|
||||
if '/' in name:
|
||||
raise ValueError(_('Resource name may not contain "/"'))
|
||||
|
||||
def _validate_name(res_name):
|
||||
if '/' in res_name:
|
||||
message = _('Resource name may not contain "/"')
|
||||
raise exception.StackValidationFailed(message=message)
|
||||
|
||||
_validate_name(name)
|
||||
self.stack = stack
|
||||
self.context = stack.context
|
||||
self.name = name
|
||||
|
@ -86,12 +86,15 @@ class Stack(collections.Mapping):
|
||||
stack is already in the database.
|
||||
'''
|
||||
|
||||
def _validate_stack_name(name):
|
||||
if not re.match("[a-zA-Z][a-zA-Z0-9_.-]*$", name):
|
||||
message = _('Invalid stack name %s must contain '
|
||||
'only alphanumeric or \"_-.\" characters, '
|
||||
'must start with alpha') % name
|
||||
raise exception.StackValidationFailed(message=message)
|
||||
|
||||
if owner_id is None:
|
||||
if re.match("[a-zA-Z][a-zA-Z0-9_.-]*$", stack_name) is None:
|
||||
raise ValueError(_('Invalid stack name %s'
|
||||
' must contain only alphanumeric or '
|
||||
'\"_-.\" characters, must start with alpha'
|
||||
) % stack_name)
|
||||
_validate_stack_name(stack_name)
|
||||
|
||||
self.id = stack_id
|
||||
self.owner_id = owner_id
|
||||
|
@ -592,7 +592,7 @@ class StackServiceCreateUpdateDeleteTest(common.HeatTestCase):
|
||||
stack_name = 'service_create/test_stack'
|
||||
stack = get_wordpress_stack('test_stack', self.ctx)
|
||||
|
||||
self.assertRaises(ValueError,
|
||||
self.assertRaises(dispatcher.ExpectedException,
|
||||
self.man.create_stack,
|
||||
self.ctx, stack_name, stack.t.t, {}, None, {})
|
||||
|
||||
@ -603,7 +603,7 @@ class StackServiceCreateUpdateDeleteTest(common.HeatTestCase):
|
||||
tmpl['Resources']['Web/Server'] = tmpl['Resources']['WebServer']
|
||||
del tmpl['Resources']['WebServer']
|
||||
|
||||
self.assertRaises(ValueError,
|
||||
self.assertRaises(dispatcher.ExpectedException,
|
||||
self.man.create_stack,
|
||||
self.ctx, stack_name,
|
||||
stack.t.t, {}, None, {})
|
||||
|
@ -3667,38 +3667,13 @@ class StackTest(common.HeatTestCase):
|
||||
self.assertIsInstance(stack, parser.Stack)
|
||||
|
||||
def test_stack_name_invalid(self):
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '_foo',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '1bad',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '.kcats',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'test stack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, ' teststack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '^-^',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '\"stack\"',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '1234',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'cat|dog',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '$(foo)',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'test/stack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'test\stack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'test::stack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'test;stack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, 'test~stack',
|
||||
self.tmpl)
|
||||
self.assertRaises(ValueError, parser.Stack, self.ctx, '#test',
|
||||
self.tmpl)
|
||||
stack_names = ['_foo', '1bad', '.kcats', 'test stack', ' teststack',
|
||||
'^-^', '\"stack\"', '1234', 'cat|dog', '$(foo)',
|
||||
'test/stack', 'test\stack', 'test::stack', 'test;stack',
|
||||
'test~stack', '#test']
|
||||
for stack_name in stack_names:
|
||||
self.assertRaises(exception.StackValidationFailed, parser.Stack,
|
||||
self.ctx, stack_name, self.tmpl)
|
||||
|
||||
def test_resource_state_get_att(self):
|
||||
tmpl = {
|
||||
|
@ -80,6 +80,15 @@ class ResourceTest(common.HeatTestCase):
|
||||
self.assertIsInstance(res, generic_rsrc.GenericResource)
|
||||
self.assertEqual("INIT", res.action)
|
||||
|
||||
def test_resource_invalid_name(self):
|
||||
snippet = rsrc_defn.ResourceDefinition('wrong/name',
|
||||
'GenericResourceType')
|
||||
ex = self.assertRaises(exception.StackValidationFailed,
|
||||
resource.Resource, 'wrong/name',
|
||||
snippet, self.stack)
|
||||
self.assertEqual('Resource name may not contain "/"',
|
||||
six.text_type(ex))
|
||||
|
||||
def test_resource_new_stack_not_stored(self):
|
||||
snippet = rsrc_defn.ResourceDefinition('aresource',
|
||||
'GenericResourceType')
|
||||
|
Loading…
Reference in New Issue
Block a user