Merge "Add task-get-parameters command"
This commit is contained in:
@@ -33,7 +33,6 @@ def format(task=None):
|
|||||||
'Workflow name',
|
'Workflow name',
|
||||||
'Execution ID',
|
'Execution ID',
|
||||||
'State',
|
'State',
|
||||||
'Parameters',
|
|
||||||
)
|
)
|
||||||
|
|
||||||
if task:
|
if task:
|
||||||
@@ -43,7 +42,6 @@ def format(task=None):
|
|||||||
task.wf_name,
|
task.wf_name,
|
||||||
task.execution_id,
|
task.execution_id,
|
||||||
task.state,
|
task.state,
|
||||||
task.parameters,
|
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
data = (tuple('<none>' for _ in range(len(columns))),)
|
data = (tuple('<none>' for _ in range(len(columns))),)
|
||||||
@@ -152,3 +150,27 @@ class GetResult(command.Command):
|
|||||||
LOG.debug("Task result is not JSON.")
|
LOG.debug("Task result is not JSON.")
|
||||||
|
|
||||||
self.app.stdout.write(result or "\n")
|
self.app.stdout.write(result or "\n")
|
||||||
|
|
||||||
|
|
||||||
|
class GetParameters(command.Command):
|
||||||
|
"""Show task parameters."""
|
||||||
|
|
||||||
|
def get_parser(self, prog_name):
|
||||||
|
parser = super(GetParameters, self).get_parser(prog_name)
|
||||||
|
parser.add_argument(
|
||||||
|
'id',
|
||||||
|
help='Task ID')
|
||||||
|
|
||||||
|
return parser
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
result = tasks.TaskManager(self.app.client)\
|
||||||
|
.get(parsed_args.id).parameters
|
||||||
|
|
||||||
|
try:
|
||||||
|
result = json.loads(result)
|
||||||
|
result = json.dumps(result, indent=4) + "\n"
|
||||||
|
except:
|
||||||
|
LOG.debug("Task result is not JSON.")
|
||||||
|
|
||||||
|
self.app.stdout.write(result or "\n")
|
||||||
|
@@ -251,6 +251,8 @@ class MistralShell(app.App):
|
|||||||
'task-list': mistralclient.commands.v2.tasks.List,
|
'task-list': mistralclient.commands.v2.tasks.List,
|
||||||
'task-get': mistralclient.commands.v2.tasks.Get,
|
'task-get': mistralclient.commands.v2.tasks.Get,
|
||||||
'task-get-output': mistralclient.commands.v2.tasks.GetOutput,
|
'task-get-output': mistralclient.commands.v2.tasks.GetOutput,
|
||||||
|
'task-get-parameters':
|
||||||
|
mistralclient.commands.v2.tasks.GetParameters,
|
||||||
'task-get-result': mistralclient.commands.v2.tasks.GetResult,
|
'task-get-result': mistralclient.commands.v2.tasks.GetResult,
|
||||||
'task-update': mistralclient.commands.v2.tasks.Update,
|
'task-update': mistralclient.commands.v2.tasks.Update,
|
||||||
'action-list': mistralclient.commands.v2.actions.List,
|
'action-list': mistralclient.commands.v2.actions.List,
|
||||||
|
@@ -14,6 +14,7 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
import json
|
||||||
import mock
|
import mock
|
||||||
|
|
||||||
from mistralclient.tests.unit import base
|
from mistralclient.tests.unit import base
|
||||||
@@ -21,14 +22,28 @@ from mistralclient.tests.unit import base
|
|||||||
from mistralclient.commands.v2 import tasks as task_cmd
|
from mistralclient.commands.v2 import tasks as task_cmd
|
||||||
from mistralclient.api.v2 import tasks
|
from mistralclient.api.v2 import tasks
|
||||||
|
|
||||||
TASK = tasks.Task(mock, {
|
TASK_DICT = {
|
||||||
'id': '123',
|
'id': '123',
|
||||||
'name': 'some',
|
'name': 'some',
|
||||||
'wf_name': 'thing',
|
'wf_name': 'thing',
|
||||||
'execution_id': '321',
|
'execution_id': '321',
|
||||||
'state': 'RUNNING',
|
'state': 'RUNNING',
|
||||||
'parameters': {},
|
}
|
||||||
})
|
|
||||||
|
TASK_RESULT = {"test": "is", "passed": "successfully"}
|
||||||
|
TASK_PARAMETERS = {"param1": "val1", "param2": 2}
|
||||||
|
|
||||||
|
TASK_WITH_RESULT_DICT = TASK_DICT.copy()
|
||||||
|
TASK_WITH_RESULT_DICT.update({'result': json.dumps(TASK_RESULT)})
|
||||||
|
TASK_WITH_OUTPUT_DICT = TASK_DICT.copy()
|
||||||
|
TASK_WITH_OUTPUT_DICT.update({'output': json.dumps(TASK_RESULT)})
|
||||||
|
TASK_WITH_PARAMETERS_DICT = TASK_DICT.copy()
|
||||||
|
TASK_WITH_PARAMETERS_DICT.update({'parameters': json.dumps(TASK_PARAMETERS)})
|
||||||
|
|
||||||
|
TASK = tasks.Task(mock, TASK_DICT)
|
||||||
|
TASK_WITH_RESULT = tasks.Task(mock, TASK_WITH_RESULT_DICT)
|
||||||
|
TASK_WITH_OUTPUT = tasks.Task(mock, TASK_WITH_OUTPUT_DICT)
|
||||||
|
TASK_WITH_PARAMETERS = tasks.Task(mock, TASK_WITH_PARAMETERS_DICT)
|
||||||
|
|
||||||
|
|
||||||
class TestCLIT1asksV2(base.BaseCommandTest):
|
class TestCLIT1asksV2(base.BaseCommandTest):
|
||||||
@@ -39,7 +54,7 @@ class TestCLIT1asksV2(base.BaseCommandTest):
|
|||||||
result = self.call(task_cmd.Update,
|
result = self.call(task_cmd.Update,
|
||||||
app_args=['id', 'ERROR'])
|
app_args=['id', 'ERROR'])
|
||||||
|
|
||||||
self.assertEqual(('123', 'some', 'thing', '321', 'RUNNING', {}),
|
self.assertEqual(('123', 'some', 'thing', '321', 'RUNNING'),
|
||||||
result[1])
|
result[1])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.v2.tasks.TaskManager.list')
|
@mock.patch('mistralclient.api.v2.tasks.TaskManager.list')
|
||||||
@@ -48,7 +63,7 @@ class TestCLIT1asksV2(base.BaseCommandTest):
|
|||||||
|
|
||||||
result = self.call(task_cmd.List)
|
result = self.call(task_cmd.List)
|
||||||
|
|
||||||
self.assertEqual([('123', 'some', 'thing', '321', 'RUNNING', {})],
|
self.assertEqual([('123', 'some', 'thing', '321', 'RUNNING')],
|
||||||
result[1])
|
result[1])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.v2.tasks.TaskManager.get')
|
@mock.patch('mistralclient.api.v2.tasks.TaskManager.get')
|
||||||
@@ -57,5 +72,32 @@ class TestCLIT1asksV2(base.BaseCommandTest):
|
|||||||
|
|
||||||
result = self.call(task_cmd.Get, app_args=['id'])
|
result = self.call(task_cmd.Get, app_args=['id'])
|
||||||
|
|
||||||
self.assertEqual(('123', 'some', 'thing', '321', 'RUNNING', {}),
|
self.assertEqual(('123', 'some', 'thing', '321', 'RUNNING'),
|
||||||
result[1])
|
result[1])
|
||||||
|
|
||||||
|
@mock.patch('mistralclient.api.v2.tasks.TaskManager.get')
|
||||||
|
def test_get_result(self, mock):
|
||||||
|
mock.return_value = TASK_WITH_RESULT
|
||||||
|
|
||||||
|
self.call(task_cmd.GetResult, app_args=['id'])
|
||||||
|
|
||||||
|
self.app.stdout.write.assert_called_with(
|
||||||
|
json.dumps(TASK_RESULT, indent=4) + "\n")
|
||||||
|
|
||||||
|
@mock.patch('mistralclient.api.v2.tasks.TaskManager.get')
|
||||||
|
def test_get_output(self, mock):
|
||||||
|
mock.return_value = TASK_WITH_OUTPUT
|
||||||
|
|
||||||
|
self.call(task_cmd.GetOutput, app_args=['id'])
|
||||||
|
|
||||||
|
self.app.stdout.write.assert_called_with(
|
||||||
|
json.dumps(TASK_RESULT, indent=4) + "\n")
|
||||||
|
|
||||||
|
@mock.patch('mistralclient.api.v2.tasks.TaskManager.get')
|
||||||
|
def test_get_parameters(self, mock):
|
||||||
|
mock.return_value = TASK_WITH_PARAMETERS
|
||||||
|
|
||||||
|
self.call(task_cmd.GetParameters, app_args=['id'])
|
||||||
|
|
||||||
|
self.app.stdout.write.assert_called_with(
|
||||||
|
json.dumps(TASK_PARAMETERS, indent=4) + "\n")
|
||||||
|
Reference in New Issue
Block a user