Merge "Make SetAggregate inherit from cliff.Command"

This commit is contained in:
Jenkins 2016-03-01 08:29:03 +00:00 committed by Gerrit Code Review
commit d91e104670
4 changed files with 84 additions and 14 deletions

View File

@ -150,6 +150,18 @@ List of Backwards Incompatible Changes
* Bug: https://bugs.launchpad.net/python-openstackclient/+bug/1546065 * Bug: https://bugs.launchpad.net/python-openstackclient/+bug/1546065
* Commit: https://review.openstack.org/#/c/281088/ * Commit: https://review.openstack.org/#/c/281088/
13. `aggregate set` commands will no longer return the modified resource
Previously, modifying an aggregate would result in the new aggregate being
displayed to the user. To keep things consistent with other `set` commands,
we will no longer be showing the modified resource.
* In favor of: Use `set` then `show`
* As of: NA
* Removed in: NA
* Bug: https://bugs.launchpad.net/python-openstackclient/+bug/1546065
* Commit: https://review.openstack.org/#/c/281089/
For Developers For Developers
============== ==============

View File

@ -0,0 +1,56 @@
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import uuid
from functional.common import test
class AggregateTests(test.TestCase):
"""Functional tests for aggregate. """
NAME = uuid.uuid4().hex
HEADERS = ['Name']
FIELDS = ['name']
@classmethod
def setUpClass(cls):
opts = cls.get_show_opts(cls.FIELDS)
raw_output = cls.openstack('aggregate create ' + cls.NAME + opts)
expected = cls.NAME + '\n'
cls.assertOutput(expected, raw_output)
@classmethod
def tearDownClass(cls):
raw_output = cls.openstack('aggregate delete ' + cls.NAME)
cls.assertOutput('', raw_output)
def test_aggregate_list(self):
opts = self.get_list_opts(self.HEADERS)
raw_output = self.openstack('aggregate list' + opts)
self.assertIn(self.NAME, raw_output)
def test_aggregate_show(self):
opts = self.get_show_opts(self.FIELDS)
raw_output = self.openstack('aggregate show ' + self.NAME + opts)
self.assertEqual(self.NAME + "\n", raw_output)
def test_aggregate_properties(self):
opts = self.get_show_opts(['properties'])
raw_output = self.openstack(
'aggregate set --property a=b --property c=d ' + self.NAME
)
self.assertEqual('', raw_output)
raw_output = self.openstack('aggregate show ' + self.NAME + opts)
self.assertIn("a='b', c='d'\n", raw_output)

View File

@ -201,7 +201,7 @@ class RemoveAggregateHost(command.ShowOne):
return zip(*sorted(six.iteritems(info))) return zip(*sorted(six.iteritems(info)))
class SetAggregate(command.ShowOne): class SetAggregate(command.Command):
"""Set aggregate properties""" """Set aggregate properties"""
def get_parser(self, prog_name): def get_parser(self, prog_name):
@ -238,28 +238,22 @@ class SetAggregate(command.ShowOne):
parsed_args.aggregate, parsed_args.aggregate,
) )
info = {}
kwargs = {} kwargs = {}
if parsed_args.name: if parsed_args.name:
kwargs['name'] = parsed_args.name kwargs['name'] = parsed_args.name
if parsed_args.zone: if parsed_args.zone:
kwargs['availability_zone'] = parsed_args.zone kwargs['availability_zone'] = parsed_args.zone
if kwargs: if kwargs:
info.update(compute_client.aggregates.update( compute_client.aggregates.update(
aggregate, aggregate,
kwargs kwargs
)._info) )
if parsed_args.property: if parsed_args.property:
info.update(compute_client.aggregates.set_metadata( compute_client.aggregates.set_metadata(
aggregate, aggregate,
parsed_args.property, parsed_args.property
)._info) )
if info:
return zip(*sorted(six.iteritems(info)))
else:
return ({}, {})
class ShowAggregate(command.ShowOne): class ShowAggregate(command.ShowOne):
@ -284,8 +278,14 @@ class ShowAggregate(command.ShowOne):
# Remove availability_zone from metadata because Nova doesn't # Remove availability_zone from metadata because Nova doesn't
if 'availability_zone' in data.metadata: if 'availability_zone' in data.metadata:
data.metadata.pop('availability_zone') data.metadata.pop('availability_zone')
# Map 'metadata' column to 'properties'
data._info.update({'properties': data._info.pop('metadata')}) # Special mapping for columns to make the output easier to read:
# 'metadata' --> 'properties'
data._info.update(
{
'properties': utils.format_dict(data._info.pop('metadata')),
},
)
info = {} info = {}
info.update(data._info) info.update(data._info)

View File

@ -6,3 +6,5 @@ fixes:
[Bug `1546065 <https://bugs.launchpad.net/python-openstackclient/+bug/1546065>`_] [Bug `1546065 <https://bugs.launchpad.net/python-openstackclient/+bug/1546065>`_]
- Command ``compute agent set`` now outputs nothing. - Command ``compute agent set`` now outputs nothing.
[Bug `1546065 <https://bugs.launchpad.net/python-openstackclient/+bug/1546065>`_] [Bug `1546065 <https://bugs.launchpad.net/python-openstackclient/+bug/1546065>`_]
- Command ``aggregate set`` now outputs nothing.
[Bug `1546065 <https://bugs.launchpad.net/python-openstackclient/+bug/1546065>`_]