Merge "Render hidden stack parameters with a password field"

This commit is contained in:
Jenkins 2014-09-04 14:16:09 +00:00 committed by Gerrit Code Review
commit 8a83578bcc
2 changed files with 58 additions and 0 deletions

View File

@ -23,6 +23,7 @@ from horizon import forms
from horizon import messages from horizon import messages
from openstack_dashboard import api from openstack_dashboard import api
from openstack_dashboard.openstack.common import strutils
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -294,6 +295,7 @@ class CreateStackForm(forms.SelfHandlingForm):
} }
param_type = param.get('Type', None) param_type = param.get('Type', None)
hidden = strutils.bool_from_string(param.get('NoEcho', 'false'))
if 'AllowedValues' in param: if 'AllowedValues' in param:
choices = map(lambda x: (x, x), param['AllowedValues']) choices = map(lambda x: (x, x), param['AllowedValues'])
@ -306,6 +308,8 @@ class CreateStackForm(forms.SelfHandlingForm):
field_args['required'] = param.get('MinLength', 0) > 0 field_args['required'] = param.get('MinLength', 0) > 0
if 'MaxLength' in param: if 'MaxLength' in param:
field_args['max_length'] = int(param['MaxLength']) field_args['max_length'] = int(param['MaxLength'])
if hidden:
field_args['widget'] = forms.PasswordInput()
field = forms.CharField(**field_args) field = forms.CharField(**field_args)
elif param_type == 'Number': elif param_type == 'Number':

View File

@ -315,6 +315,60 @@ class StackTests(test.TestCase):
res = self.client.post(url, form_data) res = self.client.post(url, form_data)
self.assertRedirectsNoFollow(res, INDEX_URL) self.assertRedirectsNoFollow(res, INDEX_URL)
@test.create_stubs({api.heat: ('template_validate',)})
def test_launch_stack_with_hidden_parameters(self):
template = {
'data': ('heat_template_version: 2013-05-23\n'
'parameters:\n'
' public_string:\n'
' type: string\n'
' secret_string:\n'
' type: string\n'
' hidden: true\n'),
'validate': {
'Description': 'No description',
'Parameters': {
'public_string': {
'Label': 'public_string',
'Description': '',
'Type': 'String',
'NoEcho': 'false'
},
'secret_string': {
'Label': 'secret_string',
'Description': '',
'Type': 'String',
'NoEcho': 'true'
}
}
}
}
api.heat.template_validate(IsA(http.HttpRequest),
template=template['data']) \
.AndReturn(template['validate'])
self.mox.ReplayAll()
url = reverse('horizon:project:stacks:select_template')
res = self.client.get(url)
self.assertTemplateUsed(res, 'project/stacks/select_template.html')
form_data = {'template_source': 'raw',
'template_data': template['data'],
'method': forms.TemplateForm.__name__}
res = self.client.post(url, form_data)
self.assertTemplateUsed(res, 'project/stacks/create.html')
# ensure the fields were rendered correctly
self.assertContains(res, '<input class=" form-control" '
'id="id___param_public_string" '
'name="__param_public_string" '
'type="text" />', html=True)
self.assertContains(res, '<input class=" form-control" '
'id="id___param_secret_string" '
'name="__param_secret_string" '
'type="password" />', html=True)
@test.create_stubs({api.heat: ('stack_update', 'stack_get', @test.create_stubs({api.heat: ('stack_update', 'stack_get',
'template_get', 'template_validate')}) 'template_get', 'template_validate')})
def test_edit_stack_template(self): def test_edit_stack_template(self):