Return share_type UUID instead of name in Share API

APIImpact
Change-Id: I082bdac82c981adf733c709472ce1b9e26d5650b
Closes-Bug: #1483886
This commit is contained in:
Igor Malinovskiy 2015-09-14 06:14:24 -07:00
parent b1f06b6b8b
commit 0460c7a84f
9 changed files with 101 additions and 6 deletions

View File

@ -51,6 +51,7 @@ REST_API_VERSION_HISTORY = """
* 2.3 - Share instances admin API * 2.3 - Share instances admin API
* 2.4 - Consistency Group support * 2.4 - Consistency Group support
* 2.5 - Share Migration admin API * 2.5 - Share Migration admin API
* 2.6 - Return share_type UUID instead of name in Share API
""" """
@ -58,7 +59,7 @@ REST_API_VERSION_HISTORY = """
# The default api version request is defined to be the # The default api version request is defined to be the
# the minimum version of the API supported. # the minimum version of the API supported.
_MIN_API_VERSION = "2.0" _MIN_API_VERSION = "2.0"
_MAX_API_VERSION = "2.5" _MAX_API_VERSION = "2.6"
DEFAULT_API_VERSION = _MIN_API_VERSION DEFAULT_API_VERSION = _MIN_API_VERSION

View File

@ -56,3 +56,8 @@ user documentation.
2.5 2.5
--- ---
Share Migration admin API. Share Migration admin API.
2.6
---
Return share_type UUID instead of name in Share API and add share_type_name
field.

View File

@ -20,7 +20,10 @@ class ViewBuilder(common.ViewBuilder):
"""Model a server API response as a python dictionary.""" """Model a server API response as a python dictionary."""
_collection_name = 'shares' _collection_name = 'shares'
_detail_version_modifiers = ["add_consistency_group_fields"] _detail_version_modifiers = [
"add_consistency_group_fields",
"modify_share_type_field",
]
def summary_list(self, request, shares): def summary_list(self, request, shares):
"""Show a list of shares without many details.""" """Show a list of shares without many details."""
@ -92,6 +95,19 @@ class ViewBuilder(common.ViewBuilder):
share_dict['source_cgsnapshot_member_id'] = share.get( share_dict['source_cgsnapshot_member_id'] = share.get(
'source_cgsnapshot_member_id') 'source_cgsnapshot_member_id')
@common.ViewBuilder.versioned_method("2.6")
def modify_share_type_field(self, share_dict, share):
share_type = share.get('share_type_id')
share_type_name = None
if share.get('share_type'):
share_type_name = share.get('share_type').get('name')
share_dict.update({
'share_type_name': share_type_name,
'share_type': share_type,
})
def _list_view(self, func, request, shares): def _list_view(self, func, request, shares):
"""Provide a view for a list of shares.""" """Provide a view for a list of shares."""
shares_list = [func(request, share)['share'] for share in shares] shares_list = [func(request, share)['share'] for share in shares]

View File

@ -425,6 +425,15 @@ class ShareApiTest(test.TestCase):
expected['share']['source_cgsnapshot_member_id'] = None expected['share']['source_cgsnapshot_member_id'] = None
self.assertEqual(expected, res_dict) self.assertEqual(expected, res_dict)
def test_share_show_with_share_type_name(self):
req = fakes.HTTPRequest.blank('/shares/1', version='2.6')
res_dict = self.controller.show(req, '1')
expected = self._get_expected_share_detailed_response()
expected['share']['consistency_group_id'] = None
expected['share']['source_cgsnapshot_member_id'] = None
expected['share']['share_type_name'] = None
self.assertEqual(expected, res_dict)
def test_share_show_admin(self): def test_share_show_admin(self):
req = fakes.HTTPRequest.blank('/shares/1', use_admin_context=True) req = fakes.HTTPRequest.blank('/shares/1', use_admin_context=True)
res_dict = self.controller.show(req, '1') res_dict = self.controller.show(req, '1')

View File

@ -0,0 +1,47 @@
# Copyright (c) 2015 Mirantis, Inc.
# All Rights Reserved.
#
# 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 manila.api.views import shares
from manila import test
from manila.tests.api import fakes
class ViewBuilderTestCase(test.TestCase):
def setUp(self):
super(ViewBuilderTestCase, self).setUp()
self.builder = shares.ViewBuilder()
self.req = fakes.HTTPRequest.blank('/shares', version="2.6")
def test__collection_name(self):
self.assertEqual('shares', self.builder._collection_name)
def test_detail_v_2_6(self):
fake_share = {
'id': 'fake_id',
'share_type_id': 'fake_share_type_id',
'share_type': {'name': 'fake_share_type_name'}
}
actual_result = self.builder.detail(self.req, fake_share)
self.assertSubDictMatch(
{
'id': fake_share['id'],
'share_type': fake_share['share_type_id'],
'share_type_name': fake_share['share_type']['name'],
},
actual_result['share']
)

View File

@ -36,7 +36,7 @@ ShareGroup = [
help="The minimum api microversion is configured to be the " help="The minimum api microversion is configured to be the "
"value of the minimum microversion supported by Manila."), "value of the minimum microversion supported by Manila."),
cfg.StrOpt("max_api_microversion", cfg.StrOpt("max_api_microversion",
default="2.5", default="2.6",
help="The maximum api microversion is configured to be the " help="The maximum api microversion is configured to be the "
"value of the latest microversion supported by Manila."), "value of the latest microversion supported by Manila."),
cfg.StrOpt("region", cfg.StrOpt("region",

View File

@ -67,9 +67,19 @@ class ShareMultiBackendTest(base.BaseSharesAdminTest):
def test_share_share_type(self): def test_share_share_type(self):
# Share type should be the same as provided with share creation # Share type should be the same as provided with share creation
for i in [0, 1]: for i in [0, 1]:
get = self.shares_client.get_share(self.shares[i]['id']) get = self.shares_v2_client.get_share(self.shares[i]['id'],
version="2.5")
self.assertEqual(get["share_type"], self.sts[i]["name"]) self.assertEqual(get["share_type"], self.sts[i]["name"])
@test.attr(type=["gate", "smoke", ])
def test_share_share_type_v_2_6(self):
# Share type should be the same as provided with share creation
for i in [0, 1]:
get = self.shares_v2_client.get_share(self.shares[i]['id'],
version="2.6")
self.assertEqual(get["share_type"], self.sts[i]["id"])
self.assertEqual(get["share_type_name"], self.sts[i]["name"])
@test.attr(type=["gate", ]) @test.attr(type=["gate", ])
def test_share_export_locations(self): def test_share_export_locations(self):
# Different backends have different IPs on interfaces # Different backends have different IPs on interfaces

View File

@ -107,13 +107,16 @@ class ManageNFSShareTest(base.BaseSharesAdminTest):
self.shares_client.wait_for_share_status(share['id'], 'available') self.shares_client.wait_for_share_status(share['id'], 'available')
# Verify data of managed share # Verify data of managed share
get = self.shares_client.get_share(share['id']) get = self.shares_v2_client.get_share(share['id'], version="2.5")
self.assertEqual(name, get['name']) self.assertEqual(name, get['name'])
self.assertEqual(description, get['description']) self.assertEqual(description, get['description'])
self.assertEqual(self.share1['host'], get['host']) self.assertEqual(self.share1['host'], get['host'])
self.assertEqual(self.share1['share_proto'], get['share_proto']) self.assertEqual(self.share1['share_proto'], get['share_proto'])
self.assertEqual(self.st['share_type']['name'], get['share_type']) self.assertEqual(self.st['share_type']['name'], get['share_type'])
get = self.shares_v2_client.get_share(share['id'], version="2.6")
self.assertEqual(self.st['share_type']['id'], get['share_type'])
# Delete share # Delete share
self.shares_client.delete_share(share['id']) self.shares_client.delete_share(share['id'])
self.shares_client.wait_for_resource_deletion(share_id=share['id']) self.shares_client.wait_for_resource_deletion(share_id=share['id'])

View File

@ -107,11 +107,15 @@ class ShareTypesAdminTest(base.BaseSharesAdminTest):
self.shares_client.wait_for_share_status(share["id"], "available") self.shares_client.wait_for_share_status(share["id"], "available")
# Verify share info # Verify share info
get = self.shares_client.get_share(share["id"]) get = self.shares_v2_client.get_share(share["id"], version="2.5")
self.assertEqual(share_name, get["name"]) self.assertEqual(share_name, get["name"])
self.assertEqual(share["id"], get["id"]) self.assertEqual(share["id"], get["id"])
self.assertEqual(shr_type_name, get["share_type"]) self.assertEqual(shr_type_name, get["share_type"])
get = self.shares_v2_client.get_share(share["id"], version="2.6")
self.assertEqual(st_create["share_type"]["id"], get["share_type"])
self.assertEqual(shr_type_name, get["share_type_name"])
def test_private_share_type_access(self): def test_private_share_type_access(self):
name = data_utils.rand_name("tempest-manila") name = data_utils.rand_name("tempest-manila")
extra_specs = self.add_required_extra_specs_to_dict({"key": "value", }) extra_specs = self.add_required_extra_specs_to_dict({"key": "value", })