Added audit & strategy ObjectField for ActionPlan
In this changeset, I added the "audit" and the "strategy "ObjectField which can either be loaded by setting the new "eager" parameter as True or not loaded (as before) by setting it to False. The advantage of introducing this eager parameter is that this way, we can reduce to a minimum the overhead of DB queries whenever the related object fields is not actually needed. Change-Id: Ieca6fa438cbf2267f5ae2ea0d059b2953e65076b Partially-Implements: blueprint watcher-versioned-objects
This commit is contained in:
@@ -71,10 +71,9 @@ state may be one of the following:
|
|||||||
|
|
||||||
from watcher.common import exception
|
from watcher.common import exception
|
||||||
from watcher.common import utils
|
from watcher.common import utils
|
||||||
from watcher.db import api as dbapi
|
from watcher.db import api as db_api
|
||||||
from watcher.objects import action as action_objects
|
from watcher import objects
|
||||||
from watcher.objects import base
|
from watcher.objects import base
|
||||||
from watcher.objects import efficacy_indicator as indicator_objects
|
|
||||||
from watcher.objects import fields as wfields
|
from watcher.objects import fields as wfields
|
||||||
|
|
||||||
|
|
||||||
@@ -91,10 +90,12 @@ class State(object):
|
|||||||
@base.WatcherObjectRegistry.register
|
@base.WatcherObjectRegistry.register
|
||||||
class ActionPlan(base.WatcherPersistentObject, base.WatcherObject,
|
class ActionPlan(base.WatcherPersistentObject, base.WatcherObject,
|
||||||
base.WatcherObjectDictCompat):
|
base.WatcherObjectDictCompat):
|
||||||
# Version 1.0: Initial version
|
|
||||||
VERSION = '1.0'
|
|
||||||
|
|
||||||
dbapi = dbapi.get_instance()
|
# Version 1.0: Initial version
|
||||||
|
# Version 1.1: Added 'audit' and 'strategy' object field
|
||||||
|
VERSION = '1.1'
|
||||||
|
|
||||||
|
dbapi = db_api.get_instance()
|
||||||
|
|
||||||
fields = {
|
fields = {
|
||||||
'id': wfields.IntegerField(),
|
'id': wfields.IntegerField(),
|
||||||
@@ -104,50 +105,63 @@ class ActionPlan(base.WatcherPersistentObject, base.WatcherObject,
|
|||||||
'first_action_id': wfields.IntegerField(nullable=True),
|
'first_action_id': wfields.IntegerField(nullable=True),
|
||||||
'state': wfields.StringField(nullable=True),
|
'state': wfields.StringField(nullable=True),
|
||||||
'global_efficacy': wfields.FlexibleDictField(nullable=True),
|
'global_efficacy': wfields.FlexibleDictField(nullable=True),
|
||||||
|
|
||||||
|
'audit': wfields.ObjectField('Audit', nullable=True),
|
||||||
|
'strategy': wfields.ObjectField('Strategy', nullable=True),
|
||||||
|
}
|
||||||
|
|
||||||
|
object_fields = {
|
||||||
|
'audit': (objects.Audit, 'audit_id'),
|
||||||
|
'strategy': (objects.Strategy, 'strategy_id'),
|
||||||
}
|
}
|
||||||
|
|
||||||
@base.remotable_classmethod
|
@base.remotable_classmethod
|
||||||
def get(cls, context, action_plan_id):
|
def get(cls, context, action_plan_id, eager=False):
|
||||||
"""Find a action_plan based on its id or uuid and return a Action object.
|
"""Find a action_plan based on its id or uuid and return a Action object.
|
||||||
|
|
||||||
:param action_plan_id: the id *or* uuid of a action_plan.
|
:param action_plan_id: the id *or* uuid of a action_plan.
|
||||||
|
:param eager: Load object fields if True (Default: False)
|
||||||
:returns: a :class:`Action` object.
|
:returns: a :class:`Action` object.
|
||||||
"""
|
"""
|
||||||
if utils.is_int_like(action_plan_id):
|
if utils.is_int_like(action_plan_id):
|
||||||
return cls.get_by_id(context, action_plan_id)
|
return cls.get_by_id(context, action_plan_id, eager=eager)
|
||||||
elif utils.is_uuid_like(action_plan_id):
|
elif utils.is_uuid_like(action_plan_id):
|
||||||
return cls.get_by_uuid(context, action_plan_id)
|
return cls.get_by_uuid(context, action_plan_id, eager=eager)
|
||||||
else:
|
else:
|
||||||
raise exception.InvalidIdentity(identity=action_plan_id)
|
raise exception.InvalidIdentity(identity=action_plan_id)
|
||||||
|
|
||||||
@base.remotable_classmethod
|
@base.remotable_classmethod
|
||||||
def get_by_id(cls, context, action_plan_id):
|
def get_by_id(cls, context, action_plan_id, eager=False):
|
||||||
"""Find a action_plan based on its integer id and return a Action object.
|
"""Find a action_plan based on its integer id and return a Action object.
|
||||||
|
|
||||||
:param action_plan_id: the id of a action_plan.
|
:param action_plan_id: the id of a action_plan.
|
||||||
|
:param eager: Load object fields if True (Default: False)
|
||||||
:returns: a :class:`Action` object.
|
:returns: a :class:`Action` object.
|
||||||
"""
|
"""
|
||||||
db_action_plan = cls.dbapi.get_action_plan_by_id(
|
db_action_plan = cls.dbapi.get_action_plan_by_id(
|
||||||
context, action_plan_id)
|
context, action_plan_id, eager=eager)
|
||||||
action_plan = ActionPlan._from_db_object(
|
action_plan = cls._from_db_object(
|
||||||
cls(context), db_action_plan)
|
cls(context), db_action_plan, eager=eager)
|
||||||
return action_plan
|
return action_plan
|
||||||
|
|
||||||
@base.remotable_classmethod
|
@base.remotable_classmethod
|
||||||
def get_by_uuid(cls, context, uuid):
|
def get_by_uuid(cls, context, uuid, eager=False):
|
||||||
"""Find a action_plan based on uuid and return a :class:`Action` object.
|
"""Find a action_plan based on uuid and return a :class:`Action` object.
|
||||||
|
|
||||||
:param uuid: the uuid of a action_plan.
|
:param uuid: the uuid of a action_plan.
|
||||||
:param context: Security context
|
:param context: Security context
|
||||||
|
:param eager: Load object fields if True (Default: False)
|
||||||
:returns: a :class:`Action` object.
|
:returns: a :class:`Action` object.
|
||||||
"""
|
"""
|
||||||
db_action_plan = cls.dbapi.get_action_plan_by_uuid(context, uuid)
|
db_action_plan = cls.dbapi.get_action_plan_by_uuid(
|
||||||
action_plan = ActionPlan._from_db_object(cls(context), db_action_plan)
|
context, uuid, eager=eager)
|
||||||
|
action_plan = cls._from_db_object(
|
||||||
|
cls(context), db_action_plan, eager=eager)
|
||||||
return action_plan
|
return action_plan
|
||||||
|
|
||||||
@base.remotable_classmethod
|
@base.remotable_classmethod
|
||||||
def list(cls, context, limit=None, marker=None, filters=None,
|
def list(cls, context, limit=None, marker=None, filters=None,
|
||||||
sort_key=None, sort_dir=None):
|
sort_key=None, sort_dir=None, eager=False):
|
||||||
"""Return a list of Action objects.
|
"""Return a list of Action objects.
|
||||||
|
|
||||||
:param context: Security context.
|
:param context: Security context.
|
||||||
@@ -156,30 +170,36 @@ class ActionPlan(base.WatcherPersistentObject, base.WatcherObject,
|
|||||||
:param filters: Filters to apply. Defaults to None.
|
:param filters: Filters to apply. Defaults to None.
|
||||||
:param sort_key: column to sort results by.
|
:param sort_key: column to sort results by.
|
||||||
:param sort_dir: direction to sort. "asc" or "desc".
|
:param sort_dir: direction to sort. "asc" or "desc".
|
||||||
|
:param eager: Load object fields if True (Default: False)
|
||||||
:returns: a list of :class:`ActionPlan` object.
|
:returns: a list of :class:`ActionPlan` object.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
db_action_plans = cls.dbapi.get_action_plan_list(context,
|
db_action_plans = cls.dbapi.get_action_plan_list(context,
|
||||||
limit=limit,
|
limit=limit,
|
||||||
marker=marker,
|
marker=marker,
|
||||||
filters=filters,
|
filters=filters,
|
||||||
sort_key=sort_key,
|
sort_key=sort_key,
|
||||||
sort_dir=sort_dir)
|
sort_dir=sort_dir,
|
||||||
|
eager=eager)
|
||||||
|
|
||||||
return [cls._from_db_object(cls(context), obj)
|
return [cls._from_db_object(cls(context), obj, eager=eager)
|
||||||
for obj in db_action_plans]
|
for obj in db_action_plans]
|
||||||
|
|
||||||
@base.remotable
|
@base.remotable
|
||||||
def create(self):
|
def create(self):
|
||||||
"""Create a Action record in the DB"""
|
"""Create an :class:`ActionPlan` record in the DB.
|
||||||
|
|
||||||
|
:returns: An :class:`ActionPlan` object.
|
||||||
|
"""
|
||||||
values = self.obj_get_changes()
|
values = self.obj_get_changes()
|
||||||
db_action_plan = self.dbapi.create_action_plan(values)
|
db_action_plan = self.dbapi.create_action_plan(values)
|
||||||
self._from_db_object(self, db_action_plan)
|
# Note(v-francoise): Always load eagerly upon creation so we can send
|
||||||
|
# notifications containing information about the related relationships
|
||||||
|
self._from_db_object(self, db_action_plan, eager=True)
|
||||||
|
|
||||||
@base.remotable
|
@base.remotable
|
||||||
def destroy(self):
|
def destroy(self):
|
||||||
"""Delete the action plan from the DB"""
|
"""Delete the action plan from the DB"""
|
||||||
related_efficacy_indicators = indicator_objects.EfficacyIndicator.list(
|
related_efficacy_indicators = objects.EfficacyIndicator.list(
|
||||||
context=self._context,
|
context=self._context,
|
||||||
filters={"action_plan_uuid": self.uuid})
|
filters={"action_plan_uuid": self.uuid})
|
||||||
|
|
||||||
@@ -203,20 +223,21 @@ class ActionPlan(base.WatcherPersistentObject, base.WatcherObject,
|
|||||||
self.obj_reset_changes()
|
self.obj_reset_changes()
|
||||||
|
|
||||||
@base.remotable
|
@base.remotable
|
||||||
def refresh(self):
|
def refresh(self, eager=False):
|
||||||
"""Loads updates for this Action plan.
|
"""Loads updates for this Action plan.
|
||||||
|
|
||||||
Loads a action_plan with the same uuid from the database and
|
Loads a action_plan with the same uuid from the database and
|
||||||
checks for updated attributes. Updates are applied from
|
checks for updated attributes. Updates are applied from
|
||||||
the loaded action_plan column by column, if there are any updates.
|
the loaded action_plan column by column, if there are any updates.
|
||||||
|
:param eager: Load object fields if True (Default: False)
|
||||||
"""
|
"""
|
||||||
current = self.__class__.get_by_uuid(self._context, uuid=self.uuid)
|
current = self.get_by_uuid(self._context, uuid=self.uuid, eager=eager)
|
||||||
self.obj_refresh(current)
|
self.obj_refresh(current)
|
||||||
|
|
||||||
@base.remotable
|
@base.remotable
|
||||||
def soft_delete(self):
|
def soft_delete(self):
|
||||||
"""Soft Delete the Action plan from the DB"""
|
"""Soft Delete the Action plan from the DB"""
|
||||||
related_actions = action_objects.Action.list(
|
related_actions = objects.Action.list(
|
||||||
context=self._context,
|
context=self._context,
|
||||||
filters={"action_plan_uuid": self.uuid})
|
filters={"action_plan_uuid": self.uuid})
|
||||||
|
|
||||||
@@ -224,7 +245,7 @@ class ActionPlan(base.WatcherPersistentObject, base.WatcherObject,
|
|||||||
for related_action in related_actions:
|
for related_action in related_actions:
|
||||||
related_action.soft_delete()
|
related_action.soft_delete()
|
||||||
|
|
||||||
related_efficacy_indicators = indicator_objects.EfficacyIndicator.list(
|
related_efficacy_indicators = objects.EfficacyIndicator.list(
|
||||||
context=self._context,
|
context=self._context,
|
||||||
filters={"action_plan_uuid": self.uuid})
|
filters={"action_plan_uuid": self.uuid})
|
||||||
|
|
||||||
|
|||||||
@@ -52,9 +52,10 @@ class TestListAction(api_base.FunctionalTest):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestListAction, self).setUp()
|
super(TestListAction, self).setUp()
|
||||||
obj_utils.create_test_goal(self.context)
|
self.goal = obj_utils.create_test_goal(self.context)
|
||||||
obj_utils.create_test_strategy(self.context)
|
self.strategy = obj_utils.create_test_strategy(self.context)
|
||||||
obj_utils.create_test_action_plan(self.context)
|
self.audit = obj_utils.create_test_audit(self.context)
|
||||||
|
self.action_plan = obj_utils.create_test_action_plan(self.context)
|
||||||
|
|
||||||
def test_empty(self):
|
def test_empty(self):
|
||||||
response = self.get_json('/actions')
|
response = self.get_json('/actions')
|
||||||
@@ -155,12 +156,9 @@ class TestListAction(api_base.FunctionalTest):
|
|||||||
self.assertEqual(action_plan.uuid, action['action_plan_uuid'])
|
self.assertEqual(action_plan.uuid, action['action_plan_uuid'])
|
||||||
|
|
||||||
def test_filter_by_audit_uuid(self):
|
def test_filter_by_audit_uuid(self):
|
||||||
audit = obj_utils.create_test_audit(self.context,
|
|
||||||
uuid=utils.generate_uuid())
|
|
||||||
action_plan_1 = obj_utils.create_test_action_plan(
|
action_plan_1 = obj_utils.create_test_action_plan(
|
||||||
self.context,
|
self.context,
|
||||||
uuid=utils.generate_uuid(),
|
uuid=utils.generate_uuid())
|
||||||
audit_id=audit.id)
|
|
||||||
action_list = []
|
action_list = []
|
||||||
|
|
||||||
for id_ in range(3):
|
for id_ in range(3):
|
||||||
@@ -170,8 +168,8 @@ class TestListAction(api_base.FunctionalTest):
|
|||||||
uuid=utils.generate_uuid())
|
uuid=utils.generate_uuid())
|
||||||
action_list.append(action.uuid)
|
action_list.append(action.uuid)
|
||||||
|
|
||||||
audit2 = obj_utils.create_test_audit(self.context,
|
audit2 = obj_utils.create_test_audit(
|
||||||
uuid=utils.generate_uuid())
|
self.context, id=2, uuid=utils.generate_uuid())
|
||||||
action_plan_2 = obj_utils.create_test_action_plan(
|
action_plan_2 = obj_utils.create_test_action_plan(
|
||||||
self.context,
|
self.context,
|
||||||
uuid=utils.generate_uuid(),
|
uuid=utils.generate_uuid(),
|
||||||
@@ -183,18 +181,15 @@ class TestListAction(api_base.FunctionalTest):
|
|||||||
action_plan_id=action_plan_2.id,
|
action_plan_id=action_plan_2.id,
|
||||||
uuid=utils.generate_uuid())
|
uuid=utils.generate_uuid())
|
||||||
|
|
||||||
response = self.get_json('/actions?audit_uuid=%s' % audit.uuid)
|
response = self.get_json('/actions?audit_uuid=%s' % self.audit.uuid)
|
||||||
self.assertEqual(len(action_list), len(response['actions']))
|
self.assertEqual(len(action_list), len(response['actions']))
|
||||||
for action in response['actions']:
|
for action in response['actions']:
|
||||||
self.assertEqual(action_plan_1.uuid, action['action_plan_uuid'])
|
self.assertEqual(action_plan_1.uuid, action['action_plan_uuid'])
|
||||||
|
|
||||||
def test_filter_by_action_plan_uuid(self):
|
def test_filter_by_action_plan_uuid(self):
|
||||||
audit = obj_utils.create_test_audit(self.context,
|
|
||||||
uuid=utils.generate_uuid())
|
|
||||||
action_plan_1 = obj_utils.create_test_action_plan(
|
action_plan_1 = obj_utils.create_test_action_plan(
|
||||||
self.context,
|
self.context,
|
||||||
uuid=utils.generate_uuid(),
|
uuid=utils.generate_uuid())
|
||||||
audit_id=audit.id)
|
|
||||||
action_list = []
|
action_list = []
|
||||||
|
|
||||||
for id_ in range(3):
|
for id_ in range(3):
|
||||||
@@ -206,8 +201,7 @@ class TestListAction(api_base.FunctionalTest):
|
|||||||
|
|
||||||
action_plan_2 = obj_utils.create_test_action_plan(
|
action_plan_2 = obj_utils.create_test_action_plan(
|
||||||
self.context,
|
self.context,
|
||||||
uuid=utils.generate_uuid(),
|
uuid=utils.generate_uuid())
|
||||||
audit_id=audit.id)
|
|
||||||
|
|
||||||
for id_ in range(4, 5, 6):
|
for id_ in range(4, 5, 6):
|
||||||
obj_utils.create_test_action(
|
obj_utils.create_test_action(
|
||||||
@@ -432,6 +426,9 @@ class TestPatch(api_base.FunctionalTest):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestPatch, self).setUp()
|
super(TestPatch, self).setUp()
|
||||||
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
obj_utils.create_test_action_plan(self.context)
|
obj_utils.create_test_action_plan(self.context)
|
||||||
self.action = obj_utils.create_test_action(self.context, next=None)
|
self.action = obj_utils.create_test_action(self.context, next=None)
|
||||||
p = mock.patch.object(db_api.BaseConnection, 'update_action')
|
p = mock.patch.object(db_api.BaseConnection, 'update_action')
|
||||||
@@ -465,7 +462,9 @@ class TestDelete(api_base.FunctionalTest):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestDelete, self).setUp()
|
super(TestDelete, self).setUp()
|
||||||
obj_utils.create_test_action_plan(self.context)
|
self.goal = obj_utils.create_test_goal(self.context)
|
||||||
|
self.strategy = obj_utils.create_test_strategy(self.context)
|
||||||
|
self.audit = obj_utils.create_test_audit(self.context)
|
||||||
self.action = obj_utils.create_test_action(self.context, next=None)
|
self.action = obj_utils.create_test_action(self.context, next=None)
|
||||||
p = mock.patch.object(db_api.BaseConnection, 'update_action')
|
p = mock.patch.object(db_api.BaseConnection, 'update_action')
|
||||||
self.mock_action_update = p.start()
|
self.mock_action_update = p.start()
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ class TestListActionPlan(api_base.FunctionalTest):
|
|||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestListActionPlan, self).setUp()
|
super(TestListActionPlan, self).setUp()
|
||||||
obj_utils.create_test_goal(self.context)
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
obj_utils.create_test_audit(self.context)
|
obj_utils.create_test_audit(self.context)
|
||||||
|
|
||||||
def test_empty(self):
|
def test_empty(self):
|
||||||
@@ -292,6 +293,9 @@ class TestDelete(api_base.FunctionalTest):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestDelete, self).setUp()
|
super(TestDelete, self).setUp()
|
||||||
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
self.action_plan = obj_utils.create_test_action_plan(
|
self.action_plan = obj_utils.create_test_action_plan(
|
||||||
self.context)
|
self.context)
|
||||||
p = mock.patch.object(db_api.BaseConnection, 'destroy_action_plan')
|
p = mock.patch.object(db_api.BaseConnection, 'destroy_action_plan')
|
||||||
@@ -348,6 +352,9 @@ class TestPatch(api_base.FunctionalTest):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestPatch, self).setUp()
|
super(TestPatch, self).setUp()
|
||||||
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
self.action_plan = obj_utils.create_test_action_plan(
|
self.action_plan = obj_utils.create_test_action_plan(
|
||||||
self.context, state=objects.action_plan.State.RECOMMENDED)
|
self.context, state=objects.action_plan.State.RECOMMENDED)
|
||||||
p = mock.patch.object(db_api.BaseConnection, 'update_action_plan')
|
p = mock.patch.object(db_api.BaseConnection, 'update_action_plan')
|
||||||
@@ -487,6 +494,12 @@ class TestPatchStateTransitionDenied(api_base.FunctionalTest):
|
|||||||
"new_state": new_state} not in ALLOWED_TRANSITIONS
|
"new_state": new_state} not in ALLOWED_TRANSITIONS
|
||||||
]
|
]
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestPatchStateTransitionDenied, self).setUp()
|
||||||
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
|
|
||||||
@mock.patch.object(
|
@mock.patch.object(
|
||||||
db_api.BaseConnection, 'update_action_plan',
|
db_api.BaseConnection, 'update_action_plan',
|
||||||
mock.Mock(side_effect=lambda ap: ap.save() or ap))
|
mock.Mock(side_effect=lambda ap: ap.save() or ap))
|
||||||
@@ -520,6 +533,12 @@ class TestPatchStateTransitionOk(api_base.FunctionalTest):
|
|||||||
for transition in ALLOWED_TRANSITIONS
|
for transition in ALLOWED_TRANSITIONS
|
||||||
]
|
]
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestPatchStateTransitionOk, self).setUp()
|
||||||
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
|
|
||||||
@mock.patch.object(
|
@mock.patch.object(
|
||||||
db_api.BaseConnection, 'update_action_plan',
|
db_api.BaseConnection, 'update_action_plan',
|
||||||
mock.Mock(side_effect=lambda ap: ap.save() or ap))
|
mock.Mock(side_effect=lambda ap: ap.save() or ap))
|
||||||
@@ -543,6 +562,12 @@ class TestPatchStateTransitionOk(api_base.FunctionalTest):
|
|||||||
|
|
||||||
class TestActionPlanPolicyEnforcement(api_base.FunctionalTest):
|
class TestActionPlanPolicyEnforcement(api_base.FunctionalTest):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestActionPlanPolicyEnforcement, self).setUp()
|
||||||
|
obj_utils.create_test_goal(self.context)
|
||||||
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
|
|
||||||
def _common_policy_check(self, rule, func, *arg, **kwarg):
|
def _common_policy_check(self, rule, func, *arg, **kwarg):
|
||||||
self.policy.set_rules({
|
self.policy.set_rules({
|
||||||
"admin_api": "(role:admin or role:administrator)",
|
"admin_api": "(role:admin or role:administrator)",
|
||||||
|
|||||||
@@ -28,8 +28,10 @@ from watcher.tests.objects import utils as obj_utils
|
|||||||
class TestDefaultActionPlanHandler(base.DbTestCase):
|
class TestDefaultActionPlanHandler(base.DbTestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestDefaultActionPlanHandler, self).setUp()
|
super(TestDefaultActionPlanHandler, self).setUp()
|
||||||
self.action_plan = obj_utils.create_test_action_plan(
|
obj_utils.create_test_goal(self.context)
|
||||||
self.context)
|
obj_utils.create_test_strategy(self.context)
|
||||||
|
obj_utils.create_test_audit(self.context)
|
||||||
|
self.action_plan = obj_utils.create_test_action_plan(self.context)
|
||||||
|
|
||||||
def test_launch_action_plan(self):
|
def test_launch_action_plan(self):
|
||||||
command = default.DefaultActionPlanHandler(
|
command = default.DefaultActionPlanHandler(
|
||||||
|
|||||||
@@ -274,9 +274,9 @@ class TestPurgeCommand(base.DbTestCase):
|
|||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
uuid=utils.generate_uuid())
|
uuid=utils.generate_uuid())
|
||||||
action_plan4 = obj_utils.create_test_action_plan(
|
action_plan4 = obj_utils.create_test_action_plan(
|
||||||
self.context, audit_id=audit4.id,
|
self.context,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(), uuid=utils.generate_uuid(),
|
||||||
uuid=utils.generate_uuid())
|
audit_id=audit4.id, strategy_id=self.strategy1.id)
|
||||||
action4 = obj_utils.create_test_action(
|
action4 = obj_utils.create_test_action(
|
||||||
self.context, action_plan_id=action_plan4.id,
|
self.context, action_plan_id=action_plan4.id,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
@@ -292,9 +292,9 @@ class TestPurgeCommand(base.DbTestCase):
|
|||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
uuid=utils.generate_uuid())
|
uuid=utils.generate_uuid())
|
||||||
action_plan5 = obj_utils.create_test_action_plan(
|
action_plan5 = obj_utils.create_test_action_plan(
|
||||||
self.context, audit_id=audit5.id,
|
self.context,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(), uuid=utils.generate_uuid(),
|
||||||
uuid=utils.generate_uuid())
|
audit_id=audit5.id, strategy_id=self.strategy1.id)
|
||||||
action5 = obj_utils.create_test_action(
|
action5 = obj_utils.create_test_action(
|
||||||
self.context, action_plan_id=action_plan5.id,
|
self.context, action_plan_id=action_plan5.id,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
@@ -367,13 +367,13 @@ class TestPurgeCommand(base.DbTestCase):
|
|||||||
strategy_id=None, id=self._generate_id(),
|
strategy_id=None, id=self._generate_id(),
|
||||||
uuid=utils.generate_uuid())
|
uuid=utils.generate_uuid())
|
||||||
audit4 = obj_utils.create_test_audit(
|
audit4 = obj_utils.create_test_audit(
|
||||||
self.context, audit_template_id=audit_template4.id,
|
self.context,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(), uuid=utils.generate_uuid(),
|
||||||
uuid=utils.generate_uuid())
|
audit_template_id=audit_template4.id)
|
||||||
action_plan4 = obj_utils.create_test_action_plan(
|
action_plan4 = obj_utils.create_test_action_plan(
|
||||||
self.context, audit_id=audit4.id,
|
self.context,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(), uuid=utils.generate_uuid(),
|
||||||
uuid=utils.generate_uuid())
|
audit_id=audit4.id, strategy_id=self.strategy1.id)
|
||||||
action4 = obj_utils.create_test_action(
|
action4 = obj_utils.create_test_action(
|
||||||
self.context, action_plan_id=action_plan4.id,
|
self.context, action_plan_id=action_plan4.id,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
@@ -389,9 +389,9 @@ class TestPurgeCommand(base.DbTestCase):
|
|||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
uuid=utils.generate_uuid())
|
uuid=utils.generate_uuid())
|
||||||
action_plan5 = obj_utils.create_test_action_plan(
|
action_plan5 = obj_utils.create_test_action_plan(
|
||||||
self.context, audit_id=audit5.id,
|
self.context,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(), uuid=utils.generate_uuid(),
|
||||||
uuid=utils.generate_uuid())
|
audit_id=audit5.id, strategy_id=self.strategy1.id)
|
||||||
action5 = obj_utils.create_test_action(
|
action5 = obj_utils.create_test_action(
|
||||||
self.context, action_plan_id=action_plan5.id,
|
self.context, action_plan_id=action_plan5.id,
|
||||||
id=self._generate_id(),
|
id=self._generate_id(),
|
||||||
|
|||||||
@@ -137,7 +137,7 @@ def create_test_action(**kwargs):
|
|||||||
|
|
||||||
|
|
||||||
def get_test_action_plan(**kwargs):
|
def get_test_action_plan(**kwargs):
|
||||||
return {
|
action_plan_data = {
|
||||||
'id': kwargs.get('id', 1),
|
'id': kwargs.get('id', 1),
|
||||||
'uuid': kwargs.get('uuid', '76be87bd-3422-43f9-93a0-e85a577e3061'),
|
'uuid': kwargs.get('uuid', '76be87bd-3422-43f9-93a0-e85a577e3061'),
|
||||||
'state': kwargs.get('state', objects.action_plan.State.ONGOING),
|
'state': kwargs.get('state', objects.action_plan.State.ONGOING),
|
||||||
@@ -150,6 +150,15 @@ def get_test_action_plan(**kwargs):
|
|||||||
'deleted_at': kwargs.get('deleted_at'),
|
'deleted_at': kwargs.get('deleted_at'),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# ObjectField doesn't allow None nor dict, so if we want to simulate a
|
||||||
|
# non-eager object loading, the field should not be referenced at all.
|
||||||
|
if kwargs.get('audit'):
|
||||||
|
action_plan_data['audit'] = kwargs.get('audit')
|
||||||
|
if kwargs.get('strategy'):
|
||||||
|
action_plan_data['strategy'] = kwargs.get('strategy')
|
||||||
|
|
||||||
|
return action_plan_data
|
||||||
|
|
||||||
|
|
||||||
def create_test_action_plan(**kwargs):
|
def create_test_action_plan(**kwargs):
|
||||||
"""Create test action plan entry in DB and return Action Plan DB object.
|
"""Create test action plan entry in DB and return Action Plan DB object.
|
||||||
|
|||||||
@@ -14,158 +14,214 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
|
|
||||||
from watcher.common import exception
|
from watcher.common import exception
|
||||||
|
from watcher.db.sqlalchemy import api as db_api
|
||||||
from watcher import objects
|
from watcher import objects
|
||||||
from watcher.objects import action_plan as apobjects
|
|
||||||
from watcher.tests.db import base
|
from watcher.tests.db import base
|
||||||
from watcher.tests.db import utils
|
from watcher.tests.db import utils
|
||||||
|
|
||||||
|
|
||||||
class TestActionPlanObject(base.DbTestCase):
|
class TestActionPlanObject(base.DbTestCase):
|
||||||
|
|
||||||
|
audit_id = 2
|
||||||
|
strategy_id = 2
|
||||||
|
|
||||||
|
scenarios = [
|
||||||
|
('non_eager', dict(
|
||||||
|
eager=False,
|
||||||
|
fake_action_plan=utils.get_test_action_plan(
|
||||||
|
audit_id=audit_id,
|
||||||
|
strategy_id=strategy_id))),
|
||||||
|
('eager_with_non_eager_load', dict(
|
||||||
|
eager=True,
|
||||||
|
fake_action_plan=utils.get_test_action_plan(
|
||||||
|
audit_id=audit_id,
|
||||||
|
strategy_id=strategy_id))),
|
||||||
|
('eager_with_eager_load', dict(
|
||||||
|
eager=True,
|
||||||
|
fake_action_plan=utils.get_test_action_plan(
|
||||||
|
strategy_id=strategy_id,
|
||||||
|
strategy=utils.get_test_strategy(id=strategy_id),
|
||||||
|
audit_id=audit_id,
|
||||||
|
audit=utils.get_test_audit(id=audit_id)))),
|
||||||
|
]
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestActionPlanObject, self).setUp()
|
super(TestActionPlanObject, self).setUp()
|
||||||
self.fake_action_plan = utils.get_test_action_plan()
|
self.fake_audit = utils.create_test_audit(id=self.audit_id)
|
||||||
|
self.fake_strategy = utils.create_test_strategy(
|
||||||
|
id=self.strategy_id, name="DUMMY")
|
||||||
|
|
||||||
def test_get_by_id(self):
|
def eager_load_action_plan_assert(self, action_plan):
|
||||||
|
if self.eager:
|
||||||
|
self.assertIsNotNone(action_plan.audit)
|
||||||
|
fields_to_check = set(
|
||||||
|
super(objects.Audit, objects.Audit).fields
|
||||||
|
).symmetric_difference(objects.Audit.fields)
|
||||||
|
db_data = {
|
||||||
|
k: v for k, v in self.fake_audit.as_dict().items()
|
||||||
|
if k in fields_to_check}
|
||||||
|
object_data = {
|
||||||
|
k: v for k, v in action_plan.audit.as_dict().items()
|
||||||
|
if k in fields_to_check}
|
||||||
|
self.assertEqual(db_data, object_data)
|
||||||
|
|
||||||
|
@mock.patch.object(db_api.Connection, 'get_action_plan_by_id')
|
||||||
|
def test_get_by_id(self, mock_get_action_plan):
|
||||||
|
mock_get_action_plan.return_value = self.fake_action_plan
|
||||||
action_plan_id = self.fake_action_plan['id']
|
action_plan_id = self.fake_action_plan['id']
|
||||||
with mock.patch.object(self.dbapi, 'get_action_plan_by_id',
|
action_plan = objects.ActionPlan.get(
|
||||||
autospec=True) as mock_get_action_plan:
|
self.context, action_plan_id, eager=self.eager)
|
||||||
mock_get_action_plan.return_value = self.fake_action_plan
|
mock_get_action_plan.assert_called_once_with(
|
||||||
action_plan = objects.ActionPlan.get(self.context, action_plan_id)
|
self.context, action_plan_id, eager=self.eager)
|
||||||
mock_get_action_plan.assert_called_once_with(
|
self.assertEqual(self.context, action_plan._context)
|
||||||
self.context, action_plan_id)
|
self.eager_load_action_plan_assert(action_plan)
|
||||||
self.assertEqual(self.context, action_plan._context)
|
|
||||||
|
|
||||||
def test_get_by_uuid(self):
|
@mock.patch.object(db_api.Connection, 'get_action_plan_by_uuid')
|
||||||
|
def test_get_by_uuid(self, mock_get_action_plan):
|
||||||
|
mock_get_action_plan.return_value = self.fake_action_plan
|
||||||
uuid = self.fake_action_plan['uuid']
|
uuid = self.fake_action_plan['uuid']
|
||||||
with mock.patch.object(self.dbapi, 'get_action_plan_by_uuid',
|
action_plan = objects.ActionPlan.get(
|
||||||
autospec=True) as mock_get_action_plan:
|
self.context, uuid, eager=self.eager)
|
||||||
mock_get_action_plan.return_value = self.fake_action_plan
|
mock_get_action_plan.assert_called_once_with(
|
||||||
action_plan = objects.ActionPlan.get(self.context, uuid)
|
self.context, uuid, eager=self.eager)
|
||||||
mock_get_action_plan.assert_called_once_with(self.context, uuid)
|
self.assertEqual(self.context, action_plan._context)
|
||||||
self.assertEqual(self.context, action_plan._context)
|
self.eager_load_action_plan_assert(action_plan)
|
||||||
|
|
||||||
def test_get_bad_id_and_uuid(self):
|
def test_get_bad_id_and_uuid(self):
|
||||||
self.assertRaises(exception.InvalidIdentity,
|
self.assertRaises(exception.InvalidIdentity,
|
||||||
objects.ActionPlan.get, self.context, 'not-a-uuid')
|
objects.ActionPlan.get, self.context,
|
||||||
|
'not-a-uuid', eager=self.eager)
|
||||||
|
|
||||||
def test_list(self):
|
@mock.patch.object(db_api.Connection, 'get_action_plan_list')
|
||||||
with mock.patch.object(self.dbapi, 'get_action_plan_list',
|
def test_list(self, mock_get_list):
|
||||||
autospec=True) as mock_get_list:
|
mock_get_list.return_value = [self.fake_action_plan]
|
||||||
mock_get_list.return_value = [self.fake_action_plan]
|
action_plans = objects.ActionPlan.list(self.context, eager=self.eager)
|
||||||
action_plans = objects.ActionPlan.list(self.context)
|
self.assertEqual(1, mock_get_list.call_count)
|
||||||
self.assertEqual(1, mock_get_list.call_count)
|
self.assertEqual(1, len(action_plans))
|
||||||
self.assertEqual(1, len(action_plans))
|
self.assertIsInstance(action_plans[0], objects.ActionPlan)
|
||||||
self.assertIsInstance(action_plans[0], objects.ActionPlan)
|
self.assertEqual(self.context, action_plans[0]._context)
|
||||||
self.assertEqual(self.context, action_plans[0]._context)
|
for action_plan in action_plans:
|
||||||
|
self.eager_load_action_plan_assert(action_plan)
|
||||||
|
|
||||||
def test_create(self):
|
@mock.patch.object(db_api.Connection, 'update_action_plan')
|
||||||
with mock.patch.object(self.dbapi, 'create_action_plan',
|
@mock.patch.object(db_api.Connection, 'get_action_plan_by_uuid')
|
||||||
autospec=True) as mock_create_action_plan:
|
def test_save(self, mock_get_action_plan, mock_update_action_plan):
|
||||||
mock_create_action_plan.return_value = self.fake_action_plan
|
mock_get_action_plan.return_value = self.fake_action_plan
|
||||||
action_plan = objects.ActionPlan(
|
|
||||||
self.context, **self.fake_action_plan)
|
|
||||||
action_plan.create()
|
|
||||||
mock_create_action_plan.assert_called_once_with(
|
|
||||||
self.fake_action_plan)
|
|
||||||
self.assertEqual(self.context, action_plan._context)
|
|
||||||
|
|
||||||
def test_destroy(self):
|
|
||||||
efficacy_indicator = utils.get_test_efficacy_indicator(
|
|
||||||
action_plan_id=self.fake_action_plan['id'])
|
|
||||||
uuid = self.fake_action_plan['uuid']
|
uuid = self.fake_action_plan['uuid']
|
||||||
|
action_plan = objects.ActionPlan.get_by_uuid(
|
||||||
|
self.context, uuid, eager=self.eager)
|
||||||
|
action_plan.state = objects.action_plan.State.SUCCEEDED
|
||||||
|
action_plan.save()
|
||||||
|
|
||||||
with mock.patch.multiple(
|
mock_get_action_plan.assert_called_once_with(
|
||||||
self.dbapi, autospec=True,
|
self.context, uuid, eager=self.eager)
|
||||||
get_action_plan_by_uuid=mock.DEFAULT,
|
mock_update_action_plan.assert_called_once_with(
|
||||||
destroy_action_plan=mock.DEFAULT,
|
uuid, {'state': objects.action_plan.State.SUCCEEDED})
|
||||||
get_efficacy_indicator_list=mock.DEFAULT,
|
self.assertEqual(self.context, action_plan._context)
|
||||||
destroy_efficacy_indicator=mock.DEFAULT,
|
self.eager_load_action_plan_assert(action_plan)
|
||||||
) as m_dict:
|
|
||||||
m_get_action_plan = m_dict['get_action_plan_by_uuid']
|
|
||||||
m_destroy_action_plan = m_dict['destroy_action_plan']
|
|
||||||
m_get_efficacy_indicator_list = (
|
|
||||||
m_dict['get_efficacy_indicator_list'])
|
|
||||||
m_destroy_efficacy_indicator = m_dict['destroy_efficacy_indicator']
|
|
||||||
m_get_action_plan.return_value = self.fake_action_plan
|
|
||||||
m_get_efficacy_indicator_list.return_value = [efficacy_indicator]
|
|
||||||
action_plan = objects.ActionPlan.get_by_uuid(self.context, uuid)
|
|
||||||
action_plan.destroy()
|
|
||||||
m_get_action_plan.assert_called_once_with(self.context, uuid)
|
|
||||||
m_get_efficacy_indicator_list.assert_called_once_with(
|
|
||||||
self.context, filters={"action_plan_uuid": uuid},
|
|
||||||
limit=None, marker=None, sort_dir=None, sort_key=None)
|
|
||||||
m_destroy_action_plan.assert_called_once_with(uuid)
|
|
||||||
m_destroy_efficacy_indicator.assert_called_once_with(
|
|
||||||
efficacy_indicator['uuid'])
|
|
||||||
self.assertEqual(self.context, action_plan._context)
|
|
||||||
|
|
||||||
def test_soft_delete(self):
|
@mock.patch.object(db_api.Connection, 'get_action_plan_by_uuid')
|
||||||
efficacy_indicator = utils.get_test_efficacy_indicator(
|
def test_refresh(self, mock_get_action_plan):
|
||||||
action_plan_id=self.fake_action_plan['id'])
|
|
||||||
uuid = self.fake_action_plan['uuid']
|
|
||||||
|
|
||||||
with mock.patch.multiple(
|
|
||||||
self.dbapi, autospec=True,
|
|
||||||
get_action_plan_by_uuid=mock.DEFAULT,
|
|
||||||
soft_delete_action_plan=mock.DEFAULT,
|
|
||||||
update_action_plan=mock.DEFAULT,
|
|
||||||
get_efficacy_indicator_list=mock.DEFAULT,
|
|
||||||
soft_delete_efficacy_indicator=mock.DEFAULT,
|
|
||||||
) as m_dict:
|
|
||||||
m_get_action_plan = m_dict['get_action_plan_by_uuid']
|
|
||||||
m_soft_delete_action_plan = m_dict['soft_delete_action_plan']
|
|
||||||
m_get_efficacy_indicator_list = (
|
|
||||||
m_dict['get_efficacy_indicator_list'])
|
|
||||||
m_soft_delete_efficacy_indicator = (
|
|
||||||
m_dict['soft_delete_efficacy_indicator'])
|
|
||||||
m_update_action_plan = m_dict['update_action_plan']
|
|
||||||
m_get_action_plan.return_value = self.fake_action_plan
|
|
||||||
m_get_efficacy_indicator_list.return_value = [efficacy_indicator]
|
|
||||||
action_plan = objects.ActionPlan.get_by_uuid(self.context, uuid)
|
|
||||||
action_plan.soft_delete()
|
|
||||||
m_get_action_plan.assert_called_once_with(self.context, uuid)
|
|
||||||
m_get_efficacy_indicator_list.assert_called_once_with(
|
|
||||||
self.context, filters={"action_plan_uuid": uuid},
|
|
||||||
limit=None, marker=None, sort_dir=None, sort_key=None)
|
|
||||||
m_soft_delete_action_plan.assert_called_once_with(uuid)
|
|
||||||
m_soft_delete_efficacy_indicator.assert_called_once_with(
|
|
||||||
efficacy_indicator['uuid'])
|
|
||||||
m_update_action_plan.assert_called_once_with(
|
|
||||||
uuid, {'state': apobjects.State.DELETED})
|
|
||||||
self.assertEqual(self.context, action_plan._context)
|
|
||||||
|
|
||||||
def test_save(self):
|
|
||||||
uuid = self.fake_action_plan['uuid']
|
|
||||||
with mock.patch.object(self.dbapi, 'get_action_plan_by_uuid',
|
|
||||||
autospec=True) as mock_get_action_plan:
|
|
||||||
mock_get_action_plan.return_value = self.fake_action_plan
|
|
||||||
with mock.patch.object(self.dbapi, 'update_action_plan',
|
|
||||||
autospec=True) as mock_update_action_plan:
|
|
||||||
action_plan = objects.ActionPlan.get_by_uuid(
|
|
||||||
self.context, uuid)
|
|
||||||
action_plan.state = apobjects.State.SUCCEEDED
|
|
||||||
action_plan.save()
|
|
||||||
|
|
||||||
mock_get_action_plan.assert_called_once_with(
|
|
||||||
self.context, uuid)
|
|
||||||
mock_update_action_plan.assert_called_once_with(
|
|
||||||
uuid, {'state': apobjects.State.SUCCEEDED})
|
|
||||||
self.assertEqual(self.context, action_plan._context)
|
|
||||||
|
|
||||||
def test_refresh(self):
|
|
||||||
uuid = self.fake_action_plan['uuid']
|
|
||||||
returns = [dict(self.fake_action_plan, state="first state"),
|
returns = [dict(self.fake_action_plan, state="first state"),
|
||||||
dict(self.fake_action_plan, state="second state")]
|
dict(self.fake_action_plan, state="second state")]
|
||||||
expected = [mock.call(self.context, uuid),
|
mock_get_action_plan.side_effect = returns
|
||||||
mock.call(self.context, uuid)]
|
uuid = self.fake_action_plan['uuid']
|
||||||
with mock.patch.object(self.dbapi, 'get_action_plan_by_uuid',
|
expected = [mock.call(self.context, uuid, eager=self.eager),
|
||||||
side_effect=returns,
|
mock.call(self.context, uuid, eager=self.eager)]
|
||||||
autospec=True) as mock_get_action_plan:
|
action_plan = objects.ActionPlan.get(
|
||||||
action_plan = objects.ActionPlan.get(self.context, uuid)
|
self.context, uuid, eager=self.eager)
|
||||||
self.assertEqual("first state", action_plan.state)
|
self.assertEqual("first state", action_plan.state)
|
||||||
action_plan.refresh()
|
action_plan.refresh(eager=self.eager)
|
||||||
self.assertEqual("second state", action_plan.state)
|
self.assertEqual("second state", action_plan.state)
|
||||||
self.assertEqual(expected, mock_get_action_plan.call_args_list)
|
self.assertEqual(expected, mock_get_action_plan.call_args_list)
|
||||||
self.assertEqual(self.context, action_plan._context)
|
self.assertEqual(self.context, action_plan._context)
|
||||||
|
self.eager_load_action_plan_assert(action_plan)
|
||||||
|
|
||||||
|
|
||||||
|
class TestCreateDeleteActionPlanObject(base.DbTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestCreateDeleteActionPlanObject, self).setUp()
|
||||||
|
self.fake_strategy = utils.create_test_strategy(name="DUMMY")
|
||||||
|
self.fake_audit = utils.create_test_audit()
|
||||||
|
self.fake_action_plan = utils.get_test_action_plan()
|
||||||
|
|
||||||
|
@mock.patch.object(db_api.Connection, 'create_action_plan')
|
||||||
|
def test_create(self, mock_create_action_plan):
|
||||||
|
mock_create_action_plan.return_value = self.fake_action_plan
|
||||||
|
action_plan = objects.ActionPlan(
|
||||||
|
self.context, **self.fake_action_plan)
|
||||||
|
action_plan.create()
|
||||||
|
mock_create_action_plan.assert_called_once_with(
|
||||||
|
self.fake_action_plan)
|
||||||
|
self.assertEqual(self.context, action_plan._context)
|
||||||
|
|
||||||
|
@mock.patch.multiple(
|
||||||
|
db_api.Connection,
|
||||||
|
get_action_plan_by_uuid=mock.DEFAULT,
|
||||||
|
soft_delete_action_plan=mock.DEFAULT,
|
||||||
|
update_action_plan=mock.DEFAULT,
|
||||||
|
get_efficacy_indicator_list=mock.DEFAULT,
|
||||||
|
soft_delete_efficacy_indicator=mock.DEFAULT,
|
||||||
|
)
|
||||||
|
def test_soft_delete(self, get_action_plan_by_uuid,
|
||||||
|
soft_delete_action_plan, update_action_plan,
|
||||||
|
get_efficacy_indicator_list,
|
||||||
|
soft_delete_efficacy_indicator):
|
||||||
|
efficacy_indicator = utils.get_test_efficacy_indicator(
|
||||||
|
action_plan_id=self.fake_action_plan['id'])
|
||||||
|
uuid = self.fake_action_plan['uuid']
|
||||||
|
m_get_action_plan = get_action_plan_by_uuid
|
||||||
|
m_soft_delete_action_plan = soft_delete_action_plan
|
||||||
|
m_get_efficacy_indicator_list = get_efficacy_indicator_list
|
||||||
|
m_soft_delete_efficacy_indicator = soft_delete_efficacy_indicator
|
||||||
|
m_update_action_plan = update_action_plan
|
||||||
|
m_get_action_plan.return_value = self.fake_action_plan
|
||||||
|
m_get_efficacy_indicator_list.return_value = [efficacy_indicator]
|
||||||
|
action_plan = objects.ActionPlan.get_by_uuid(self.context, uuid)
|
||||||
|
action_plan.soft_delete()
|
||||||
|
|
||||||
|
m_get_action_plan.assert_called_once_with(
|
||||||
|
self.context, uuid, eager=False)
|
||||||
|
m_get_efficacy_indicator_list.assert_called_once_with(
|
||||||
|
self.context, filters={"action_plan_uuid": uuid},
|
||||||
|
limit=None, marker=None, sort_dir=None, sort_key=None)
|
||||||
|
m_soft_delete_action_plan.assert_called_once_with(uuid)
|
||||||
|
m_soft_delete_efficacy_indicator.assert_called_once_with(
|
||||||
|
efficacy_indicator['uuid'])
|
||||||
|
m_update_action_plan.assert_called_once_with(
|
||||||
|
uuid, {'state': objects.action_plan.State.DELETED})
|
||||||
|
self.assertEqual(self.context, action_plan._context)
|
||||||
|
|
||||||
|
@mock.patch.multiple(
|
||||||
|
db_api.Connection,
|
||||||
|
get_action_plan_by_uuid=mock.DEFAULT,
|
||||||
|
destroy_action_plan=mock.DEFAULT,
|
||||||
|
get_efficacy_indicator_list=mock.DEFAULT,
|
||||||
|
destroy_efficacy_indicator=mock.DEFAULT,
|
||||||
|
)
|
||||||
|
def test_destroy(self, get_action_plan_by_uuid, destroy_action_plan,
|
||||||
|
get_efficacy_indicator_list, destroy_efficacy_indicator):
|
||||||
|
m_get_action_plan = get_action_plan_by_uuid
|
||||||
|
m_destroy_action_plan = destroy_action_plan
|
||||||
|
m_get_efficacy_indicator_list = get_efficacy_indicator_list
|
||||||
|
m_destroy_efficacy_indicator = destroy_efficacy_indicator
|
||||||
|
efficacy_indicator = utils.get_test_efficacy_indicator(
|
||||||
|
action_plan_id=self.fake_action_plan['id'])
|
||||||
|
uuid = self.fake_action_plan['uuid']
|
||||||
|
m_get_action_plan.return_value = self.fake_action_plan
|
||||||
|
m_get_efficacy_indicator_list.return_value = [efficacy_indicator]
|
||||||
|
action_plan = objects.ActionPlan.get_by_uuid(self.context, uuid)
|
||||||
|
action_plan.destroy()
|
||||||
|
|
||||||
|
m_get_action_plan.assert_called_once_with(
|
||||||
|
self.context, uuid, eager=False)
|
||||||
|
m_get_efficacy_indicator_list.assert_called_once_with(
|
||||||
|
self.context, filters={"action_plan_uuid": uuid},
|
||||||
|
limit=None, marker=None, sort_dir=None, sort_key=None)
|
||||||
|
m_destroy_action_plan.assert_called_once_with(uuid)
|
||||||
|
m_destroy_efficacy_indicator.assert_called_once_with(
|
||||||
|
efficacy_indicator['uuid'])
|
||||||
|
self.assertEqual(self.context, action_plan._context)
|
||||||
|
|||||||
@@ -413,7 +413,7 @@ expected_object_fingerprints = {
|
|||||||
'Strategy': '1.1-73f164491bdd4c034f48083a51bdeb7b',
|
'Strategy': '1.1-73f164491bdd4c034f48083a51bdeb7b',
|
||||||
'AuditTemplate': '1.1-b291973ffc5efa2c61b24fe34fdccc0b',
|
'AuditTemplate': '1.1-b291973ffc5efa2c61b24fe34fdccc0b',
|
||||||
'Audit': '1.1-dc246337c8d511646cb537144fcb0f3a',
|
'Audit': '1.1-dc246337c8d511646cb537144fcb0f3a',
|
||||||
'ActionPlan': '1.0-cc76fd7f0e8479aeff817dd266341de4',
|
'ActionPlan': '1.1-299bd9c76f2402a0b2167f8e4d744a05',
|
||||||
'Action': '1.0-a78f69c0da98e13e601f9646f6b2f883',
|
'Action': '1.0-a78f69c0da98e13e601f9646f6b2f883',
|
||||||
'EfficacyIndicator': '1.0-655b71234a82bc7478aff964639c4bb0',
|
'EfficacyIndicator': '1.0-655b71234a82bc7478aff964639c4bb0',
|
||||||
'ScoringEngine': '1.0-4abbe833544000728e17bd9e83f97576',
|
'ScoringEngine': '1.0-4abbe833544000728e17bd9e83f97576',
|
||||||
|
|||||||
Reference in New Issue
Block a user