aboutsummaryrefslogtreecommitdiffstats
path: root/app/test/event_based_scan/test_event_delete_base.py
diff options
context:
space:
mode:
Diffstat (limited to 'app/test/event_based_scan/test_event_delete_base.py')
-rw-r--r--app/test/event_based_scan/test_event_delete_base.py66
1 files changed, 30 insertions, 36 deletions
diff --git a/app/test/event_based_scan/test_event_delete_base.py b/app/test/event_based_scan/test_event_delete_base.py
index 1ccabb3..a470d7d 100644
--- a/app/test/event_based_scan/test_event_delete_base.py
+++ b/app/test/event_based_scan/test_event_delete_base.py
@@ -7,9 +7,11 @@
# which accompanies this distribution, and is available at #
# http://www.apache.org/licenses/LICENSE-2.0 #
###############################################################################
+from unittest.mock import patch, call
+
+import re
from bson import ObjectId
-from discover.clique_finder import CliqueFinder
from discover.events.event_base import EventBase
from test.event_based_scan.test_event import TestEvent
@@ -20,45 +22,37 @@ class TestEventDeleteBase(TestEvent):
super().setUp()
self.values = {}
- def set_item_for_deletion(self, object_type, document):
-
- payload = self.values['payload']
- self.item_id = payload['{}_id'.format(object_type)]
- if object_type == 'router':
- host_id = self.values['publisher_id'].replace("network.", "", 1)
- self.item_id = "-".join([host_id, "qrouter", self.item_id])
-
- self.assertEqual(document['id'], self.item_id, msg="Document id and payload id are different")
-
- item = self.inv.get_by_id(self.env, self.item_id)
- if not item:
- self.log.info('{} document is not found, add document for deleting.'.format(object_type))
+ self.cf = patch("discover.events.event_delete_base.CliqueFinder")
+ self.clique_finder = self.cf.start().return_value
+ self.clique_finder.find_links_by_source.return_value = []
+ self.clique_finder.find_links_by_target.return_value = []
- # add network document for deleting.
- self.set_item(document)
- item = self.inv.get_by_id(self.env, self.item_id)
- self.assertIsNotNone(item)
+ def handle_delete(self, handler: EventBase, db_object: dict):
+ with patch("discover.events.event_delete_base.CliqueFinder") as cf:
+ self.inv.get_by_id.return_value = db_object
- def handle_delete(self, handler: EventBase):
+ event_result = handler.handle(self.env, self.values)
+ self.assertTrue(event_result.result)
- item = self.inv.get_by_id(self.env, self.item_id)
- db_id = ObjectId(item['_id'])
- clique_finder = CliqueFinder()
+ self.check_inv_calls(db_object)
- # delete item
- event_result = handler.handle(self.env, self.values)
- self.assertTrue(event_result.result)
+ def check_inv_calls(self, db_object):
+ db_id = ObjectId(db_object['_id'])
+ id_path_regex = re.compile('^{}/'.format(db_object['id_path']))
- # check instance delete result.
- item = self.inv.get_by_id(self.env, self.item_id)
- self.assertIsNone(item)
+ delete_clique = call('cliques', {'focal_point': db_id})
+ delete_source_links = call('links', {'source': db_id})
+ delete_target_links = call('links', {'target': db_id})
+ delete_object = call('inventory', {'_id': db_id})
+ delete_id_path = call('inventory', {'id_path':
+ {'$regex': id_path_regex}})
- # check links
- matched_links_source = clique_finder.find_links_by_source(db_id)
- matched_links_target = clique_finder.find_links_by_target(db_id)
- self.assertEqual(matched_links_source.count(), 0)
- self.assertEqual(matched_links_target.count(), 0)
+ self.inv.delete.assert_has_calls([delete_clique,
+ delete_source_links,
+ delete_target_links,
+ delete_object,
+ delete_id_path])
- # check children
- matched_children = self.inv.get_children(self.env, None, self.item_id)
- self.assertEqual(len(matched_children), 0)
+ def tearDown(self):
+ super().tearDown()
+ self.cf.stop() \ No newline at end of file