058302cf4b
oslo cache 1.31.1 was excluded by requirements https://review.openstack.org/#/c/615935/ we now can test again gnocchi Change-Id: I78b9d21c0a61833967810cd98c2026f69e8f00f6
177 lines
7.0 KiB
Python
177 lines
7.0 KiB
Python
# Copyright 2016 - Nokia
|
|
#
|
|
# 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 oslo_log import log as logging
|
|
from vitrage_tempest_plugin.tests import utils
|
|
|
|
from vitrage_tempest_plugin.tests.api.alarms.base import BaseAlarmsTest
|
|
from vitrage_tempest_plugin.tests.common import aodh_utils
|
|
from vitrage_tempest_plugin.tests.common import nova_utils
|
|
from vitrage_tempest_plugin.tests.common.tempest_clients import TempestClients
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class TestAodhAlarm(BaseAlarmsTest):
|
|
NUM_INSTANCE = 1
|
|
NUM_ALARM = 1
|
|
|
|
def setUp(self):
|
|
super(TestAodhAlarm, self).setUp()
|
|
|
|
def tearDown(self):
|
|
super(TestAodhAlarm, self).tearDown()
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
super(TestAodhAlarm, cls).setUpClass()
|
|
|
|
@utils.tempest_logger
|
|
def test_alarm_with_resource_id(self):
|
|
try:
|
|
# Action
|
|
nova_utils.create_instances(num_instances=self.NUM_INSTANCE)
|
|
aodh_utils.create_aodh_alarm(self._find_instance_resource_id())
|
|
# Calculate expected results
|
|
api_graph = self.vitrage_client.topology.get(all_tenants=True)
|
|
graph = self._create_graph_from_graph_dictionary(api_graph)
|
|
entities = self._entities_validation_data(
|
|
host_entities=1,
|
|
host_edges=1 + self.NUM_INSTANCE,
|
|
instance_entities=self.NUM_INSTANCE,
|
|
instance_edges=2 * self.NUM_INSTANCE + self.NUM_ALARM,
|
|
aodh_entities=self.NUM_ALARM,
|
|
aodh_edges=self.NUM_ALARM)
|
|
num_entities = self.num_default_entities + \
|
|
2 * self.NUM_INSTANCE + self.NUM_ALARM + \
|
|
self.num_default_networks + self.num_default_ports
|
|
num_edges = self.num_default_edges + 3 * self.NUM_INSTANCE + \
|
|
self.NUM_ALARM + self.num_default_ports
|
|
|
|
# Test Assertions
|
|
self._validate_graph_correctness(graph,
|
|
num_entities,
|
|
num_edges,
|
|
entities)
|
|
except Exception as e:
|
|
self._handle_exception(e)
|
|
raise
|
|
finally:
|
|
aodh_utils.delete_all_aodh_alarms()
|
|
nova_utils.delete_all_instances()
|
|
|
|
@utils.tempest_logger
|
|
def test_gnocchi_aggregation_by_metrics_threshold_alarm(self):
|
|
try:
|
|
# Action
|
|
nova_utils.create_instances(num_instances=self.NUM_INSTANCE)
|
|
aodh_utils.create_aodh_metrics_threshold_alarm()
|
|
|
|
api_graph = self.vitrage_client.topology.get(all_tenants=True)
|
|
graph = self._create_graph_from_graph_dictionary(api_graph)
|
|
entities = self._entities_validation_data(
|
|
host_entities=1,
|
|
host_edges=1 + self.NUM_INSTANCE,
|
|
instance_entities=self.NUM_INSTANCE,
|
|
instance_edges=2 * self.NUM_INSTANCE,
|
|
aodh_entities=self.NUM_ALARM,
|
|
aodh_edges=0)
|
|
num_entities = self.num_default_entities + \
|
|
2 * self.NUM_INSTANCE + self.NUM_ALARM + \
|
|
self.num_default_networks + self.num_default_ports
|
|
num_edges = self.num_default_edges + 3 * self.NUM_INSTANCE + \
|
|
self.num_default_ports
|
|
|
|
self._validate_graph_correctness(graph,
|
|
num_entities,
|
|
num_edges,
|
|
entities)
|
|
|
|
except Exception as e:
|
|
self._handle_exception(e)
|
|
raise
|
|
finally:
|
|
aodh_utils.delete_all_aodh_alarms()
|
|
aodh_utils.delete_all_gnocchi_metrics()
|
|
nova_utils.delete_all_instances()
|
|
|
|
@utils.tempest_logger
|
|
def test_gnocchi_aggregation_by_resources_threshold(self):
|
|
try:
|
|
# Action
|
|
nova_utils.create_instances(num_instances=self.NUM_INSTANCE)
|
|
aodh_utils.create_aodh_resources_threshold_alarm(
|
|
resource_id=self._find_instance_resource_id())
|
|
|
|
api_graph = self.vitrage_client.topology.get(all_tenants=True)
|
|
graph = self._create_graph_from_graph_dictionary(api_graph)
|
|
entities = self._entities_validation_data(
|
|
host_entities=1,
|
|
host_edges=1 + self.NUM_INSTANCE,
|
|
instance_entities=self.NUM_INSTANCE,
|
|
instance_edges=2 * self.NUM_INSTANCE + self.NUM_ALARM,
|
|
aodh_entities=self.NUM_ALARM,
|
|
aodh_edges=self.NUM_ALARM)
|
|
num_entities = self.num_default_entities + \
|
|
2 * self.NUM_INSTANCE + self.NUM_ALARM + \
|
|
self.num_default_networks + self.num_default_ports
|
|
num_edges = self.num_default_edges + 3 * self.NUM_INSTANCE + \
|
|
+ self.NUM_ALARM + self.num_default_ports
|
|
|
|
self._validate_graph_correctness(graph,
|
|
num_entities,
|
|
num_edges,
|
|
entities)
|
|
|
|
except Exception as e:
|
|
self._handle_exception(e)
|
|
raise
|
|
finally:
|
|
aodh_utils.delete_all_aodh_alarms()
|
|
aodh_utils.delete_all_gnocchi_metrics()
|
|
nova_utils.delete_all_instances()
|
|
|
|
@utils.tempest_logger
|
|
def test_alarm_without_resource_id(self):
|
|
try:
|
|
# Action
|
|
aodh_utils.create_aodh_alarm()
|
|
|
|
# Calculate expected results
|
|
api_graph = self.vitrage_client.topology.get(all_tenants=True)
|
|
graph = self._create_graph_from_graph_dictionary(api_graph)
|
|
entities = self._entities_validation_data(
|
|
host_entities=1,
|
|
host_edges=1,
|
|
aodh_entities=self.NUM_ALARM,
|
|
aodh_edges=0)
|
|
num_entities = self.num_default_entities + self.NUM_ALARM + \
|
|
self.num_default_networks + self.num_default_ports
|
|
num_edges = self.num_default_edges + self.num_default_ports
|
|
|
|
# Test Assertions
|
|
self._validate_graph_correctness(graph,
|
|
num_entities,
|
|
num_edges,
|
|
entities)
|
|
except Exception as e:
|
|
self._handle_exception(e)
|
|
raise
|
|
finally:
|
|
aodh_utils.delete_all_aodh_alarms()
|
|
|
|
def _find_instance_resource_id(self):
|
|
servers = TempestClients.nova().servers.list()
|
|
return servers[0].id
|