Merge "Add CLI tests for actions"

This commit is contained in:
Jenkins 2014-11-05 12:36:27 +00:00 committed by Gerrit Code Review
commit e929e88aff
4 changed files with 183 additions and 11 deletions

View File

@ -0,0 +1,21 @@
---
version: "2.0"
greeting:
description: "This action says 'Hello'"
tags: [hello]
base: std.echo
base-input:
output: 'Hello, {$.name}'
input:
- name
output:
string: $.output
farewell:
base: std.echo
base-input:
output: 'Bye!'
output:
info: $.output

View File

@ -14,22 +14,36 @@
import os import os
from tempest import cli from tempest_lib.cli import base
from tempest import config
from tempest import test
CONF = config.CONF
class MistralCLIAuth(cli.ClientTestBase): class MistralCLIAuth(base.ClientTestBase, test.BaseTestCase):
_mistral_url = None _mistral_url = None
def mistral(self, action, flags='', params='', admin=True, fail_ok=False, def _get_clients(self):
keystone_version=3): clients = base.CLIClient(
CONF.identity.admin_username,
CONF.identity.admin_password,
CONF.identity.admin_tenant_name,
CONF.identity.uri,
CONF.cli.cli_dir)
return clients
def mistral(self, action, flags='', params='', fail_ok=False):
"""Executes Mistral command.""" """Executes Mistral command."""
mistral_url_op = "--os-mistral-url %s" % self._mistral_url mistral_url_op = "--os-mistral-url %s" % self._mistral_url
if 'WITHOUT_AUTH' in os.environ: if 'WITHOUT_AUTH' in os.environ:
return cli.execute( return base.execute(
'mistral %s' % mistral_url_op, action, flags, params) 'mistral %s' % mistral_url_op, action, flags, params,
fail_ok, merge_stderr=False, cli_dir='')
else: else:
return self.cmd_with_auth( return self.clients.cmd_with_auth(
'mistral %s' % mistral_url_op, action, flags, params, admin, 'mistral %s' % mistral_url_op, action, flags, params,
fail_ok, keystone_version) fail_ok)

View File

@ -14,7 +14,7 @@
import os import os
from tempest import exceptions from tempest_lib import exceptions
from mistralclient.tests.functional.cli import base from mistralclient.tests.functional.cli import base

View File

@ -14,7 +14,7 @@
import os import os
from tempest import exceptions from tempest_lib import exceptions
from mistralclient.tests.functional.cli import base from mistralclient.tests.functional.cli import base
@ -65,6 +65,14 @@ class SimpleMistralCLITests(base.MistralCLIAuth):
'Next execution time', 'Next execution time',
'Created at', 'Updated at']) 'Created at', 'Updated at'])
def test_actions_list(self):
actions = self.parser.listing(
self.mistral('action-list'))
self.assertTableStruct(actions,
['Name', 'Is system', 'Input',
'Description', 'Tags', 'Created at',
'Updated at'])
class ClientTestBase(base.MistralCLIAuth): class ClientTestBase(base.MistralCLIAuth):
@ -83,6 +91,14 @@ class ClientTestBase(base.MistralCLIAuth):
cls.wf_def = os.path.relpath( cls.wf_def = os.path.relpath(
'functionaltests/resources/v2/wf_v2.yaml', os.getcwd()) 'functionaltests/resources/v2/wf_v2.yaml', os.getcwd())
cls.act_def = os.path.relpath(
'functionaltests/resources/v2/action_v2.yaml', os.getcwd())
def setUp(self):
super(ClientTestBase, self).setUp()
self.actions = []
def tearDown(self): def tearDown(self):
super(ClientTestBase, self).tearDown() super(ClientTestBase, self).tearDown()
@ -96,10 +112,17 @@ class ClientTestBase(base.MistralCLIAuth):
if id != "<none>": if id != "<none>":
self.mistral('{0}-delete'.format(object), params=id) self.mistral('{0}-delete'.format(object), params=id)
for act in self.actions:
self.mistral('action-delete', params=act)
del self.actions
def get_value_of_field(self, obj, field): def get_value_of_field(self, obj, field):
return [o['Value'] for o in obj return [o['Value'] for o in obj
if o['Field'] == "{0}".format(field)][0] if o['Field'] == "{0}".format(field)][0]
def get_item_info(self, get_from, get_by, value):
return [i for i in get_from if i[get_by] == value][0]
def mistral_command(self, cmd, params=""): def mistral_command(self, cmd, params=""):
return self.parser.listing(self.mistral('{0}'.format(cmd), return self.parser.listing(self.mistral('{0}'.format(cmd),
params='{0}'.format(params))) params='{0}'.format(params)))
@ -376,6 +399,82 @@ class TriggerCLITests(ClientTestBase):
self.mistral('cron-trigger-delete', params='{0}'.format(tr_name)) self.mistral('cron-trigger-delete', params='{0}'.format(tr_name))
class ActionCLITests(ClientTestBase):
"""Test suite checks commands to work with actions."""
@classmethod
def setUpClass(cls):
super(ActionCLITests, cls).setUpClass()
def test_action_create_delete(self):
acts = self.mistral_command(
'action-create', params='{0}'.format(self.act_def))
self.assertTableStruct(acts, ['Name', 'Is system', 'Input',
'Description', 'Tags',
'Created at', 'Updated at'])
self.assertIn('greeting', [action['Name'] for action in acts])
self.assertIn('farewell', [action['Name'] for action in acts])
action_1 = self.get_item_info(
get_from=acts, get_by='Name', value='greeting')
action_2 = self.get_item_info(
get_from=acts, get_by='Name', value='farewell')
self.assertEqual(action_1['Tags'], 'hello')
self.assertEqual(action_2['Tags'], '<none>')
self.assertEqual(action_1['Is system'], 'False')
self.assertEqual(action_2['Is system'], 'False')
self.assertEqual(action_1['Input'], 'name')
self.assertEqual(action_2['Input'], '')
acts = self.mistral_command('action-list')
self.assertIn(action_1['Name'], [action['Name'] for action in acts])
self.assertIn(action_2['Name'], [action['Name'] for action in acts])
self.mistral_command(
'action-delete', params='{0}'.format(action_1['Name']))
self.mistral_command(
'action-delete', params='{0}'.format(action_2['Name']))
acts = self.mistral_command('action-list')
self.assertNotIn(action_1['Name'], [action['Name'] for action in acts])
self.assertNotIn(action_2['Name'], [action['Name'] for action in acts])
def test_action_update(self):
acts = self.mistral_command(
'action-create', params='{0}'.format(self.act_def))
self.actions.extend([action['Name'] for action in acts])
created_action = self.get_item_info(
get_from=acts, get_by='Name', value='greeting')
acts = self.mistral_command(
'action-update', params='{0}'.format(self.act_def))
updated_action = self.get_item_info(
get_from=acts, get_by='Name', value='greeting')
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_get_definition(self):
acts = self.mistral_command(
'action-create', params='{0}'.format(self.act_def))
self.actions.extend([action['Name'] for action in acts])
definition = self.mistral_command(
'action-get-definition', params='greeting')
self.assertNotIn('404 Not Found', definition)
class NegativeCLITests(ClientTestBase): class NegativeCLITests(ClientTestBase):
"""This class contains negative tests.""" """This class contains negative tests."""
@ -507,3 +606,41 @@ class NegativeCLITests(ClientTestBase):
self.assertRaises(exceptions.CommandFailed, self.assertRaises(exceptions.CommandFailed,
self.mistral, self.mistral,
'cron-trigger-get', params='tr') 'cron-trigger-get', params='tr')
def test_action_get_nonexistent(self):
self.assertRaises(exceptions.CommandFailed,
self.mistral,
'action-get', params='nonexist')
def test_action_double_creation(self):
acts = self.mistral_command(
'action-create', params='{0}'.format(self.act_def))
self.actions.extend([action['Name'] for action in acts])
self.assertRaises(exceptions.CommandFailed,
self.mistral, 'action-create',
params='{0}'.format(self.act_def))
def test_action_create_without_def(self):
self.assertRaises(exceptions.CommandFailed,
self.mistral, 'action-create',
params='')
def test_action_create_invalid_def(self):
self.assertRaises(exceptions.CommandFailed,
self.mistral, 'action-create',
params='{0}'.format(self.wb_def))
def test_action_delete_nonexistent_act(self):
self.assertRaises(exceptions.CommandFailed,
self.mistral, 'action-delete',
params='nonexist')
def test_action_delete_standard_action(self):
self.assertRaises(exceptions.CommandFailed,
self.mistral, 'action-delete',
params='heat.events_get')
def test_action_get_definition_nonexistent_action(self):
self.assertRaises(exceptions.CommandFailed,
self.mistral, 'action-get-definition',
params='nonexist')