Add CLI tests for actions
- Fix wrong inheritance in basa.py - Added action_v2.yaml with simple action definition that describe two actions - Added positive tests which cover all CLI action commands - Added negative tests Change-Id: I075868aaff5f218718933c40bb99b4415ca80821
This commit is contained in:
parent
22edeee109
commit
313259f7ee
21
functionaltests/resources/v2/action_v2.yaml
Normal file
21
functionaltests/resources/v2/action_v2.yaml
Normal 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
|
||||||
|
|
@ -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)
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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')
|
||||||
|
Loading…
Reference in New Issue
Block a user