[microversions] Add support for API microversion 2.13

Nova now supports API microversion 2.13 to
allow return project_id and user_id for
os-server-groups API. Sync this to the
client side.

Change-Id: Ia09ab4bd5c693ed95b0f5dd9bc709b7597f7034e
Closes-Bug: #1526143
This commit is contained in:
Kevin_Zheng
2015-12-15 15:25:17 +08:00
committed by Zhenyu Zheng
parent aa2687b3f7
commit b6677ebc03
4 changed files with 115 additions and 5 deletions

View File

@@ -25,4 +25,4 @@ API_MIN_VERSION = api_versions.APIVersion("2.1")
# when client supported the max version, and bumped sequentially, otherwise
# the client may break due to server side new version may include some
# backward incompatible change.
API_MAX_VERSION = api_versions.APIVersion("2.12")
API_MAX_VERSION = api_versions.APIVersion("2.13")

View File

@@ -0,0 +1,49 @@
# Copyright 2015 Huawei Technology corp.
# 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 novaclient.tests.functional import base
class TestServerGroupClient(base.ClientTestBase):
"""Server groups v2.1 functional tests."""
COMPUTE_API_VERSION = "2.1"
def _create_sg(self, policy):
sg_name = 'server_group-' + str(uuid.uuid4())
output = self.nova('server-group-create %s %s' % (sg_name, policy))
sg_id = self._get_column_value_from_single_row_table(output, "Id")
return sg_id
def test_create_server_group(self):
sg_id = self._create_sg("affinity")
self.addCleanup(self.nova, 'server-group-delete %s' % sg_id)
sg = self.nova('server-group-get %s' % sg_id)
result = self._get_column_value_from_single_row_table(sg, "Id")
self.assertEqual(sg_id, result)
def test_list_server_group(self):
sg_id = self._create_sg("affinity")
self.addCleanup(self.nova, 'server-group-delete %s' % sg_id)
sg = self.nova('server-group-list')
result = self._get_column_value_from_single_row_table(sg, "Id")
self.assertEqual(sg_id, result)
def test_delete_server_group(self):
sg_id = self._create_sg("affinity")
sg = self.nova('server-group-get %s' % sg_id)
result = self._get_column_value_from_single_row_table(sg, "Id")
self.assertIsNotNone(result)
self.nova('server-group-delete %s' % sg_id)

View File

@@ -0,0 +1,53 @@
# Copyright 2015 Huawei Technology corp.
# 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.
from novaclient.tests.functional.v2.legacy import test_server_groups
class TestServerGroupClientV213(test_server_groups.TestServerGroupClient):
"""Server groups v2.13 functional tests."""
COMPUTE_API_VERSION = "2.latest"
def test_create_server_group(self):
sg_id = self._create_sg("affinity")
self.addCleanup(self.nova, 'server-group-delete %s' % sg_id)
sg = self.nova('server-group-get %s' % sg_id)
result = self._get_column_value_from_single_row_table(sg, "Id")
self._get_column_value_from_single_row_table(
sg, "User Id")
self._get_column_value_from_single_row_table(
sg, "Project Id")
self.assertEqual(sg_id, result)
def test_list_server_groups(self):
sg_id = self._create_sg("affinity")
self.addCleanup(self.nova, 'server-group-delete %s' % sg_id)
sg = self.nova("server-group-list")
result = self._get_column_value_from_single_row_table(sg, "Id")
self._get_column_value_from_single_row_table(
sg, "User Id")
self._get_column_value_from_single_row_table(
sg, "Project Id")
self.assertEqual(sg_id, result)
def test_get_server_group(self):
sg_id = self._create_sg("affinity")
self.addCleanup(self.nova, 'server-group-delete %s' % sg_id)
sg = self.nova('server-group-get %s' % sg_id)
result = self._get_column_value_from_single_row_table(sg, "Id")
self._get_column_value_from_single_row_table(
sg, "User Id")
self._get_column_value_from_single_row_table(
sg, "Project Id")
self.assertEqual(sg_id, result)

View File

@@ -4594,11 +4594,19 @@ def do_availability_zone_list(cs, _args):
sortby_index=None)
def _print_server_group_details(server_group):
@api_versions.wraps("2.0", "2.12")
def _print_server_group_details(cs, server_group):
columns = ['Id', 'Name', 'Policies', 'Members', 'Metadata']
utils.print_list(server_group, columns)
@api_versions.wraps("2.13")
def _print_server_group_details(cs, server_group): # noqa
columns = ['Id', 'Name', 'Project Id', 'User Id',
'Policies', 'Members', 'Metadata']
utils.print_list(server_group, columns)
@cliutils.arg(
'--all-projects',
dest='all_projects',
@@ -4608,7 +4616,7 @@ def _print_server_group_details(server_group):
def do_server_group_list(cs, args):
"""Print a list of all server groups."""
server_groups = cs.server_groups.list(args.all_projects)
_print_server_group_details(server_groups)
_print_server_group_details(cs, server_groups)
def do_secgroup_list_default_rules(cs, args):
@@ -4702,7 +4710,7 @@ def do_server_group_create(cs, args):
kwargs = {'name': args.name,
'policies': args.policy}
server_group = cs.server_groups.create(**kwargs)
_print_server_group_details([server_group])
_print_server_group_details(cs, [server_group])
@cliutils.arg(
@@ -4734,7 +4742,7 @@ def do_server_group_delete(cs, args):
def do_server_group_get(cs, args):
"""Get a specific server group."""
server_group = cs.server_groups.get(args.id)
_print_server_group_details([server_group])
_print_server_group_details(cs, [server_group])
def do_version_list(cs, args):