Removed unused param for get_counters().
This patch removed the unused param 'context' for get_counters() in central pollsters. Also added a test case for the central manager. Fixed bug #1111233. Change-Id: Ibfa3d5af8516cc432327e1d0da2af800effd9973
This commit is contained in:
parent
b13701f7c4
commit
baee82420e
@ -72,7 +72,7 @@ class _Base(plugin.CentralPollster):
|
|||||||
class KwapiPollster(_Base):
|
class KwapiPollster(_Base):
|
||||||
"""Kwapi pollster derived from the base class."""
|
"""Kwapi pollster derived from the base class."""
|
||||||
|
|
||||||
def get_counters(self, manager, context):
|
def get_counters(self, manager):
|
||||||
"""Returns all counters."""
|
"""Returns all counters."""
|
||||||
for probe in self.iter_probes():
|
for probe in self.iter_probes():
|
||||||
yield counter.Counter(
|
yield counter.Counter(
|
||||||
|
@ -83,7 +83,7 @@ class _Base(plugin.PollsterBase):
|
|||||||
|
|
||||||
class ImagePollster(_Base):
|
class ImagePollster(_Base):
|
||||||
|
|
||||||
def get_counters(self, manager, context):
|
def get_counters(self, manager):
|
||||||
for image in self.iter_images():
|
for image in self.iter_images():
|
||||||
yield counter.Counter(
|
yield counter.Counter(
|
||||||
name='image',
|
name='image',
|
||||||
|
@ -28,7 +28,7 @@ class FloatingIPPollster(plugin.CentralPollster):
|
|||||||
|
|
||||||
LOG = log.getLogger(__name__ + '.floatingip')
|
LOG = log.getLogger(__name__ + '.floatingip')
|
||||||
|
|
||||||
def get_counters(self, manager, context):
|
def get_counters(self, manager):
|
||||||
nv = nova_client.Client()
|
nv = nova_client.Client()
|
||||||
for ip in nv.floating_ip_get_all():
|
for ip in nv.floating_ip_get_all():
|
||||||
self.LOG.info("FLOATING IP USAGE: %s" % ip.address)
|
self.LOG.info("FLOATING IP USAGE: %s" % ip.address)
|
||||||
|
@ -52,7 +52,7 @@ class _Base(plugin.PollsterBase):
|
|||||||
def iter_accounts():
|
def iter_accounts():
|
||||||
"""Iterate over all accounts, yielding (tenant_id, stats) tuples."""
|
"""Iterate over all accounts, yielding (tenant_id, stats) tuples."""
|
||||||
|
|
||||||
def get_counters(self, manager, context):
|
def get_counters(self, manager):
|
||||||
for tenant, account in self.iter_accounts():
|
for tenant, account in self.iter_accounts():
|
||||||
yield counter.Counter(
|
yield counter.Counter(
|
||||||
name='storage.objects',
|
name='storage.objects',
|
||||||
|
0
tests/central/__init__.py
Normal file
0
tests/central/__init__.py
Normal file
92
tests/central/test_manager.py
Normal file
92
tests/central/test_manager.py
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
# -*- encoding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# Copyright © 2013 Intel Corp.
|
||||||
|
#
|
||||||
|
# Author: Lianhao Lu <lianhao.lu@intel.com>
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
"""Tests for ceilometer/central/manager.py
|
||||||
|
"""
|
||||||
|
|
||||||
|
import datetime
|
||||||
|
from stevedore import extension
|
||||||
|
|
||||||
|
from ceilometer.central import manager
|
||||||
|
from ceilometer import counter
|
||||||
|
from ceilometer import publish
|
||||||
|
from ceilometer.tests import base
|
||||||
|
|
||||||
|
from ceilometer.openstack.common import cfg
|
||||||
|
|
||||||
|
|
||||||
|
def test_load_plugins():
|
||||||
|
mgr = manager.AgentManager()
|
||||||
|
assert list(mgr.ext_manager), 'Failed to load any plugins'
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
class TestRunTasks(base.TestCase):
|
||||||
|
|
||||||
|
class Pollster:
|
||||||
|
counters = []
|
||||||
|
test_data = counter.Counter(
|
||||||
|
name='test',
|
||||||
|
type=counter.TYPE_CUMULATIVE,
|
||||||
|
unit='',
|
||||||
|
volume=1,
|
||||||
|
user_id='test',
|
||||||
|
project_id='test',
|
||||||
|
resource_id='test_run_tasks',
|
||||||
|
timestamp=datetime.datetime.utcnow().isoformat(),
|
||||||
|
resource_metadata={'name': 'Pollster'},
|
||||||
|
)
|
||||||
|
|
||||||
|
def get_counters(self, manager):
|
||||||
|
self.counters.append((manager, self.test_data))
|
||||||
|
return [self.test_data]
|
||||||
|
|
||||||
|
def faux_notify(self, context, msg, topic, secret, source):
|
||||||
|
self.notifications.append((msg, topic, secret, source))
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestRunTasks, self).setUp()
|
||||||
|
self.notifications = []
|
||||||
|
self.stubs.Set(publish, 'publish_counter', self.faux_notify)
|
||||||
|
self.mgr = manager.AgentManager()
|
||||||
|
self.mgr.ext_manager = extension.ExtensionManager('fake',
|
||||||
|
invoke_on_load=False,
|
||||||
|
)
|
||||||
|
self.mgr.ext_manager.extensions = [extension.Extension('test',
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
self.Pollster(),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
# Invoke the periodic tasks to call the pollsters.
|
||||||
|
self.mgr.periodic_tasks(None)
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
self.Pollster.counters = []
|
||||||
|
super(TestRunTasks, self).tearDown()
|
||||||
|
|
||||||
|
def test_message(self):
|
||||||
|
self.assertEqual(len(self.Pollster.counters), 1)
|
||||||
|
self.assertTrue(self.Pollster.counters[0][1] is
|
||||||
|
self.Pollster.test_data)
|
||||||
|
|
||||||
|
def test_notifications(self):
|
||||||
|
actual = self.notifications
|
||||||
|
self.assertEqual(list(actual[0]), [self.Pollster.test_data,
|
||||||
|
cfg.CONF.metering_topic,
|
||||||
|
cfg.CONF.metering_secret,
|
||||||
|
cfg.CONF.counter_source])
|
@ -19,7 +19,6 @@
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
import mock
|
|
||||||
|
|
||||||
from stevedore import extension
|
from stevedore import extension
|
||||||
|
|
||||||
@ -94,11 +93,11 @@ class TestRunTasks(base.TestCase):
|
|||||||
|
|
||||||
def test_message(self):
|
def test_message(self):
|
||||||
self.assertEqual(len(self.Pollster.counters), 2)
|
self.assertEqual(len(self.Pollster.counters), 2)
|
||||||
assert self.Pollster.counters[0][1] is self.instance
|
self.assertTrue(self.Pollster.counters[0][1] is self.instance)
|
||||||
|
|
||||||
def test_notifications(self):
|
def test_notifications(self):
|
||||||
actual = self.notifications
|
actual = self.notifications
|
||||||
assert list(actual[0]) == [self.Pollster.test_data,
|
self.assertEqual(list(actual[0]), [self.Pollster.test_data,
|
||||||
cfg.CONF.metering_topic,
|
cfg.CONF.metering_topic,
|
||||||
cfg.CONF.metering_secret,
|
cfg.CONF.metering_secret,
|
||||||
cfg.CONF.counter_source]
|
cfg.CONF.counter_source])
|
||||||
|
@ -60,8 +60,7 @@ class TestKwapiPollster(base.TestCase):
|
|||||||
self.stubs.Set(kwapi._Base, 'iter_probes', self.fake_kwapi_iter_probes)
|
self.stubs.Set(kwapi._Base, 'iter_probes', self.fake_kwapi_iter_probes)
|
||||||
|
|
||||||
def test_kwapi_counter(self):
|
def test_kwapi_counter(self):
|
||||||
counters = list(kwapi.KwapiPollster().get_counters(self.manager,
|
counters = list(kwapi.KwapiPollster().get_counters(self.manager))
|
||||||
self.context))
|
|
||||||
self.assertEqual(len(counters), 6)
|
self.assertEqual(len(counters), 6)
|
||||||
energy_counters = [counter for counter in counters
|
energy_counters = [counter for counter in counters
|
||||||
if counter.name == "energy"]
|
if counter.name == "energy"]
|
||||||
|
@ -97,8 +97,7 @@ class TestImagePollster(base.TestCase):
|
|||||||
self.fake_glance_iter_images)
|
self.fake_glance_iter_images)
|
||||||
|
|
||||||
def test_glance_image_counter(self):
|
def test_glance_image_counter(self):
|
||||||
counters = list(glance.ImagePollster().get_counters(self.manager,
|
counters = list(glance.ImagePollster().get_counters(self.manager))
|
||||||
self.context))
|
|
||||||
self.assertEqual(len(counters), 6)
|
self.assertEqual(len(counters), 6)
|
||||||
for counter in [c for c in counters if c.name == 'image']:
|
for counter in [c for c in counters if c.name == 'image']:
|
||||||
self.assertEqual(counter.volume, 1)
|
self.assertEqual(counter.volume, 1)
|
||||||
|
@ -58,7 +58,7 @@ class TestFloatingIPPollster(base.TestCase):
|
|||||||
# assert False, 'Should have seen an error'
|
# assert False, 'Should have seen an error'
|
||||||
|
|
||||||
def test_get_counters_not_empty(self):
|
def test_get_counters_not_empty(self):
|
||||||
counters = list(self.pollster.get_counters(self.manager, self.context))
|
counters = list(self.pollster.get_counters(self.manager))
|
||||||
self.assertEqual(len(counters), 3)
|
self.assertEqual(len(counters), 3)
|
||||||
addresses = [c.resource_metadata['address']
|
addresses = [c.resource_metadata['address']
|
||||||
for c in counters
|
for c in counters
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
from ceilometer.central import manager
|
||||||
from ceilometer.objectstore import swift
|
from ceilometer.objectstore import swift
|
||||||
from ceilometer.tests import base
|
from ceilometer.tests import base
|
||||||
|
|
||||||
@ -40,9 +41,10 @@ class TestSwiftPollster(base.TestCase):
|
|||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestSwiftPollster, self).setUp()
|
super(TestSwiftPollster, self).setUp()
|
||||||
self.pollster = swift.SwiftPollster()
|
self.pollster = swift.SwiftPollster()
|
||||||
|
self.manager = manager.AgentManager()
|
||||||
self.stubs.Set(swift.SwiftPollster, 'iter_accounts',
|
self.stubs.Set(swift.SwiftPollster, 'iter_accounts',
|
||||||
self.fake_iter_accounts)
|
self.fake_iter_accounts)
|
||||||
|
|
||||||
def test_objectstore_metering(self):
|
def test_objectstore_metering(self):
|
||||||
counters = list(self.pollster.get_counters(None, None))
|
counters = list(self.pollster.get_counters(self.manager))
|
||||||
self.assertEqual(len(counters), 6)
|
self.assertEqual(len(counters), 6)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user