Files
aodh/ceilometer/tests/compute/pollsters/base.py
lzhijun 568717ae53 Expose vm's metadata to metrics
We have customized ceilometer publisher to send metrics into openTSDB service.
Hence, we need more user-friendly VM information (e.g. VM hostname, IP
and project_cos) as metrics tags during populate metrics into openTSDB.

So we expected samples can attach nova meta data at publisher.PublisherBase's
publish_samples function. Then it's available for customized publisher
to access metadata.

However the current method add_reserved_user_metadata can't support various
naming convention which didn't have one particular prefix. So we need to
add one more config for metadata keys "reserved_metadata_keys" in
ceilometer.conf, and user can define the key name they cared in
instance.metadata.

DocImpact

Change-Id: I588aaf22a0e8593042dad4bbc37be27adc96c2b4
Closes-bug: #1391778
2015-01-19 10:47:25 +08:00

58 lines
2.1 KiB
Python

#
# Copyright 2012 eNovance <licensing@enovance.com>
# Copyright 2012 Red Hat, Inc
#
# Author: Julien Danjou <julien@danjou.info>
# Author: Eoghan Glynn <eglynn@redhat.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.
import mock
from oslotest import mockpatch
import ceilometer.tests.base as base
class TestPollsterBase(base.BaseTestCase):
def setUp(self):
super(TestPollsterBase, self).setUp()
self.inspector = mock.Mock()
self.instance = mock.MagicMock()
self.instance.name = 'instance-00000001'
setattr(self.instance, 'OS-EXT-SRV-ATTR:instance_name',
self.instance.name)
self.instance.id = 1
self.instance.flavor = {'name': 'm1.small', 'id': 2, 'vcpus': 1,
'ram': 512, 'disk': 20, 'ephemeral': 0}
self.instance.status = 'active'
self.instance.metadata = {
'fqdn': 'vm_fqdn',
'metering.stack': '2cadc4b4-8789-123c-b4eg-edd2f0a9c128',
'project_cos': 'dev'}
patch_virt = mockpatch.Patch(
'ceilometer.compute.virt.inspector.get_hypervisor_inspector',
new=mock.Mock(return_value=self.inspector))
self.useFixture(patch_virt)
# as we're having lazy hypervisor inspector singleton object in the
# base compute pollster class, that leads to the fact that we
# need to mock all this class property to avoid context sharing between
# the tests
patch_inspector = mockpatch.Patch(
'ceilometer.compute.pollsters.BaseComputePollster.inspector',
self.inspector)
self.useFixture(patch_inspector)