127 lines
5.1 KiB
Python

# Copyright 2016 Mirantis, Inc.
#
# 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.
import datetime
import time
import ceilometerclient.v2.client
from proboscis import asserts
from six.moves import configparser
from stacklight_tests import base_test
from stacklight_tests.ceilometer_redis import plugin_settings
from stacklight_tests.helpers import helpers
class CeilometerRedisPluginApi(base_test.PluginApi):
def __init__(self):
super(CeilometerRedisPluginApi, self).__init__()
self._ceilometer = None
@property
def ceilometer(self):
if self._ceilometer is None:
keystone_access = self.helpers.os_conn.keystone_access
endpoint = keystone_access.service_catalog.url_for(
service_type='metering',
service_name='ceilometer',
interface='internal')
if not endpoint:
raise helpers.NotFound("Cannot find ceilometer endpoint")
self._ceilometer = ceilometerclient.v2.Client(
endpoint=endpoint, token=lambda: keystone_access.auth_token)
return self._ceilometer
def get_plugin_settings(self):
return plugin_settings
def prepare_plugin(self):
self.helpers.prepare_plugin(self.settings.plugin_path)
def run_ostf(self):
self.fuel_web.run_ostf(
cluster_id=self.helpers.cluster_id,
test_sets=['smoke', 'sanity'],
timeout=60 * 15
)
test_class_main = ('fuel_health.tests.tests_platform.'
'test_ceilometer.'
'CeilometerApiPlatformTests')
tests_names = ['test_check_alarm_state',
'test_create_sample',
'test_check_volume_events',
'test_check_glance_notifications',
'test_check_keystone_notifications',
'test_check_neutron_notifications',
'test_check_events_and_traits']
test_classes = ['{0}.{1}'.format(test_class_main, test_name)
for test_name in tests_names]
for test_name in test_classes:
self.helpers.run_single_ostf(
test_sets=['tests_platform'], test_name=test_name)
def activate_plugin(self, options=None):
if options is None:
options = self.settings.default_options
self.helpers.activate_plugin(
self.settings.name, self.settings.version, options)
def check_plugin_online(self):
resource_names = ['p_redis-server', 'p_ceilometer-agent-central',
'p_aodh-evaluator']
for resource_name in resource_names:
self.helpers.check_pacemaker_resource(resource_name, "controller")
def uninstall_plugin(self):
return self.helpers.uninstall_plugin(self.settings.name,
self.settings.version)
def check_uninstall_failure(self):
return self.helpers.check_plugin_cannot_be_uninstalled(
self.settings.name, self.settings.version)
def disable_coordination(self):
ceilometer_conf = '/etc/ceilometer/ceilometer.conf'
controllers = self.fuel_web.get_nailgun_cluster_nodes_by_roles(
self.helpers.cluster_id, ['controller'])
for controller in controllers:
with self.fuel_web.get_ssh_for_nailgun_node(controller) as remote:
with remote.open(ceilometer_conf) as f:
parser = configparser.RawConfigParser()
parser.readfp(f)
parser.remove_option('coordination', 'backend_url')
with remote.open(ceilometer_conf, 'w') as f:
parser.write(f)
with self.fuel_web.get_ssh_for_nailgun_node(controllers[0]) as remote:
self.remote_ops.manage_pacemaker_service(
remote, 'p_ceilometer-agent-central', operation='restart')
def check_sample_count(self, expected_count):
image = self.helpers.create_image()
time.sleep(2 * self.settings.polling_interval)
f = datetime.datetime.now() - datetime.timedelta(seconds=600)
query = [{'field': 'timestamp', 'op': 'ge', 'value': f.isoformat()},
{'field': 'resource_id', 'op': 'eq', 'value': image.id}]
actual_count = self.ceilometer.statistics.list(
q=query, meter_name='image')[0].count
msg = ("Expected {0} image sample for one "
"polling period , got : {1} .").format(expected_count,
actual_count)
asserts.assert_true(expected_count == actual_count, msg)