Add functional tests to watcherclient
This Patch Set implements functional tests for watcherclient to cover all use cases of watcher objects. Implements : blueprint tempest-cli-test Change-Id: I920d5b1ae25c62a72d3474538f866a5415c2e119
This commit is contained in:
1
tox.ini
1
tox.ini
@@ -10,6 +10,7 @@ install_command =
|
|||||||
pip install -U {opts} {packages}
|
pip install -U {opts} {packages}
|
||||||
setenv =
|
setenv =
|
||||||
VIRTUAL_ENV={envdir}
|
VIRTUAL_ENV={envdir}
|
||||||
|
OS_TEST_PATH=./watcherclient/tests/unit
|
||||||
deps = -r{toxinidir}/test-requirements.txt
|
deps = -r{toxinidir}/test-requirements.txt
|
||||||
commands = python setup.py testr --slowest --testr-args='{posargs}'
|
commands = python setup.py testr --slowest --testr-args='{posargs}'
|
||||||
|
|
||||||
|
61
watcherclient/tests/README.rst
Normal file
61
watcherclient/tests/README.rst
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
..
|
||||||
|
Except where otherwise noted, this document is licensed under Creative
|
||||||
|
Commons Attribution 3.0 License. You can view the license at:
|
||||||
|
|
||||||
|
https://creativecommons.org/licenses/by/3.0/
|
||||||
|
|
||||||
|
=======
|
||||||
|
Testing
|
||||||
|
=======
|
||||||
|
|
||||||
|
.. _functional_tests:
|
||||||
|
|
||||||
|
Functional tests
|
||||||
|
================
|
||||||
|
|
||||||
|
The following procedure gets you started with Tempest testing but you can also
|
||||||
|
refer to the `Tempest documentation`_ for more details.
|
||||||
|
|
||||||
|
.. _Tempest documentation: http://docs.openstack.org/developer/tempest/
|
||||||
|
|
||||||
|
|
||||||
|
Tempest installation
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
You need to install virtualenv, create a virtual environment and activate it::
|
||||||
|
|
||||||
|
$ pip install virtualenv
|
||||||
|
$ virtualenv watcher-env
|
||||||
|
$ source watcher-env/bin/activate
|
||||||
|
|
||||||
|
Then, to install Tempest you can issue the following commands::
|
||||||
|
|
||||||
|
$ git clone https://github.com/openstack/tempest/
|
||||||
|
$ pip install tempest/
|
||||||
|
|
||||||
|
There should be set environment variables using the OpenStack RC file. If
|
||||||
|
you don't have RC file yet, create ``admin-openrc`` file and fill it using
|
||||||
|
the following example::
|
||||||
|
|
||||||
|
export OS_PROJECT_DOMAIN_NAME=default
|
||||||
|
export OS_USER_DOMAIN_NAME=default
|
||||||
|
export OS_PROJECT_NAME=admin
|
||||||
|
export OS_USERNAME=admin
|
||||||
|
export OS_PASSWORD=admin
|
||||||
|
export OS_AUTH_URL=http://controller:35357/v3
|
||||||
|
export OS_IDENTITY_API_VERSION=3
|
||||||
|
export OS_IMAGE_API_VERSION=2
|
||||||
|
|
||||||
|
Then, save file and execute ``source admin-openrc`` to set environment
|
||||||
|
variables.
|
||||||
|
|
||||||
|
To run functional tests you need to go to python-watcherclient folder, install
|
||||||
|
all requirements and execute ``tempest run`` command::
|
||||||
|
|
||||||
|
$ pip install -r requirements.txt test-requirements.txt
|
||||||
|
$ pip install .
|
||||||
|
$ tempest run --regex watcherclient.tests.functional
|
||||||
|
|
||||||
|
You can run specified test(s) by using regular expression::
|
||||||
|
|
||||||
|
$ tempest run --regex watcherclient.tests.functional.v1.test_action.ActionTests.test_action_list
|
108
watcherclient/tests/functional/v1/base.py
Normal file
108
watcherclient/tests/functional/v1/base.py
Normal file
@@ -0,0 +1,108 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import re
|
||||||
|
import shlex
|
||||||
|
import subprocess
|
||||||
|
import testtools
|
||||||
|
|
||||||
|
import six
|
||||||
|
from tempest.lib.cli import output_parser
|
||||||
|
from tempest.lib import exceptions
|
||||||
|
|
||||||
|
|
||||||
|
def execute(cmd, fail_ok=False, merge_stderr=False):
|
||||||
|
"""Executes specified command for the given action."""
|
||||||
|
cmdlist = shlex.split(cmd)
|
||||||
|
stdout = subprocess.PIPE
|
||||||
|
stderr = subprocess.STDOUT if merge_stderr else subprocess.PIPE
|
||||||
|
proc = subprocess.Popen(cmdlist, stdout=stdout, stderr=stderr)
|
||||||
|
result, result_err = proc.communicate()
|
||||||
|
result = result.decode('utf-8')
|
||||||
|
if not fail_ok and proc.returncode != 0:
|
||||||
|
raise exceptions.CommandFailed(proc.returncode, cmd, result,
|
||||||
|
result_err)
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
|
class TestCase(testtools.TestCase):
|
||||||
|
|
||||||
|
delimiter_line = re.compile('^\+\-[\+\-]+\-\+$')
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def watcher(cls, cmd, fail_ok=False):
|
||||||
|
"""Executes watcherclient command for the given action."""
|
||||||
|
return execute('watcher {0}'.format(cmd), fail_ok=fail_ok)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_opts(cls, fields, format='value'):
|
||||||
|
return ' -f {0} {1}'.format(format,
|
||||||
|
' '.join(['-c ' + it for it in fields]))
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def assertOutput(cls, expected, actual):
|
||||||
|
if expected != actual:
|
||||||
|
raise Exception('{0} != {1}'.format(expected, actual))
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def assertInOutput(cls, expected, actual):
|
||||||
|
if expected not in actual:
|
||||||
|
raise Exception('{0} not in {1}'.format(expected, actual))
|
||||||
|
|
||||||
|
def assert_table_structure(self, items, field_names):
|
||||||
|
"""Verify that all items have keys listed in field_names."""
|
||||||
|
for item in items:
|
||||||
|
for field in field_names:
|
||||||
|
self.assertIn(field, item)
|
||||||
|
|
||||||
|
def assert_show_fields(self, items, field_names):
|
||||||
|
"""Verify that all items have keys listed in field_names."""
|
||||||
|
for item in items:
|
||||||
|
for key in six.iterkeys(item):
|
||||||
|
self.assertIn(key, field_names)
|
||||||
|
|
||||||
|
def assert_show_structure(self, items, field_names):
|
||||||
|
"""Verify that all field_names listed in keys of all items."""
|
||||||
|
if isinstance(items, list):
|
||||||
|
o = {}
|
||||||
|
for d in items:
|
||||||
|
o.update(d)
|
||||||
|
else:
|
||||||
|
o = items
|
||||||
|
item_keys = o.keys()
|
||||||
|
for field in field_names:
|
||||||
|
self.assertIn(field, item_keys)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def parse_show_as_object(raw_output):
|
||||||
|
"""Return a dict with values parsed from cli output."""
|
||||||
|
items = TestCase.parse_show(raw_output)
|
||||||
|
o = {}
|
||||||
|
for item in items:
|
||||||
|
o.update(item)
|
||||||
|
return o
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def parse_show(raw_output):
|
||||||
|
"""Return list of dicts with item values parsed from cli output."""
|
||||||
|
|
||||||
|
items = []
|
||||||
|
table_ = output_parser.table(raw_output)
|
||||||
|
for row in table_['values']:
|
||||||
|
item = {}
|
||||||
|
item[row[0]] = row[1]
|
||||||
|
items.append(item)
|
||||||
|
return items
|
||||||
|
|
||||||
|
def parse_listing(self, raw_output):
|
||||||
|
"""Return list of dicts with basic item parsed from cli output."""
|
||||||
|
return output_parser.listing(raw_output)
|
72
watcherclient/tests/functional/v1/test_action.py
Normal file
72
watcherclient/tests/functional/v1/test_action.py
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class ActionTests(base.TestCase):
|
||||||
|
"""Functional tests for action."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy'
|
||||||
|
list_fields = ['UUID', 'Parents', 'State', 'Action Plan', 'Action']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Updated At',
|
||||||
|
'Deleted At', 'Parameters']
|
||||||
|
audit_template_name = 'a' + uuidutils.generate_uuid()
|
||||||
|
audit_uuid = None
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
template_raw_output = cls.watcher(
|
||||||
|
'audittemplate create %s dummy -s dummy' % cls.audit_template_name)
|
||||||
|
template_output = cls.parse_show_as_object(template_raw_output)
|
||||||
|
audit_raw_output = cls.watcher(
|
||||||
|
'audit create -a %s' % template_output['Name'])
|
||||||
|
audit_output = cls.parse_show_as_object(audit_raw_output)
|
||||||
|
cls.audit_uuid = audit_output['UUID']
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
# Delete Action Plan and all related actions.
|
||||||
|
output = cls.parse_show(
|
||||||
|
cls.watcher('actionplan list --audit %s' % cls.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
raw_output = cls.watcher('actionplan delete %s' % action_plan_uuid)
|
||||||
|
cls.assertOutput('', raw_output)
|
||||||
|
# Delete audit
|
||||||
|
raw_output = cls.watcher('audit delete %s' % cls.audit_uuid)
|
||||||
|
cls.assertOutput('', raw_output)
|
||||||
|
# Delete Template
|
||||||
|
raw_output = cls.watcher(
|
||||||
|
'audittemplate delete %s' % cls.audit_template_name)
|
||||||
|
cls.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
def test_action_list(self):
|
||||||
|
raw_output = self.watcher('action list')
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_action_detailed_list(self):
|
||||||
|
raw_output = self.watcher('action list --detail')
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_action_show(self):
|
||||||
|
action_list = self.parse_show(self.watcher('action list'))
|
||||||
|
action_uuid = action_list[0].keys()[0]
|
||||||
|
action = self.watcher('action show ' + action_uuid)
|
||||||
|
self.assertIn(action_uuid, action)
|
||||||
|
self.assert_table_structure([action],
|
||||||
|
self.detailed_list_fields)
|
123
watcherclient/tests/functional/v1/test_action_plan.py
Normal file
123
watcherclient/tests/functional/v1/test_action_plan.py
Normal file
@@ -0,0 +1,123 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class ActionPlanTests(base.TestCase):
|
||||||
|
"""Functional tests for action plan."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy'
|
||||||
|
list_fields = ['UUID', 'Audit', 'State', 'Updated At', 'Global efficacy']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Deleted At',
|
||||||
|
'Strategy', 'Efficacy indicators']
|
||||||
|
audit_template_name = 'a' + uuidutils.generate_uuid()
|
||||||
|
audit_uuid = None
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
template_raw_output = cls.watcher(
|
||||||
|
'audittemplate create %s dummy -s dummy' % cls.audit_template_name)
|
||||||
|
template_output = cls.parse_show_as_object(template_raw_output)
|
||||||
|
audit_raw_output = cls.watcher('audit create -a %s'
|
||||||
|
% template_output['Name'])
|
||||||
|
audit_output = cls.parse_show_as_object(audit_raw_output)
|
||||||
|
cls.audit_uuid = audit_output['UUID']
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
# Delete action plan
|
||||||
|
output = cls.parse_show(
|
||||||
|
cls.watcher('actionplan list --audit %s' % cls.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
raw_output = cls.watcher('actionplan delete %s' % action_plan_uuid)
|
||||||
|
cls.assertOutput('', raw_output)
|
||||||
|
# Delete audit
|
||||||
|
raw_output = cls.watcher('audit delete %s' % cls.audit_uuid)
|
||||||
|
cls.assertOutput('', raw_output)
|
||||||
|
# Delete Template
|
||||||
|
raw_output = cls.watcher(
|
||||||
|
'audittemplate delete %s' % cls.audit_template_name)
|
||||||
|
cls.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
def test_action_plan_list(self):
|
||||||
|
raw_output = self.watcher('actionplan list')
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_action_plan_detailed_list(self):
|
||||||
|
raw_output = self.watcher('actionplan list --detail')
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_action_plan_show(self):
|
||||||
|
action_plan_list = self.parse_show(self.watcher('actionplan list'))
|
||||||
|
action_plan_uuid = action_plan_list[0].keys()[0]
|
||||||
|
actionplan = self.watcher('actionplan show %s' % action_plan_uuid)
|
||||||
|
self.assertIn(action_plan_uuid, actionplan)
|
||||||
|
self.assert_table_structure([actionplan],
|
||||||
|
self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_action_plan_start(self):
|
||||||
|
output = self.parse_show(self.watcher('actionplan list --audit %s'
|
||||||
|
% self.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
self.watcher('actionplan start %s' % action_plan_uuid)
|
||||||
|
raw_output = self.watcher('actionplan show %s' % action_plan_uuid)
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
|
||||||
|
|
||||||
|
class ActionPlanActiveTests(base.TestCase):
|
||||||
|
|
||||||
|
audit_uuid = None
|
||||||
|
audit_template_name = 'b' + uuidutils.generate_uuid()
|
||||||
|
|
||||||
|
list_fields = ['UUID', 'Audit', 'State', 'Updated At', 'Global efficacy']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Deleted At',
|
||||||
|
'Strategy', 'Efficacy indicators']
|
||||||
|
|
||||||
|
def _delete_action_plan(self):
|
||||||
|
output = self.parse_show(
|
||||||
|
self.watcher('actionplan list --audit %s' % self.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
raw_output = self.watcher('actionplan delete %s' % action_plan_uuid)
|
||||||
|
self.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
def _delete_audit(self):
|
||||||
|
raw_output = self.watcher('audit delete %s' % self.audit_uuid)
|
||||||
|
self.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
def _delete_audit_template(self):
|
||||||
|
raw_output = self.watcher(
|
||||||
|
'audittemplate delete %s' % self.audit_template_name)
|
||||||
|
self.assertOutput('', raw_output)
|
||||||
|
|
||||||
|
def _create_audit_template(self):
|
||||||
|
template_raw_output = self.watcher(
|
||||||
|
'audittemplate create %s dummy -s dummy'
|
||||||
|
% self.audit_template_name)
|
||||||
|
template_output = self.parse_show_as_object(template_raw_output)
|
||||||
|
return template_output
|
||||||
|
|
||||||
|
def test_action_plan_create(self):
|
||||||
|
template_output = self._create_audit_template()
|
||||||
|
action_plan = self.watcher(
|
||||||
|
'actionplan create -a %s' % template_output['Name'])
|
||||||
|
self.audit_uuid = self.parse_show_as_object(action_plan)['UUID']
|
||||||
|
self.assert_table_structure([action_plan], self.detailed_list_fields)
|
||||||
|
self._delete_action_plan()
|
||||||
|
self._delete_audit()
|
||||||
|
self._delete_audit_template()
|
114
watcherclient/tests/functional/v1/test_audit.py
Normal file
114
watcherclient/tests/functional/v1/test_audit.py
Normal file
@@ -0,0 +1,114 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class AuditTests(base.TestCase):
|
||||||
|
"""Functional tests for audit."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy'
|
||||||
|
list_fields = ['UUID', 'Audit Type', 'State', 'Goal', 'Strategy']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Updated At',
|
||||||
|
'Deleted At', 'Parameters',
|
||||||
|
'Interval', 'Audit Scope']
|
||||||
|
audit_template_name = 'a' + uuidutils.generate_uuid()
|
||||||
|
audit_uuid = None
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
raw_output = cls.watcher('audittemplate create %s dummy -s dummy'
|
||||||
|
% cls.audit_template_name)
|
||||||
|
template_output = cls.parse_show_as_object(raw_output)
|
||||||
|
audit_raw_output = cls.watcher(
|
||||||
|
'audit create -a %s' % template_output['Name'])
|
||||||
|
audit_output = cls.parse_show_as_object(audit_raw_output)
|
||||||
|
cls.audit_uuid = audit_output['UUID']
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
output = cls.parse_show(
|
||||||
|
cls.watcher('actionplan list --audit %s' % cls.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
cls.watcher('actionplan delete %s' % action_plan_uuid)
|
||||||
|
cls.watcher('audit delete %s' % cls.audit_uuid)
|
||||||
|
cls.watcher('audittemplate delete %s' % cls.audit_template_name)
|
||||||
|
|
||||||
|
def test_audit_list(self):
|
||||||
|
raw_output = self.watcher('audit list')
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_audit_detailed_list(self):
|
||||||
|
raw_output = self.watcher('audit list --detail')
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_audit_show(self):
|
||||||
|
audit = self.watcher('audit show ' + self.audit_uuid)
|
||||||
|
self.assertIn(self.audit_uuid, audit)
|
||||||
|
self.assert_table_structure([audit], self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_audit_update(self):
|
||||||
|
audit_raw_output = self.watcher('audit update %s add interval=2'
|
||||||
|
% self.audit_uuid)
|
||||||
|
audit_output = self.parse_show_as_object(audit_raw_output)
|
||||||
|
assert int(audit_output['Interval']) == 2
|
||||||
|
|
||||||
|
|
||||||
|
class AuditActiveTests(base.TestCase):
|
||||||
|
|
||||||
|
list_fields = ['UUID', 'Audit Type', 'State', 'Goal', 'Strategy']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Updated At',
|
||||||
|
'Deleted At', 'Parameters',
|
||||||
|
'Interval', 'Audit Scope']
|
||||||
|
audit_template_name = 'a' + uuidutils.generate_uuid()
|
||||||
|
audit_uuid = None
|
||||||
|
|
||||||
|
def _create_audit(self):
|
||||||
|
raw_output = self.watcher('audittemplate create %s dummy -s dummy'
|
||||||
|
% self.audit_template_name)
|
||||||
|
template_output = self.parse_show_as_object(raw_output)
|
||||||
|
self.audit_uuid = self.parse_show_as_object(
|
||||||
|
self.watcher('audit create -a %s'
|
||||||
|
% template_output['Name']))['UUID']
|
||||||
|
|
||||||
|
def _delete_audit(self):
|
||||||
|
output = self.parse_show(
|
||||||
|
self.watcher('actionplan list --audit %s' % self.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
self.watcher('actionplan delete %s' % action_plan_uuid)
|
||||||
|
self.watcher('audit delete %s' % self.audit_uuid)
|
||||||
|
self.watcher('audittemplate delete %s' % self.audit_template_name)
|
||||||
|
|
||||||
|
def test_create_audit(self):
|
||||||
|
raw_output = self.watcher('audittemplate create %s dummy -s dummy'
|
||||||
|
% self.audit_template_name)
|
||||||
|
template_output = self.parse_show_as_object(raw_output)
|
||||||
|
audit = self.watcher('audit create -a %s' % template_output['Name'])
|
||||||
|
self.audit_uuid = self.parse_show_as_object(audit)['UUID']
|
||||||
|
self.assert_table_structure([audit], self.detailed_list_fields)
|
||||||
|
self._delete_audit()
|
||||||
|
|
||||||
|
def test_delete_audit(self):
|
||||||
|
self._create_audit()
|
||||||
|
raw_output = self.watcher('audit delete %s' % self.audit_uuid)
|
||||||
|
self.assertOutput('', raw_output)
|
||||||
|
output = self.parse_show(
|
||||||
|
self.watcher('actionplan list --audit %s' % self.audit_uuid))
|
||||||
|
action_plan_uuid = output[0].keys()[0]
|
||||||
|
self.watcher('actionplan delete %s' % action_plan_uuid)
|
||||||
|
self.watcher('audittemplate delete %s' % self.audit_template_name)
|
90
watcherclient/tests/functional/v1/test_audit_template.py
Normal file
90
watcherclient/tests/functional/v1/test_audit_template.py
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from oslo_utils import uuidutils
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class AuditTemplateTests(base.TestCase):
|
||||||
|
"""Functional tests for audit template."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy'
|
||||||
|
list_fields = ['UUID', 'Name', 'Goal', 'Strategy']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Updated At',
|
||||||
|
'Deleted At', 'Description',
|
||||||
|
'Audit Scope']
|
||||||
|
audit_template_name = 'a' + uuidutils.generate_uuid()
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def setUpClass(cls):
|
||||||
|
cls.watcher('audittemplate create %s dummy -s dummy'
|
||||||
|
% cls.audit_template_name)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def tearDownClass(cls):
|
||||||
|
cls.watcher('audittemplate delete %s' % cls.audit_template_name)
|
||||||
|
|
||||||
|
def test_audit_template_list(self):
|
||||||
|
raw_output = self.watcher('audittemplate list')
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_audit_template_detailed_list(self):
|
||||||
|
raw_output = self.watcher('audittemplate list --detail')
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_audit_template_show(self):
|
||||||
|
audit_template = self.watcher(
|
||||||
|
'audittemplate show %s' % self.audit_template_name)
|
||||||
|
self.assertIn(self.audit_template_name, audit_template)
|
||||||
|
self.assert_table_structure([audit_template],
|
||||||
|
self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_audit_template_update(self):
|
||||||
|
raw_output = self.watcher('audittemplate update %s replace '
|
||||||
|
'description="Updated Desc"'
|
||||||
|
% self.audit_template_name)
|
||||||
|
audit_template_output = self.parse_show_as_object(raw_output)
|
||||||
|
assert audit_template_output['Description'] == 'Updated Desc'
|
||||||
|
|
||||||
|
|
||||||
|
class AuditTemplateActiveTests(base.TestCase):
|
||||||
|
|
||||||
|
audit_template_name = 'b' + uuidutils.generate_uuid()
|
||||||
|
list_fields = ['UUID', 'Name', 'Goal', 'Strategy']
|
||||||
|
detailed_list_fields = list_fields + ['Created At', 'Updated At',
|
||||||
|
'Deleted At', 'Description',
|
||||||
|
'Audit Scope']
|
||||||
|
|
||||||
|
def _create_audit_template(self):
|
||||||
|
self.watcher('audittemplate create %s dummy -s dummy '
|
||||||
|
'-d "Test Audit Template"' % self.audit_template_name)
|
||||||
|
|
||||||
|
def _delete_audit_template(self):
|
||||||
|
self.watcher('audittemplate delete %s' % self.audit_template_name)
|
||||||
|
|
||||||
|
def test_create_audit_template(self):
|
||||||
|
raw_output = self.watcher('audittemplate create %s dummy '
|
||||||
|
'-s dummy -d "Test Audit Template"'
|
||||||
|
% self.audit_template_name)
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
self._delete_audit_template()
|
||||||
|
|
||||||
|
def test_delete_audit_template(self):
|
||||||
|
self._create_audit_template()
|
||||||
|
raw_output = self.watcher('audittemplate delete %s'
|
||||||
|
% self.audit_template_name)
|
||||||
|
self.assertOutput('', raw_output)
|
42
watcherclient/tests/functional/v1/test_goal.py
Normal file
42
watcherclient/tests/functional/v1/test_goal.py
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class GoalTests(base.TestCase):
|
||||||
|
"""Functional tests for goal."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy'
|
||||||
|
list_fields = ['UUID', 'Name', 'Display name']
|
||||||
|
|
||||||
|
def test_goal_list(self):
|
||||||
|
raw_output = self.watcher('goal list')
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_goal_detailed_list(self):
|
||||||
|
raw_output = self.watcher('goal list --detail')
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure(
|
||||||
|
[raw_output], self.list_fields + ['Efficacy specification'])
|
||||||
|
|
||||||
|
def test_goal_show(self):
|
||||||
|
raw_output = self.watcher('goal show %s' % self.dummy_name)
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure(
|
||||||
|
[raw_output], self.list_fields + ['Efficacy specification'])
|
||||||
|
self.assertNotIn('server_consolidation', raw_output)
|
41
watcherclient/tests/functional/v1/test_scoring_engine.py
Normal file
41
watcherclient/tests/functional/v1/test_scoring_engine.py
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class ScoringEngineTests(base.TestCase):
|
||||||
|
"""Functional tests for scoring engine."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy_scorer'
|
||||||
|
list_fields = ['UUID', 'Name', 'Description']
|
||||||
|
detailed_list_fields = list_fields + ['Metainfo']
|
||||||
|
|
||||||
|
def test_scoringengine_list(self):
|
||||||
|
raw_output = self.watcher('scoringengine list')
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_scoringengine_detailed_list(self):
|
||||||
|
raw_output = self.watcher('scoringengine list --detail')
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
|
||||||
|
def test_scoringengine_show(self):
|
||||||
|
raw_output = self.watcher('scoringengine show %s' % self.dummy_name)
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output], self.detailed_list_fields)
|
||||||
|
self.assertNotIn('dummy_avg_scorer', raw_output)
|
46
watcherclient/tests/functional/v1/test_service.py
Normal file
46
watcherclient/tests/functional/v1/test_service.py
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class ServiceTests(base.TestCase):
|
||||||
|
"""Functional tests for service."""
|
||||||
|
|
||||||
|
decision_engine_name = 'watcher-decision-engine'
|
||||||
|
applier_name = 'watcher-applier'
|
||||||
|
list_fields = ['ID', 'Name', 'Host', 'Status']
|
||||||
|
|
||||||
|
def test_service_list(self):
|
||||||
|
raw_output = self.watcher('service list')
|
||||||
|
self.assertIn(self.decision_engine_name, raw_output)
|
||||||
|
self.assertIn(self.applier_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_service_detailed_list(self):
|
||||||
|
raw_output = self.watcher('service list --detail')
|
||||||
|
self.assertIn(self.decision_engine_name, raw_output)
|
||||||
|
self.assertIn(self.applier_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output],
|
||||||
|
self.list_fields + ['Last seen up'])
|
||||||
|
|
||||||
|
def test_service_show(self):
|
||||||
|
raw_output = self.watcher('service show %s'
|
||||||
|
% self.decision_engine_name)
|
||||||
|
self.assertIn(self.decision_engine_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output],
|
||||||
|
self.list_fields + ['Last seen up'])
|
||||||
|
self.assertNotIn(self.applier_name, raw_output)
|
42
watcherclient/tests/functional/v1/test_strategy.py
Normal file
42
watcherclient/tests/functional/v1/test_strategy.py
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
# Copyright (c) 2016 Servionica
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
# implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
from watcherclient.tests.functional.v1 import base
|
||||||
|
|
||||||
|
|
||||||
|
class StrategyTests(base.TestCase):
|
||||||
|
"""Functional tests for strategy."""
|
||||||
|
|
||||||
|
dummy_name = 'dummy'
|
||||||
|
list_fields = ['UUID', 'Name', 'Display name', 'Goal']
|
||||||
|
|
||||||
|
def test_strategy_list(self):
|
||||||
|
raw_output = self.watcher('strategy list')
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output], self.list_fields)
|
||||||
|
|
||||||
|
def test_strategy_detailed_list(self):
|
||||||
|
raw_output = self.watcher('strategy list --detail')
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output],
|
||||||
|
self.list_fields + ['Parameters spec'])
|
||||||
|
|
||||||
|
def test_strategy_show(self):
|
||||||
|
raw_output = self.watcher('strategy show %s' % self.dummy_name)
|
||||||
|
self.assertIn(self.dummy_name, raw_output)
|
||||||
|
self.assert_table_structure([raw_output],
|
||||||
|
self.list_fields + ['Parameters spec'])
|
||||||
|
self.assertNotIn('basic', raw_output)
|
0
watcherclient/tests/unit/__init__.py
Normal file
0
watcherclient/tests/unit/__init__.py
Normal file
0
watcherclient/tests/unit/common/__init__.py
Normal file
0
watcherclient/tests/unit/common/__init__.py
Normal file
@@ -17,7 +17,7 @@ import mock
|
|||||||
|
|
||||||
from watcherclient.common import api_versioning
|
from watcherclient.common import api_versioning
|
||||||
from watcherclient import exceptions
|
from watcherclient import exceptions
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
|
|
||||||
|
|
||||||
class APIVersionTestCase(utils.BaseTestCase):
|
class APIVersionTestCase(utils.BaseTestCase):
|
@@ -17,7 +17,7 @@ from keystoneauth1 import loading as kaloading
|
|||||||
from watcherclient import client as watcherclient
|
from watcherclient import client as watcherclient
|
||||||
from watcherclient.common import httpclient
|
from watcherclient.common import httpclient
|
||||||
from watcherclient import exceptions
|
from watcherclient import exceptions
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
|
|
||||||
|
|
||||||
class ClientTest(utils.BaseTestCase):
|
class ClientTest(utils.BaseTestCase):
|
@@ -11,7 +11,7 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
|
|
||||||
module_str = 'watcherclient'
|
module_str = 'watcherclient'
|
||||||
|
|
@@ -18,7 +18,7 @@ import mock
|
|||||||
|
|
||||||
from watcherclient.common.apiclient import exceptions as exc
|
from watcherclient.common.apiclient import exceptions as exc
|
||||||
from watcherclient.common import utils
|
from watcherclient.common import utils
|
||||||
from watcherclient.tests import utils as test_utils
|
from watcherclient.tests.unit import utils as test_utils
|
||||||
|
|
||||||
|
|
||||||
class UtilsTest(test_utils.BaseTestCase):
|
class UtilsTest(test_utils.BaseTestCase):
|
0
watcherclient/tests/unit/v1/__init__.py
Normal file
0
watcherclient/tests/unit/v1/__init__.py
Normal file
@@ -20,7 +20,7 @@ import mock
|
|||||||
from osc_lib import utils as oscutils
|
from osc_lib import utils as oscutils
|
||||||
|
|
||||||
from watcherclient.common import httpclient
|
from watcherclient.common import httpclient
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
|
|
||||||
|
|
||||||
class CommandTestCase(utils.BaseTestCase):
|
class CommandTestCase(utils.BaseTestCase):
|
@@ -16,7 +16,7 @@
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.action
|
import watcherclient.v1.action
|
||||||
|
|
||||||
ACTION1 = {
|
ACTION1 = {
|
@@ -18,7 +18,7 @@ import copy
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.action_plan
|
import watcherclient.v1.action_plan
|
||||||
|
|
||||||
ACTION_PLAN1 = {
|
ACTION_PLAN1 = {
|
@@ -14,13 +14,12 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import exceptions
|
from watcherclient import exceptions
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -14,13 +14,12 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import exceptions
|
from watcherclient import exceptions
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -18,7 +18,7 @@ import copy
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.audit
|
import watcherclient.v1.audit
|
||||||
|
|
||||||
|
|
@@ -14,13 +14,12 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import exceptions
|
from watcherclient import exceptions
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -18,7 +18,7 @@ import copy
|
|||||||
from six.moves.urllib import parse as urlparse
|
from six.moves.urllib import parse as urlparse
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.audit_template
|
import watcherclient.v1.audit_template
|
||||||
|
|
||||||
AUDIT_TMPL1 = {
|
AUDIT_TMPL1 = {
|
@@ -14,12 +14,11 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -17,7 +17,7 @@
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.goal
|
import watcherclient.v1.goal
|
||||||
|
|
||||||
GOAL1 = {
|
GOAL1 = {
|
@@ -14,12 +14,11 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -17,7 +17,7 @@
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.scoring_engine
|
import watcherclient.v1.scoring_engine
|
||||||
|
|
||||||
SE1 = {
|
SE1 = {
|
@@ -14,12 +14,11 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -17,7 +17,7 @@
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.service
|
import watcherclient.v1.service
|
||||||
|
|
||||||
SERVICE1 = {
|
SERVICE1 = {
|
@@ -14,12 +14,11 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
@@ -17,7 +17,7 @@
|
|||||||
import testtools
|
import testtools
|
||||||
from testtools import matchers
|
from testtools import matchers
|
||||||
|
|
||||||
from watcherclient.tests import utils
|
from watcherclient.tests.unit import utils
|
||||||
import watcherclient.v1.strategy
|
import watcherclient.v1.strategy
|
||||||
|
|
||||||
STRATEGY1 = {
|
STRATEGY1 = {
|
@@ -14,12 +14,11 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from watcherclient import shell
|
from watcherclient import shell
|
||||||
from watcherclient.tests.v1 import base
|
from watcherclient.tests.unit.v1 import base
|
||||||
from watcherclient import v1 as resource
|
from watcherclient import v1 as resource
|
||||||
from watcherclient.v1 import resource_fields
|
from watcherclient.v1 import resource_fields
|
||||||
|
|
Reference in New Issue
Block a user