# Copyright 2015 OpenStack Foundation # All Rights Reserved. # # 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. """Tests for manipulating ActionPlan via the DB API""" import freezegun import six from watcher.common import exception from watcher.common import utils as w_utils from watcher.objects import action_plan as ap_objects from watcher.tests.db import base from watcher.tests.db import utils class TestDbActionPlanFilters(base.DbTestCase): FAKE_OLDER_DATE = '2014-01-01T09:52:05.219414' FAKE_OLD_DATE = '2015-01-01T09:52:05.219414' FAKE_TODAY = '2016-02-24T09:52:05.219414' def setUp(self): super(TestDbActionPlanFilters, self).setUp() self.context.show_deleted = True self._data_setup() def _data_setup(self): self.audit_template_name = "Audit Template" self.audit_template = utils.create_test_audit_template( name=self.audit_template_name, id=1, uuid=None) self.audit = utils.create_test_audit( audit_template_id=self.audit_template.id, id=1, uuid=None) with freezegun.freeze_time(self.FAKE_TODAY): self.action_plan1 = utils.create_test_action_plan( audit_id=self.audit.id, id=1, uuid=None) with freezegun.freeze_time(self.FAKE_OLD_DATE): self.action_plan2 = utils.create_test_action_plan( audit_id=self.audit.id, id=2, uuid=None) with freezegun.freeze_time(self.FAKE_OLDER_DATE): self.action_plan3 = utils.create_test_action_plan( audit_id=self.audit.id, id=3, uuid=None) def _soft_delete_action_plans(self): with freezegun.freeze_time(self.FAKE_TODAY): self.dbapi.soft_delete_action_plan(self.action_plan1.uuid) with freezegun.freeze_time(self.FAKE_OLD_DATE): self.dbapi.soft_delete_action_plan(self.action_plan2.uuid) with freezegun.freeze_time(self.FAKE_OLDER_DATE): self.dbapi.soft_delete_action_plan(self.action_plan3.uuid) def _update_action_plans(self): with freezegun.freeze_time(self.FAKE_TODAY): self.dbapi.update_action_plan( self.action_plan1.uuid, values={"state": ap_objects.State.SUCCEEDED}) with freezegun.freeze_time(self.FAKE_OLD_DATE): self.dbapi.update_action_plan( self.action_plan2.uuid, values={"state": ap_objects.State.SUCCEEDED}) with freezegun.freeze_time(self.FAKE_OLDER_DATE): self.dbapi.update_action_plan( self.action_plan3.uuid, values={"state": ap_objects.State.SUCCEEDED}) def test_get_action_plan_list_filter_deleted_true(self): with freezegun.freeze_time(self.FAKE_TODAY): self.dbapi.soft_delete_action_plan(self.action_plan1.uuid) res = self.dbapi.get_action_plan_list( self.context, filters={'deleted': True}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_deleted_false(self): with freezegun.freeze_time(self.FAKE_TODAY): self.dbapi.soft_delete_action_plan(self.action_plan1.uuid) res = self.dbapi.get_action_plan_list( self.context, filters={'deleted': False}) self.assertEqual([self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_deleted_at_eq(self): self._soft_delete_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'deleted_at__eq': self.FAKE_TODAY}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_deleted_at_lt(self): self._soft_delete_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'deleted_at__lt': self.FAKE_TODAY}) self.assertEqual( [self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_deleted_at_lte(self): self._soft_delete_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'deleted_at__lte': self.FAKE_OLD_DATE}) self.assertEqual( [self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_deleted_at_gt(self): self._soft_delete_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'deleted_at__gt': self.FAKE_OLD_DATE}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_deleted_at_gte(self): self._soft_delete_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'deleted_at__gte': self.FAKE_OLD_DATE}) self.assertEqual( [self.action_plan1['id'], self.action_plan2['id']], [r.id for r in res]) # created_at # def test_get_action_plan_list_filter_created_at_eq(self): res = self.dbapi.get_action_plan_list( self.context, filters={'created_at__eq': self.FAKE_TODAY}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_created_at_lt(self): res = self.dbapi.get_action_plan_list( self.context, filters={'created_at__lt': self.FAKE_TODAY}) self.assertEqual( [self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_created_at_lte(self): res = self.dbapi.get_action_plan_list( self.context, filters={'created_at__lte': self.FAKE_OLD_DATE}) self.assertEqual( [self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_created_at_gt(self): res = self.dbapi.get_action_plan_list( self.context, filters={'created_at__gt': self.FAKE_OLD_DATE}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_created_at_gte(self): res = self.dbapi.get_action_plan_list( self.context, filters={'created_at__gte': self.FAKE_OLD_DATE}) self.assertEqual( [self.action_plan1['id'], self.action_plan2['id']], [r.id for r in res]) # updated_at # def test_get_action_plan_list_filter_updated_at_eq(self): self._update_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'updated_at__eq': self.FAKE_TODAY}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_updated_at_lt(self): self._update_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'updated_at__lt': self.FAKE_TODAY}) self.assertEqual( [self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_updated_at_lte(self): self._update_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'updated_at__lte': self.FAKE_OLD_DATE}) self.assertEqual( [self.action_plan2['id'], self.action_plan3['id']], [r.id for r in res]) def test_get_action_plan_list_filter_updated_at_gt(self): self._update_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'updated_at__gt': self.FAKE_OLD_DATE}) self.assertEqual([self.action_plan1['id']], [r.id for r in res]) def test_get_action_plan_list_filter_updated_at_gte(self): self._update_action_plans() res = self.dbapi.get_action_plan_list( self.context, filters={'updated_at__gte': self.FAKE_OLD_DATE}) self.assertEqual( [self.action_plan1['id'], self.action_plan2['id']], [r.id for r in res]) class DbActionPlanTestCase(base.DbTestCase): def _create_test_audit(self, **kwargs): audit = utils.get_test_audit(**kwargs) self.dbapi.create_audit(audit) return audit def _create_test_action_plan(self, **kwargs): action_plan = utils.get_test_action_plan(**kwargs) self.dbapi.create_action_plan(action_plan) return action_plan def test_get_action_plan_list(self): uuids = [] for i in range(1, 6): audit = utils.create_test_action_plan(uuid=w_utils.generate_uuid()) uuids.append(six.text_type(audit['uuid'])) res = self.dbapi.get_action_plan_list(self.context) res_uuids = [r.uuid for r in res] self.assertEqual(uuids.sort(), res_uuids.sort()) def test_get_action_plan_list_with_filters(self): audit = self._create_test_audit( id=1, audit_type='ONESHOT', uuid=w_utils.generate_uuid(), deadline=None, state='ONGOING') action_plan1 = self._create_test_action_plan( id=1, uuid=w_utils.generate_uuid(), audit_id=audit['id'], first_action_id=None, state='RECOMMENDED') action_plan2 = self._create_test_action_plan( id=2, uuid=w_utils.generate_uuid(), audit_id=audit['id'], first_action_id=action_plan1['id'], state='ONGOING') res = self.dbapi.get_action_plan_list( self.context, filters={'state': 'RECOMMENDED'}) self.assertEqual([action_plan1['id']], [r.id for r in res]) res = self.dbapi.get_action_plan_list( self.context, filters={'state': 'ONGOING'}) self.assertEqual([action_plan2['id']], [r.id for r in res]) res = self.dbapi.get_action_plan_list( self.context, filters={'audit_uuid': audit['uuid']}) for r in res: self.assertEqual(audit['id'], r.audit_id) def test_get_action_plan_list_with_filter_by_uuid(self): action_plan = self._create_test_action_plan() res = self.dbapi.get_action_plan_list( self.context, filters={'uuid': action_plan["uuid"]}) self.assertEqual(len(res), 1) self.assertEqual(action_plan['uuid'], res[0].uuid) def test_get_action_plan_by_id(self): action_plan = self._create_test_action_plan() action_plan = self.dbapi.get_action_plan_by_id( self.context, action_plan['id']) self.assertEqual(action_plan['uuid'], action_plan.uuid) def test_get_action_plan_by_uuid(self): action_plan = self._create_test_action_plan() action_plan = self.dbapi.get_action_plan_by_uuid( self.context, action_plan['uuid']) self.assertEqual(action_plan['id'], action_plan.id) def test_get_action_plan_that_does_not_exist(self): self.assertRaises(exception.ActionPlanNotFound, self.dbapi.get_action_plan_by_id, self.context, 1234) def test_update_action_plan(self): action_plan = self._create_test_action_plan() res = self.dbapi.update_action_plan( action_plan['id'], {'name': 'updated-model'}) self.assertEqual('updated-model', res.name) def test_update_action_plan_that_does_not_exist(self): self.assertRaises(exception.ActionPlanNotFound, self.dbapi.update_action_plan, 1234, {'name': ''}) def test_update_action_plan_uuid(self): action_plan = self._create_test_action_plan() self.assertRaises(exception.Invalid, self.dbapi.update_action_plan, action_plan['id'], {'uuid': 'hello'}) def test_destroy_action_plan(self): action_plan = self._create_test_action_plan() self.dbapi.destroy_action_plan(action_plan['id']) self.assertRaises(exception.ActionPlanNotFound, self.dbapi.get_action_plan_by_id, self.context, action_plan['id']) def test_destroy_action_plan_by_uuid(self): uuid = w_utils.generate_uuid() self._create_test_action_plan(uuid=uuid) self.assertIsNotNone(self.dbapi.get_action_plan_by_uuid( self.context, uuid)) self.dbapi.destroy_action_plan(uuid) self.assertRaises(exception.ActionPlanNotFound, self.dbapi.get_action_plan_by_uuid, self.context, uuid) def test_destroy_action_plan_that_does_not_exist(self): self.assertRaises(exception.ActionPlanNotFound, self.dbapi.destroy_action_plan, 1234) def test_destroy_action_plan_that_referenced_by_actions(self): action_plan = self._create_test_action_plan() action = utils.create_test_action(action_plan_id=action_plan['id']) self.assertEqual(action_plan['id'], action.action_plan_id) self.assertRaises(exception.ActionPlanReferenced, self.dbapi.destroy_action_plan, action_plan['id']) def test_create_action_plan_already_exists(self): uuid = w_utils.generate_uuid() self._create_test_action_plan(id=1, uuid=uuid) self.assertRaises(exception.ActionPlanAlreadyExists, self._create_test_action_plan, id=2, uuid=uuid)