fix workflow exception on host aggregate create form

Under the circumstance that there are existing aggregates, this bug
happens when create button is clicked without the required "name" field
filled. Error toast shows instead of the expected error message on the
create form.
When the form posts without name filed filled, the name attribute in the
clean data is None instead of an empty string, which causes
AttributeError on the following string operation.

1. patch an empty string as the fallback value for the 'name' variable
2. corresponding unit test is attached

Change-Id: I0bdf469d87aa06ab58b73e6ce41bdf63bb36a538
Closes-Bug: #1617140
This commit is contained in:
shlo 2016-09-01 11:27:49 +08:00
parent d8b6fa9e44
commit eedac01a9c
2 changed files with 12 additions and 1 deletions

View File

@ -117,6 +117,17 @@ class CreateAggregateWorkflowTests(BaseAggregateWorkflowTests):
self._test_generic_create_aggregate(workflow_data, aggregate, (), 1, self._test_generic_create_aggregate(workflow_data, aggregate, (), 1,
u'This field is required') u'This field is required')
def test_create_aggregate_fails_missing_fields_existing_aggregates(self):
aggregate = self.aggregates.first()
existing_aggregates = self.aggregates.list()
workflow_data = self._get_create_workflow_data(aggregate)
workflow_data['name'] = ''
workflow_data['availability_zone'] = ''
self._test_generic_create_aggregate(workflow_data, aggregate,
existing_aggregates, 1,
u'This field is required')
def test_create_aggregate_fails_duplicated_name(self): def test_create_aggregate_fails_duplicated_name(self):
aggregate = self.aggregates.first() aggregate = self.aggregates.first()
existing_aggregates = self.aggregates.list() existing_aggregates = self.aggregates.list()

View File

@ -37,7 +37,7 @@ class SetAggregateInfoAction(workflows.Action):
def clean(self): def clean(self):
cleaned_data = super(SetAggregateInfoAction, self).clean() cleaned_data = super(SetAggregateInfoAction, self).clean()
name = cleaned_data.get('name') name = cleaned_data.get('name', '')
try: try:
aggregates = api.nova.aggregate_details_list(self.request) aggregates = api.nova.aggregate_details_list(self.request)