Added ID option to update Action Definition

Change-Id: I8f34740e6739652c0f39fce2c5622985134d9c2e
Partially-Implements: blueprint mistral-actions-identifier
This commit is contained in:
hardik 2016-07-25 19:07:07 +05:30
parent 4c232e5c56
commit 022ef56dad
5 changed files with 88 additions and 18 deletions

View File

@ -46,15 +46,17 @@ class ActionManager(base.ResourceManager):
return [self.resource_class(self, resource_data) return [self.resource_class(self, resource_data)
for resource_data in base.extract_json(resp, 'actions')] for resource_data in base.extract_json(resp, 'actions')]
def update(self, definition, scope='private'): def update(self, definition, scope='private', id=None):
self._ensure_not_empty(definition=definition) self._ensure_not_empty(definition=definition)
url_pre = ('/actions/%s' % id) if id else '/actions'
# If the specified definition is actually a file, read in the # If the specified definition is actually a file, read in the
# definition file # definition file
definition = utils.get_contents_if_file(definition) definition = utils.get_contents_if_file(definition)
resp = self.client.http_client.put( resp = self.client.http_client.put(
'/actions?scope=%s' % scope, '%s?scope=%s' % (url_pre, scope),
definition, definition,
headers={'content-type': 'text/plain'} headers={'content-type': 'text/plain'}
) )
@ -88,15 +90,15 @@ class ActionManager(base.ResourceManager):
response_key='actions', response_key='actions',
) )
def get(self, name): def get(self, identifier):
self._ensure_not_empty(name=name) self._ensure_not_empty(identifier=identifier)
return self._get('/actions/%s' % name) return self._get('/actions/%s' % identifier)
def delete(self, name): def delete(self, identifier):
self._ensure_not_empty(name=name) self._ensure_not_empty(identifier=identifier)
self._delete('/actions/%s' % name) self._delete('/actions/%s' % identifier)
def validate(self, definition): def validate(self, definition):
self._ensure_not_empty(definition=definition) self._ensure_not_empty(definition=definition)

View File

@ -31,6 +31,7 @@ def format_list(action=None):
def format(action=None, lister=False): def format(action=None, lister=False):
columns = ( columns = (
'ID',
'Name', 'Name',
'Is system', 'Is system',
'Input', 'Input',
@ -47,6 +48,7 @@ def format(action=None, lister=False):
else base.cut(action.description)) else base.cut(action.description))
data = ( data = (
action.id,
action.name, action.name,
action.is_system, action.is_system,
input, input,
@ -137,7 +139,11 @@ class Delete(command.Command):
def get_parser(self, prog_name): def get_parser(self, prog_name):
parser = super(Delete, self).get_parser(prog_name) parser = super(Delete, self).get_parser(prog_name)
parser.add_argument('name', nargs='+', help='Name of action(s).') parser.add_argument(
'action',
nargs='+',
help='Name or ID of action(s).'
)
return parser return parser
@ -146,7 +152,7 @@ class Delete(command.Command):
utils.do_action_on_many( utils.do_action_on_many(
lambda s: mistral_client.actions.delete(s), lambda s: mistral_client.actions.delete(s),
parsed_args.name, parsed_args.action,
"Request to delete action %s has been accepted.", "Request to delete action %s has been accepted.",
"Unable to delete the specified action(s)." "Unable to delete the specified action(s)."
) )
@ -163,6 +169,7 @@ class Update(base.MistralLister):
type=argparse.FileType('r'), type=argparse.FileType('r'),
help='Action definition file' help='Action definition file'
) )
parser.add_argument('--id', help='Action ID.')
parser.add_argument( parser.add_argument(
'--public', '--public',
action='store_true', action='store_true',
@ -181,7 +188,8 @@ class Update(base.MistralLister):
return mistral_client.actions.update( return mistral_client.actions.update(
parsed_args.definition.read(), parsed_args.definition.read(),
scope=scope scope=scope,
id=parsed_args.id
) )

View File

@ -752,6 +752,36 @@ class ActionCLITests(base_v2.MistralClientTestBase):
self.assertNotEqual(created_action['Updated at'], self.assertNotEqual(created_action['Updated at'],
updated_action['Updated at']) updated_action['Updated at'])
def test_action_update_with_id(self):
acts = self.action_create(self.act_def)
created_action = self.get_item_info(
get_from=acts,
get_by='Name',
value='greeting'
)
action_id = created_action['ID']
params = '{0} --id {1}'.format(self.act_tag_def, action_id)
acts = self.mistral_admin('action-update', params=params)
updated_action = self.get_item_info(
get_from=acts,
get_by='ID',
value=action_id
)
self.assertEqual(
created_action['Created at'].split(".")[0],
updated_action['Created at']
)
self.assertEqual(created_action['Name'], updated_action['Name'])
self.assertNotEqual(
created_action['Updated at'],
updated_action['Updated at']
)
def test_action_update_truncate_input(self): def test_action_update_truncate_input(self):
input_value = "very_long_input_parameter_name_that_should_be_truncated" input_value = "very_long_input_parameter_name_that_should_be_truncated"
act_def = """ act_def = """
@ -777,6 +807,15 @@ class ActionCLITests(base_v2.MistralClientTestBase):
'action-get-definition', params='greeting') 'action-get-definition', params='greeting')
self.assertNotIn('404 Not Found', definition) self.assertNotIn('404 Not Found', definition)
def test_action_get_with_id(self):
created = self.action_create(self.act_def)
action_name = created[0]['Name']
action_id = created[0]['ID']
fetched = self.mistral_admin('action-get', params=action_id)
fetched_action_name = self.get_field_value(fetched, 'Name')
self.assertEqual(action_name, fetched_action_name)
class EnvironmentCLITests(base_v2.MistralClientTestBase): class EnvironmentCLITests(base_v2.MistralClientTestBase):
"""Test suite checks commands to work with environments.""" """Test suite checks commands to work with environments."""

View File

@ -94,6 +94,20 @@ class TestActionsV2(base.BaseClientV2Test):
headers={'content-type': 'text/plain'} headers={'content-type': 'text/plain'}
) )
def test_update_with_id(self):
mock = self.mock_http_put(content={'actions': [ACTION]})
actions = self.actions.update(ACTION_DEF, id=123)
self.assertIsNotNone(actions)
self.assertEqual(ACTION_DEF, actions[0].definition)
mock.assert_called_once_with(
'/actions/123?scope=private',
ACTION_DEF,
headers={'content-type': 'text/plain'}
)
def test_update(self): def test_update(self):
mock = self.mock_http_put(content={'actions': [ACTION]}) mock = self.mock_http_put(content={'actions': [ACTION]})

View File

@ -24,6 +24,7 @@ from mistralclient.tests.unit import base
ACTION_DICT = { ACTION_DICT = {
'id': '1234-4567-7894-7895',
'name': 'a', 'name': 'a',
'is_system': True, 'is_system': True,
'input': "param1", 'input': "param1",
@ -57,7 +58,8 @@ class TestCLIActionsV2(base.BaseCommandTest):
result = self.call(action_cmd.Create, app_args=['1.txt']) result = self.call(action_cmd.Create, app_args=['1.txt'])
self.assertEqual( self.assertEqual(
[('a', True, "param1", 'My cool action', 'test', '1', '1')], [('1234-4567-7894-7895', 'a', True, "param1",
'My cool action', 'test', '1', '1')],
result[1] result[1]
) )
@ -71,7 +73,8 @@ class TestCLIActionsV2(base.BaseCommandTest):
) )
self.assertEqual( self.assertEqual(
[('a', True, "param1", 'My cool action', 'test', '1', '1')], [('1234-4567-7894-7895', 'a', True, "param1",
'My cool action', 'test', '1', '1')],
result[1] result[1]
) )
@ -96,7 +99,7 @@ class TestCLIActionsV2(base.BaseCommandTest):
result = self.call(action_cmd.Create, app_args=['1.txt']) result = self.call(action_cmd.Create, app_args=['1.txt'])
self.assertEqual( self.assertEqual(
[('a', True, cmd_base.cut(long_input), [('1234-4567-7894-7895', 'a', True, cmd_base.cut(long_input),
'My cool action', 'test', '1', '1')], 'My cool action', 'test', '1', '1')],
result[1] result[1]
) )
@ -108,7 +111,8 @@ class TestCLIActionsV2(base.BaseCommandTest):
result = self.call(action_cmd.Update, app_args=['my_action.yaml']) result = self.call(action_cmd.Update, app_args=['my_action.yaml'])
self.assertEqual( self.assertEqual(
[('a', True, "param1", 'My cool action', 'test', '1', '1')], [('1234-4567-7894-7895', 'a', True, "param1",
'My cool action', 'test', '1', '1')],
result[1] result[1]
) )
@ -122,7 +126,8 @@ class TestCLIActionsV2(base.BaseCommandTest):
) )
self.assertEqual( self.assertEqual(
[('a', True, "param1", 'My cool action', 'test', '1', '1')], [('1234-4567-7894-7895', 'a', True, "param1",
'My cool action', 'test', '1', '1')],
result[1] result[1]
) )
@ -137,7 +142,8 @@ class TestCLIActionsV2(base.BaseCommandTest):
result = self.call(action_cmd.List) result = self.call(action_cmd.List)
self.assertEqual( self.assertEqual(
[('a', True, "param1", 'My cool action', 'test', '1', '1')], [('1234-4567-7894-7895', 'a', True, "param1",
'My cool action', 'test', '1', '1')],
result[1] result[1]
) )
@ -147,7 +153,8 @@ class TestCLIActionsV2(base.BaseCommandTest):
result = self.call(action_cmd.Get, app_args=['name']) result = self.call(action_cmd.Get, app_args=['name'])
self.assertEqual( self.assertEqual(
('a', True, "param1", 'My cool action', 'test', '1', '1'), ('1234-4567-7894-7895', 'a', True, "param1",
'My cool action', 'test', '1', '1'),
result[1] result[1]
) )