[1] moves the attr decorator from test.py to tempest/lib. So, all the references to tempest.test has to be moved to tempest.lib.decorator. [2] https://review.openstack.org/#/c/456236/ Change-Id: If977e559d9f3b982baf2974efef3c5b375f263b9
222 lines
7.4 KiB
Python
222 lines
7.4 KiB
Python
# -*- encoding: utf-8 -*-
|
|
# Copyright (c) 2016 b<>com
|
|
#
|
|
# 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 __future__ import unicode_literals
|
|
|
|
import functools
|
|
|
|
from tempest.lib.common.utils import test_utils
|
|
from tempest.lib import decorators
|
|
from tempest.lib import exceptions
|
|
|
|
from watcher_tempest_plugin.tests.api.admin import base
|
|
|
|
|
|
class TestCreateUpdateDeleteAudit(base.BaseInfraOptimTest):
|
|
"""Tests for audit."""
|
|
|
|
audit_states = ['ONGOING', 'SUCCEEDED', 'FAILED',
|
|
'CANCELLED', 'DELETED', 'PENDING', 'SUSPENDED']
|
|
|
|
def assert_expected(self, expected, actual,
|
|
keys=('created_at', 'updated_at',
|
|
'deleted_at', 'state')):
|
|
super(TestCreateUpdateDeleteAudit, self).assert_expected(
|
|
expected, actual, keys)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_create_audit_oneshot(self):
|
|
_, goal = self.client.show_goal("dummy")
|
|
_, audit_template = self.create_audit_template(goal['uuid'])
|
|
|
|
audit_params = dict(
|
|
audit_template_uuid=audit_template['uuid'],
|
|
audit_type='ONESHOT',
|
|
)
|
|
|
|
_, body = self.create_audit(**audit_params)
|
|
audit_params.pop('audit_template_uuid')
|
|
audit_params['goal_uuid'] = goal['uuid']
|
|
self.assert_expected(audit_params, body)
|
|
|
|
_, audit = self.client.show_audit(body['uuid'])
|
|
self.assert_expected(audit, body)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_create_audit_continuous(self):
|
|
_, goal = self.client.show_goal("dummy")
|
|
_, audit_template = self.create_audit_template(goal['uuid'])
|
|
|
|
audit_params = dict(
|
|
audit_template_uuid=audit_template['uuid'],
|
|
audit_type='CONTINUOUS',
|
|
interval=7200,
|
|
)
|
|
|
|
_, body = self.create_audit(**audit_params)
|
|
audit_params.pop('audit_template_uuid')
|
|
audit_params['goal_uuid'] = goal['uuid']
|
|
self.assert_expected(audit_params, body)
|
|
|
|
_, audit = self.client.show_audit(body['uuid'])
|
|
self.assert_expected(audit, body)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_create_audit_with_wrong_audit_template(self):
|
|
audit_params = dict(
|
|
audit_template_uuid='INVALID',
|
|
audit_type='ONESHOT',
|
|
)
|
|
|
|
self.assertRaises(
|
|
exceptions.BadRequest, self.create_audit, **audit_params)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_create_audit_with_invalid_state(self):
|
|
_, goal = self.client.show_goal("dummy")
|
|
_, audit_template = self.create_audit_template(goal['uuid'])
|
|
|
|
audit_params = dict(
|
|
audit_template_uuid=audit_template['uuid'],
|
|
state='INVALID',
|
|
)
|
|
|
|
self.assertRaises(
|
|
exceptions.BadRequest, self.create_audit, **audit_params)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_create_audit_with_no_state(self):
|
|
_, goal = self.client.show_goal("dummy")
|
|
_, audit_template = self.create_audit_template(goal['uuid'])
|
|
|
|
audit_params = dict(
|
|
audit_template_uuid=audit_template['uuid'],
|
|
state='',
|
|
)
|
|
|
|
_, body = self.create_audit(**audit_params)
|
|
audit_params.pop('audit_template_uuid')
|
|
audit_params['goal_uuid'] = goal['uuid']
|
|
self.assert_expected(audit_params, body)
|
|
|
|
_, audit = self.client.show_audit(body['uuid'])
|
|
|
|
initial_audit_state = audit.pop('state')
|
|
self.assertIn(initial_audit_state, self.audit_states)
|
|
|
|
self.assert_expected(audit, body)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_delete_audit(self):
|
|
_, goal = self.client.show_goal("dummy")
|
|
_, audit_template = self.create_audit_template(goal['uuid'])
|
|
_, body = self.create_audit(audit_template['uuid'])
|
|
audit_uuid = body['uuid']
|
|
|
|
test_utils.call_until_true(
|
|
func=functools.partial(
|
|
self.is_audit_idle, audit_uuid),
|
|
duration=10,
|
|
sleep_for=.5
|
|
)
|
|
|
|
def is_audit_deleted(uuid):
|
|
try:
|
|
return not bool(self.client.show_audit(uuid))
|
|
except exceptions.NotFound:
|
|
return True
|
|
|
|
self.delete_audit(audit_uuid)
|
|
|
|
test_utils.call_until_true(
|
|
func=functools.partial(is_audit_deleted, audit_uuid),
|
|
duration=5,
|
|
sleep_for=1
|
|
)
|
|
|
|
self.assertTrue(is_audit_deleted(audit_uuid))
|
|
|
|
|
|
class TestShowListAudit(base.BaseInfraOptimTest):
|
|
"""Tests for audit."""
|
|
|
|
audit_states = ['ONGOING', 'SUCCEEDED', 'FAILED',
|
|
'CANCELLED', 'DELETED', 'PENDING', 'SUSPENDED']
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(TestShowListAudit, cls).resource_setup()
|
|
_, cls.goal = cls.client.show_goal("dummy")
|
|
_, cls.audit_template = cls.create_audit_template(cls.goal['uuid'])
|
|
_, cls.audit = cls.create_audit(cls.audit_template['uuid'])
|
|
|
|
def assert_expected(self, expected, actual,
|
|
keys=('created_at', 'updated_at',
|
|
'deleted_at', 'state')):
|
|
super(TestShowListAudit, self).assert_expected(
|
|
expected, actual, keys)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_show_audit(self):
|
|
_, audit = self.client.show_audit(
|
|
self.audit['uuid'])
|
|
|
|
initial_audit = self.audit.copy()
|
|
del initial_audit['state']
|
|
audit_state = audit['state']
|
|
actual_audit = audit.copy()
|
|
del actual_audit['state']
|
|
|
|
self.assertIn(audit_state, self.audit_states)
|
|
self.assert_expected(initial_audit, actual_audit)
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_show_audit_with_links(self):
|
|
_, audit = self.client.show_audit(
|
|
self.audit['uuid'])
|
|
self.assertIn('links', audit.keys())
|
|
self.assertEqual(2, len(audit['links']))
|
|
self.assertIn(audit['uuid'],
|
|
audit['links'][0]['href'])
|
|
|
|
@decorators.attr(type="smoke")
|
|
def test_list_audits(self):
|
|
_, body = self.client.list_audits()
|
|
self.assertIn(self.audit['uuid'],
|
|
[i['uuid'] for i in body['audits']])
|
|
# Verify self links.
|
|
for audit in body['audits']:
|
|
self.validate_self_link('audits', audit['uuid'],
|
|
audit['links'][0]['href'])
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_list_with_limit(self):
|
|
# We create 3 extra audits to exceed the limit we fix
|
|
for _ in range(3):
|
|
self.create_audit(self.audit_template['uuid'])
|
|
|
|
_, body = self.client.list_audits(limit=3)
|
|
|
|
next_marker = body['audits'][-1]['uuid']
|
|
self.assertEqual(3, len(body['audits']))
|
|
self.assertIn(next_marker, body['next'])
|
|
|
|
@decorators.attr(type='smoke')
|
|
def test_list_audits_related_to_given_audit_template(self):
|
|
_, body = self.client.list_audits(
|
|
goal=self.goal['uuid'])
|
|
self.assertIn(self.audit['uuid'], [n['uuid'] for n in body['audits']])
|