Tempest tests for v3 template
Story: 2004871 Task: 29129 Change-Id: Ica592866ca79afec4730955395e10316b7373ce9
This commit is contained in:
parent
aca285b10c
commit
dcde8a970e
vitrage_tempest_plugin/tests
e2e
notifiers
resources/templates/api
@ -36,36 +36,66 @@ TRIGGER_ALARM_4 = 'e2e.test_basic_actions.trigger.alarm4'
|
||||
TRIGGER_ALARM_5 = 'e2e.test_basic_actions.trigger.alarm5'
|
||||
DEDUCED = 'e2e.test_basic_actions.deduced.alarm'
|
||||
|
||||
TRIGGER_ALARM_1_V3 = 'e2e.test_basic_actions.trigger.alarm1.v3'
|
||||
TRIGGER_ALARM_2_V3 = 'e2e.test_basic_actions.trigger.alarm2.v3'
|
||||
TRIGGER_ALARM_3_V3 = 'e2e.test_basic_actions.trigger.alarm3.v3'
|
||||
TRIGGER_ALARM_4_V3 = 'e2e.test_basic_actions.trigger.alarm4.v3'
|
||||
TRIGGER_ALARM_5_V3 = 'e2e.test_basic_actions.trigger.alarm5.v3'
|
||||
DEDUCED_V3 = 'e2e.test_basic_actions.deduced.alarm.v3'
|
||||
|
||||
TRIGGER_ALARM_2_PROPS = {
|
||||
VProps.NAME: TRIGGER_ALARM_2,
|
||||
VProps.VITRAGE_CATEGORY: EntityCategory.ALARM,
|
||||
VProps.VITRAGE_TYPE: DOCTOR_DATASOURCE,
|
||||
}
|
||||
|
||||
TRIGGER_ALARM_2_PROPS_V3 = {
|
||||
VProps.NAME: TRIGGER_ALARM_2_V3,
|
||||
VProps.VITRAGE_CATEGORY: EntityCategory.ALARM,
|
||||
VProps.VITRAGE_TYPE: DOCTOR_DATASOURCE,
|
||||
}
|
||||
|
||||
DEDUCED_PROPS = {
|
||||
VProps.NAME: DEDUCED,
|
||||
VProps.VITRAGE_CATEGORY: EntityCategory.ALARM,
|
||||
VProps.VITRAGE_TYPE: VITRAGE_DATASOURCE,
|
||||
}
|
||||
|
||||
DEDUCED_PROPS_V3 = {
|
||||
VProps.NAME: DEDUCED_V3,
|
||||
VProps.VITRAGE_CATEGORY: EntityCategory.ALARM,
|
||||
VProps.VITRAGE_TYPE: VITRAGE_DATASOURCE,
|
||||
}
|
||||
|
||||
|
||||
class TestBasicActions(TestActionsBase):
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
super(TestBasicActions, cls).setUpClass()
|
||||
cls._template = v_utils.add_template("e2e_test_basic_actions.yaml")
|
||||
cls._templates = []
|
||||
cls._templates.append(
|
||||
v_utils.add_template("e2e_test_basic_actions.yaml"))
|
||||
cls._templates.append(
|
||||
v_utils.add_template("e2e_test_basic_actions_v3.yaml"))
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
if cls._template is not None:
|
||||
v_utils.delete_template(cls._template['uuid'])
|
||||
for t in cls._templates:
|
||||
v_utils.delete_template(t['uuid'])
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_set_state_host(self):
|
||||
self._do_test_action_set_state_host(TRIGGER_ALARM_1)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_set_state_host_v3(self):
|
||||
self._do_test_action_set_state_host(TRIGGER_ALARM_1_V3)
|
||||
|
||||
def _do_test_action_set_state_host(self, trigger):
|
||||
try:
|
||||
|
||||
# Do
|
||||
self._trigger_do_action(TRIGGER_ALARM_1)
|
||||
self._trigger_do_action(trigger)
|
||||
curr_host = v_utils.get_first_host()
|
||||
self.assertEqual(
|
||||
'ERROR',
|
||||
@ -73,7 +103,7 @@ class TestBasicActions(TestActionsBase):
|
||||
'state should change after set_state action')
|
||||
|
||||
# Undo
|
||||
self._trigger_undo_action(TRIGGER_ALARM_1)
|
||||
self._trigger_undo_action(trigger)
|
||||
curr_host = v_utils.get_first_host()
|
||||
self.assertEqual(
|
||||
self.orig_host.get(VProps.VITRAGE_AGGREGATED_STATE),
|
||||
@ -83,10 +113,17 @@ class TestBasicActions(TestActionsBase):
|
||||
self._handle_exception(e)
|
||||
raise
|
||||
finally:
|
||||
self._trigger_undo_action(TRIGGER_ALARM_1)
|
||||
self._trigger_undo_action(trigger)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_set_state_instance(self):
|
||||
self._do_test_action_set_state_instance(TRIGGER_ALARM_3)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_set_state_instance_v3(self):
|
||||
self._do_test_action_set_state_instance(TRIGGER_ALARM_3_V3)
|
||||
|
||||
def _do_test_action_set_state_instance(self, trigger):
|
||||
|
||||
vm_id = ""
|
||||
try:
|
||||
@ -94,7 +131,7 @@ class TestBasicActions(TestActionsBase):
|
||||
|
||||
# Do
|
||||
orig_instance = v_utils.get_first_instance(id=vm_id)
|
||||
self._trigger_do_action(TRIGGER_ALARM_3)
|
||||
self._trigger_do_action(trigger)
|
||||
curr_instance = v_utils.get_first_instance(id=vm_id)
|
||||
self.assertEqual(
|
||||
'ERROR',
|
||||
@ -102,7 +139,7 @@ class TestBasicActions(TestActionsBase):
|
||||
'state should change after set_state action')
|
||||
|
||||
# Undo
|
||||
self._trigger_undo_action(TRIGGER_ALARM_3)
|
||||
self._trigger_undo_action(trigger)
|
||||
curr_instance = v_utils.get_first_instance(id=vm_id)
|
||||
self.assertEqual(
|
||||
orig_instance.get(VProps.VITRAGE_AGGREGATED_STATE),
|
||||
@ -112,22 +149,29 @@ class TestBasicActions(TestActionsBase):
|
||||
self._handle_exception(e)
|
||||
raise
|
||||
finally:
|
||||
self._trigger_undo_action(TRIGGER_ALARM_3)
|
||||
self._trigger_undo_action(trigger)
|
||||
nova_utils.delete_all_instances(id=vm_id)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_mark_down_host(self):
|
||||
self._do_test_action_mark_down_host(TRIGGER_ALARM_4)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_mark_down_host_v3(self):
|
||||
self._do_test_action_mark_down_host(TRIGGER_ALARM_4_V3)
|
||||
|
||||
def _do_test_action_mark_down_host(self, trigger):
|
||||
try:
|
||||
host_name = self.orig_host.get(VProps.NAME)
|
||||
|
||||
# Do
|
||||
self._trigger_do_action(TRIGGER_ALARM_4)
|
||||
self._trigger_do_action(trigger)
|
||||
nova_service = TempestClients.nova().services.list(
|
||||
host=host_name, binary='nova-compute')[0]
|
||||
self.assertEqual("down", str(nova_service.state))
|
||||
|
||||
# Undo
|
||||
self._trigger_undo_action(TRIGGER_ALARM_4)
|
||||
self._trigger_undo_action(trigger)
|
||||
nova_service = TempestClients.nova().services.list(
|
||||
host=host_name, binary='nova-compute')[0]
|
||||
self.assertEqual("up", str(nova_service.state))
|
||||
@ -135,22 +179,29 @@ class TestBasicActions(TestActionsBase):
|
||||
self._handle_exception(e)
|
||||
raise
|
||||
finally:
|
||||
self._trigger_undo_action(TRIGGER_ALARM_4)
|
||||
self._trigger_undo_action(trigger)
|
||||
# nova.host datasource may take up to snapshot_intreval to update
|
||||
time.sleep(130)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_mark_down_instance(self):
|
||||
self._do_test_action_mark_down_instance(TRIGGER_ALARM_5)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_mark_down_instance_v3(self):
|
||||
self._do_test_action_mark_down_instance(TRIGGER_ALARM_5_V3)
|
||||
|
||||
def _do_test_action_mark_down_instance(self, trigger):
|
||||
vm_id = ""
|
||||
try:
|
||||
vm_id = nova_utils.create_instances(set_public_network=True)[0].id
|
||||
# Do
|
||||
self._trigger_do_action(TRIGGER_ALARM_5)
|
||||
self._trigger_do_action(trigger)
|
||||
nova_instance = TempestClients.nova().servers.get(vm_id)
|
||||
self.assertEqual("ERROR", str(nova_instance.status))
|
||||
|
||||
# Undo
|
||||
self._trigger_undo_action(TRIGGER_ALARM_5)
|
||||
self._trigger_undo_action(trigger)
|
||||
nova_instance = TempestClients.nova().servers.get(vm_id)
|
||||
self.assertEqual("ACTIVE", str(nova_instance.status))
|
||||
except Exception as e:
|
||||
@ -158,51 +209,72 @@ class TestBasicActions(TestActionsBase):
|
||||
raise
|
||||
finally:
|
||||
pass
|
||||
self._trigger_undo_action(TRIGGER_ALARM_5)
|
||||
self._trigger_undo_action(trigger)
|
||||
nova_utils.delete_all_instances(id=vm_id)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_deduce_alarm(self):
|
||||
self._do_test_action_deduce_alarm(TRIGGER_ALARM_2, DEDUCED_PROPS)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_deduce_alarm_v3(self):
|
||||
self._do_test_action_deduce_alarm(TRIGGER_ALARM_2_V3, DEDUCED_PROPS_V3)
|
||||
|
||||
def _do_test_action_deduce_alarm(self, trigger, deduced_props):
|
||||
try:
|
||||
host_id = self.orig_host.get(VProps.VITRAGE_ID)
|
||||
|
||||
# Do
|
||||
self._trigger_do_action(TRIGGER_ALARM_2)
|
||||
self._check_deduced(1, DEDUCED_PROPS, host_id)
|
||||
self._trigger_do_action(trigger)
|
||||
self._check_deduced(1, deduced_props, host_id)
|
||||
|
||||
# Undo
|
||||
self._trigger_undo_action(TRIGGER_ALARM_2)
|
||||
self._check_deduced(0, DEDUCED_PROPS, host_id)
|
||||
self._trigger_undo_action(trigger)
|
||||
self._check_deduced(0, deduced_props, host_id)
|
||||
except Exception as e:
|
||||
self._handle_exception(e)
|
||||
raise
|
||||
finally:
|
||||
self._trigger_undo_action(TRIGGER_ALARM_2)
|
||||
self._trigger_undo_action(trigger)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_add_causal_relationship(self):
|
||||
self._do_test_action_add_causal_relationship(TRIGGER_ALARM_2,
|
||||
DEDUCED_PROPS,
|
||||
TRIGGER_ALARM_2_PROPS)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_action_add_causal_relationship_v3(self):
|
||||
self._do_test_action_add_causal_relationship(TRIGGER_ALARM_2_V3,
|
||||
DEDUCED_PROPS_V3,
|
||||
TRIGGER_ALARM_2_PROPS_V3)
|
||||
|
||||
def _do_test_action_add_causal_relationship(self,
|
||||
trigger,
|
||||
deduced_props,
|
||||
trigger_alarm_props):
|
||||
try:
|
||||
# Do
|
||||
self._trigger_do_action(TRIGGER_ALARM_2)
|
||||
self._trigger_do_action(trigger)
|
||||
alarms = TempestClients.vitrage().alarm.list(
|
||||
vitrage_id=self.orig_host.get(VProps.VITRAGE_ID),
|
||||
all_tenants=True)
|
||||
self.assertTrue(len(alarms) >= 2, 'alarms %s' % str(alarms))
|
||||
|
||||
deduced = g_utils.first_match(alarms, **DEDUCED_PROPS)
|
||||
trigger = g_utils.first_match(alarms, **TRIGGER_ALARM_2_PROPS)
|
||||
deduced = g_utils.first_match(alarms, **deduced_props)
|
||||
trigger = g_utils.first_match(alarms, **trigger_alarm_props)
|
||||
|
||||
# Get Rca for the deduced
|
||||
rca = TempestClients.vitrage().rca.get(
|
||||
deduced[VProps.VITRAGE_ID], all_tenants=True)
|
||||
self._check_rca(rca, [deduced, trigger], DEDUCED_PROPS)
|
||||
self._check_rca(rca, [deduced, trigger], deduced_props)
|
||||
|
||||
# Get Rca for the trigger
|
||||
rca = TempestClients.vitrage().rca.get(
|
||||
trigger[VProps.VITRAGE_ID], all_tenants=True)
|
||||
self._check_rca(rca, [deduced, trigger], TRIGGER_ALARM_2_PROPS)
|
||||
self._check_rca(rca, [deduced, trigger], trigger_alarm_props)
|
||||
except Exception as e:
|
||||
self._handle_exception(e)
|
||||
raise
|
||||
finally:
|
||||
self._trigger_undo_action(TRIGGER_ALARM_2)
|
||||
self._trigger_undo_action(trigger)
|
||||
|
@ -47,7 +47,10 @@ class TestMistralNotifier(BaseTestEvents):
|
||||
|
||||
TRIGGER_ALARM_1 = "notifiers.mistral.trigger.alarm.1"
|
||||
TRIGGER_ALARM_2 = "notifiers.mistral.trigger.alarm.2"
|
||||
TRIGGER_ALARM_3 = "notifiers.mistral.trigger.alarm.3"
|
||||
TRIGGER_ALARM_FOR_FUNCTION = "notifiers.mistral.trigger.alarm.for.function"
|
||||
TRIGGER_ALARM_FOR_FUNCTION_v3 = \
|
||||
"notifiers.mistral.trigger.alarm.for.function.v3"
|
||||
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
@ -56,12 +59,14 @@ class TestMistralNotifier(BaseTestEvents):
|
||||
cls._templates = []
|
||||
cls._templates.append(v_utils.add_template('v1_execute_mistral.yaml'))
|
||||
cls._templates.append(v_utils.add_template('v2_execute_mistral.yaml'))
|
||||
cls._templates.append(v_utils.add_template('v3_execute_mistral.yaml'))
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
if cls._templates is not None:
|
||||
v_utils.delete_template(cls._templates[0]['uuid'])
|
||||
v_utils.delete_template(cls._templates[1]['uuid'])
|
||||
v_utils.delete_template(cls._templates[2]['uuid'])
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_execute_mistral_v1(self):
|
||||
@ -72,32 +77,39 @@ class TestMistralNotifier(BaseTestEvents):
|
||||
self._do_test_execute_mistral(self.TRIGGER_ALARM_2)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_execute_mistral_with_function(self):
|
||||
def test_execute_mistral_v3(self):
|
||||
self._do_test_execute_mistral(self.TRIGGER_ALARM_3)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_execute_mistral_with_function_v2(self):
|
||||
# Execute the basic test
|
||||
self._do_test_execute_mistral(self.TRIGGER_ALARM_FOR_FUNCTION)
|
||||
self._do_test_function(self.TRIGGER_ALARM_FOR_FUNCTION)
|
||||
|
||||
@utils.tempest_logger
|
||||
def test_execute_mistral_with_function_v3(self):
|
||||
# Execute the basic test
|
||||
self._do_test_execute_mistral(self.TRIGGER_ALARM_FOR_FUNCTION_v3)
|
||||
self._do_test_function(self.TRIGGER_ALARM_FOR_FUNCTION_v3)
|
||||
|
||||
def _do_test_function(self, trigger):
|
||||
# Make sure that the workflow execution was done with the correct input
|
||||
# (can be checked even if the Vitrage alarm is already down)
|
||||
executions = self.mistral_client.executions.list()
|
||||
|
||||
last_execution = executions[0]
|
||||
for execution in executions:
|
||||
if execution.updated_at > last_execution.updated_at:
|
||||
last_execution = execution
|
||||
|
||||
execution_input_str = last_execution.input
|
||||
self.assertIsNotNone(execution_input_str,
|
||||
'The last execution had no input')
|
||||
self.assertIn('farewell', execution_input_str,
|
||||
'No \'farewell\' key in the last execution input')
|
||||
|
||||
execution_input = json.loads(execution_input_str)
|
||||
|
||||
farewell_value = execution_input['farewell']
|
||||
self.assertIsNotNone(farewell_value, '\'farewell\' input parameter is '
|
||||
'None in last workflow execution')
|
||||
|
||||
self.assertEqual(self.TRIGGER_ALARM_FOR_FUNCTION, farewell_value,
|
||||
self.assertEqual(trigger, farewell_value,
|
||||
'\'farewell\' input parameter does not match the'
|
||||
'alarm name')
|
||||
|
||||
|
@ -0,0 +1,54 @@
|
||||
metadata:
|
||||
version: 3
|
||||
name: e2e_test_basic_actions v3
|
||||
description: this template includes vitrage basic actions
|
||||
type: standard
|
||||
entities:
|
||||
trigger_alarm_1:
|
||||
name: e2e.test_basic_actions.trigger.alarm1.v3
|
||||
trigger_alarm_2:
|
||||
name: e2e.test_basic_actions.trigger.alarm2.v3
|
||||
trigger_alarm_3:
|
||||
name: e2e.test_basic_actions.trigger.alarm3.v3
|
||||
trigger_alarm_4:
|
||||
name: e2e.test_basic_actions.trigger.alarm4.v3
|
||||
trigger_alarm_5:
|
||||
name: e2e.test_basic_actions.trigger.alarm5.v3
|
||||
deduced_alarm:
|
||||
name: e2e.test_basic_actions.deduced.alarm.v3
|
||||
type: vitrage
|
||||
host:
|
||||
type: nova.host
|
||||
instance:
|
||||
type: nova.instance
|
||||
scenarios:
|
||||
- condition: trigger_alarm_1 [ on ] host
|
||||
actions:
|
||||
- set_state:
|
||||
state: ERROR
|
||||
target: host
|
||||
- condition: trigger_alarm_4 [ on ] host
|
||||
actions:
|
||||
- mark_down:
|
||||
target: host
|
||||
- condition: trigger_alarm_2 [ on ] host
|
||||
actions:
|
||||
- raise_alarm:
|
||||
target: host
|
||||
alarm_name: e2e.test_basic_actions.deduced.alarm.v3
|
||||
severity: WARNING
|
||||
# causing_alarm: trigger_alarm_2
|
||||
- condition: trigger_alarm_2 [ on ] host AND deduced_alarm [on] host
|
||||
actions:
|
||||
- add_causal_relationship:
|
||||
source: trigger_alarm_2
|
||||
target: deduced_alarm
|
||||
- condition: trigger_alarm_3 [ on ] host AND host [ contains ] instance
|
||||
actions:
|
||||
- set_state:
|
||||
state: ERROR
|
||||
target: instance
|
||||
- condition: trigger_alarm_5 [ on ] host AND host [ contains ] instance
|
||||
actions:
|
||||
- mark_down:
|
||||
target: instance
|
@ -0,0 +1,25 @@
|
||||
metadata:
|
||||
version: 3
|
||||
name: v3_execute_mistral
|
||||
description: execute mistral
|
||||
type: standard
|
||||
entities:
|
||||
alarm_3:
|
||||
name: notifiers.mistral.trigger.alarm.3
|
||||
alarm_for_func:
|
||||
name: notifiers.mistral.trigger.alarm.for.function.v3
|
||||
host:
|
||||
type: nova.host
|
||||
scenarios:
|
||||
- condition: alarm_3 [on] host
|
||||
actions:
|
||||
- execute_mistral:
|
||||
workflow: wf_for_tempest_test_1234
|
||||
input:
|
||||
farewell: Hello and Goodbye
|
||||
- condition: alarm_for_func [on] host
|
||||
actions:
|
||||
- execute_mistral:
|
||||
workflow: wf_for_tempest_test_1234
|
||||
input:
|
||||
farewell: get_attr(alarm_for_func,name)
|
Loading…
x
Reference in New Issue
Block a user