Merge "osc resource-type-show description option"

This commit is contained in:
Jenkins 2016-05-30 07:47:15 +00:00 committed by Gerrit Code Review
commit e95df61c64
3 changed files with 32 additions and 5 deletions

View File

@ -42,11 +42,21 @@ class ResourceTypeShow(format_utils.YamlFormat):
metavar='<template-type>', metavar='<template-type>',
help=_('Optional template type to generate, hot or cfn') help=_('Optional template type to generate, hot or cfn')
) )
parser.add_argument(
'--long',
default=False,
action='store_true',
help=_('Show resource type with corresponding description.')
)
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):
self.log.debug("take_action(%s)", parsed_args) self.log.debug("take_action(%s)", parsed_args)
if parsed_args.template_type is not None and parsed_args.long:
msg = _('Cannot use --template-type and --long in one time.')
raise exc.CommandError(msg)
heat_client = self.app.client_manager.orchestration heat_client = self.app.client_manager.orchestration
return _show_resourcetype(heat_client, parsed_args) return _show_resourcetype(heat_client, parsed_args)
@ -63,7 +73,8 @@ def _show_resourcetype(heat_client, parsed_args):
'template_type': template_type} 'template_type': template_type}
data = heat_client.resource_types.generate_template(**fields) data = heat_client.resource_types.generate_template(**fields)
else: else:
data = heat_client.resource_types.get(parsed_args.resource_type) data = heat_client.resource_types.get(parsed_args.resource_type,
parsed_args.long)
except heat_exc.HTTPNotFound: except heat_exc.HTTPNotFound:
raise exc.CommandError( raise exc.CommandError(
_('Resource type not found: %s') % parsed_args.resource_type) _('Resource type not found: %s') % parsed_args.resource_type)

View File

@ -38,7 +38,7 @@ class TestResourceTypeShow(TestResourceType):
parsed_args = self.check_parser(self.cmd, arglist, []) parsed_args = self.check_parser(self.cmd, arglist, [])
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.mock_client.resource_types.get.assert_called_once_with( self.mock_client.resource_types.get.assert_called_once_with(
'OS::Heat::None') 'OS::Heat::None', False)
def test_resourcetype_show_json(self): def test_resourcetype_show_json(self):
arglist = ['OS::Heat::None', arglist = ['OS::Heat::None',
@ -46,7 +46,7 @@ class TestResourceTypeShow(TestResourceType):
parsed_args = self.check_parser(self.cmd, arglist, []) parsed_args = self.check_parser(self.cmd, arglist, [])
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.mock_client.resource_types.get.assert_called_once_with( self.mock_client.resource_types.get.assert_called_once_with(
'OS::Heat::None') 'OS::Heat::None', False)
def test_resourcetype_show_error_get(self): def test_resourcetype_show_error_get(self):
arglist = ['OS::Heat::None'] arglist = ['OS::Heat::None']
@ -96,6 +96,20 @@ class TestResourceTypeShow(TestResourceType):
parsed_args = self.check_parser(self.cmd, arglist, []) parsed_args = self.check_parser(self.cmd, arglist, [])
self.assertRaises(exc.CommandError, self.cmd.take_action, parsed_args) self.assertRaises(exc.CommandError, self.cmd.take_action, parsed_args)
def test_resourcetype_show_with_description(self):
arglist = ['OS::Heat::None', '--long']
parsed_args = self.check_parser(self.cmd, arglist, [])
self.cmd.take_action(parsed_args)
self.mock_client.resource_types.get.assert_called_with(
'OS::Heat::None', True)
def test_resourcetype_show_long_and_template_type_error(self):
arglist = ['OS::Heat::None',
'--template-type', 'cfn',
'--long']
parsed_args = self.check_parser(self.cmd, arglist, [])
self.assertRaises(exc.CommandError, self.cmd.take_action, parsed_args)
class TestTypeList(TestResourceType): class TestTypeList(TestResourceType):

View File

@ -62,15 +62,17 @@ class ResourceTypeManager(base.BaseManager):
return self._list(url, self.KEY) return self._list(url, self.KEY)
def get(self, resource_type): def get(self, resource_type, with_description=False):
"""Get the details for a specific resource_type. """Get the details for a specific resource_type.
:param resource_type: name of the resource type to get the details for :param resource_type: name of the resource type to get the details for
:param with_description: return result with description or not
""" """
url_str = '/%s/%s' % ( url_str = '/%s/%s' % (
self.KEY, self.KEY,
parse.quote(encodeutils.safe_encode(resource_type), '')) parse.quote(encodeutils.safe_encode(resource_type), ''))
resp = self.client.get(url_str) resp = self.client.get(url_str,
params={'with_description': with_description})
body = utils.get_response_body(resp) body = utils.get_response_body(resp)
return body return body