Merge "Use central agent manager's keystone token in discoveries"

This commit is contained in:
Jenkins 2014-09-15 10:25:54 +00:00 committed by Gerrit Code Review
commit a5b42f32a3
11 changed files with 76 additions and 36 deletions

View File

@ -204,7 +204,7 @@ class AgentManager(os_service.Service):
discoverer = self._discoverer(name) discoverer = self._discoverer(name)
if discoverer: if discoverer:
try: try:
discovered = discoverer.discover(param) discovered = discoverer.discover(self, param)
partitioned = self.partition_coordinator.extract_my_subset( partitioned = self.partition_coordinator.extract_my_subset(
self._construct_group_id(discoverer.group_id), self._construct_group_id(discoverer.group_id),
discovered) discovered)

View File

@ -15,7 +15,6 @@
# 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 keystoneclient.v2_0 import client as ksclient
from oslo.config import cfg from oslo.config import cfg
from ceilometer.openstack.common.gettextutils import _LW from ceilometer.openstack.common.gettextutils import _LW
@ -28,22 +27,11 @@ cfg.CONF.import_group('service_credentials', 'ceilometer.service')
class EndpointDiscovery(plugin.DiscoveryBase): class EndpointDiscovery(plugin.DiscoveryBase):
def __init__(self):
super(EndpointDiscovery, self).__init__()
self.keystone = ksclient.Client(
username=cfg.CONF.service_credentials.os_username,
password=cfg.CONF.service_credentials.os_password,
tenant_id=cfg.CONF.service_credentials.os_tenant_id,
tenant_name=cfg.CONF.service_credentials.os_tenant_name,
cacert=cfg.CONF.service_credentials.os_cacert,
auth_url=cfg.CONF.service_credentials.os_auth_url,
region_name=cfg.CONF.service_credentials.os_region_name,
insecure=cfg.CONF.service_credentials.insecure)
def discover(self, param=None): def discover(self, manager, param=None):
if not param: if not param:
return [] return []
endpoints = self.keystone.service_catalog.get_urls( endpoints = manager.keystone.service_catalog.get_urls(
service_type=param, service_type=param,
endpoint_type=cfg.CONF.service_credentials.os_endpoint_type, endpoint_type=cfg.CONF.service_credentials.os_endpoint_type,
region_name=cfg.CONF.service_credentials.os_region_name) region_name=cfg.CONF.service_credentials.os_region_name)

View File

@ -34,7 +34,7 @@ class InstanceDiscovery(plugin.DiscoveryBase):
super(InstanceDiscovery, self).__init__() super(InstanceDiscovery, self).__init__()
self.nova_cli = nova_client.Client() self.nova_cli = nova_client.Client()
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
instances = self.nova_cli.instance_get_all_by_host(cfg.CONF.host) instances = self.nova_cli.instance_get_all_by_host(cfg.CONF.host)
return [i for i in instances return [i for i in instances

View File

@ -45,7 +45,7 @@ class NodesDiscoveryTripleO(plugin.DiscoveryBase):
def _address(instance, field): def _address(instance, field):
return instance.addresses['ctlplane'][0].get(field) return instance.addresses['ctlplane'][0].get(field)
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
instances = self.nova_cli.instance_get_all() instances = self.nova_cli.instance_get_all()

View File

@ -29,7 +29,7 @@ class _BaseServicesDiscovery(base_plugin.DiscoveryBase):
class LBPoolsDiscovery(_BaseServicesDiscovery): class LBPoolsDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
pools = self.neutron_cli.pool_get_all() pools = self.neutron_cli.pool_get_all()
@ -39,7 +39,7 @@ class LBPoolsDiscovery(_BaseServicesDiscovery):
class LBVipsDiscovery(_BaseServicesDiscovery): class LBVipsDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
vips = self.neutron_cli.vip_get_all() vips = self.neutron_cli.vip_get_all()
@ -49,7 +49,7 @@ class LBVipsDiscovery(_BaseServicesDiscovery):
class LBMembersDiscovery(_BaseServicesDiscovery): class LBMembersDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
members = self.neutron_cli.member_get_all() members = self.neutron_cli.member_get_all()
@ -59,7 +59,7 @@ class LBMembersDiscovery(_BaseServicesDiscovery):
class LBHealthMonitorsDiscovery(_BaseServicesDiscovery): class LBHealthMonitorsDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
probes = self.neutron_cli.health_monitor_get_all() probes = self.neutron_cli.health_monitor_get_all()
@ -68,7 +68,7 @@ class LBHealthMonitorsDiscovery(_BaseServicesDiscovery):
class VPNServicesDiscovery(_BaseServicesDiscovery): class VPNServicesDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
vpnservices = self.neutron_cli.vpn_get_all() vpnservices = self.neutron_cli.vpn_get_all()
@ -78,7 +78,7 @@ class VPNServicesDiscovery(_BaseServicesDiscovery):
class IPSecConnectionsDiscovery(_BaseServicesDiscovery): class IPSecConnectionsDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
conns = self.neutron_cli.ipsec_site_connections_get_all() conns = self.neutron_cli.ipsec_site_connections_get_all()
@ -87,7 +87,7 @@ class IPSecConnectionsDiscovery(_BaseServicesDiscovery):
class FirewallDiscovery(_BaseServicesDiscovery): class FirewallDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
fw = self.neutron_cli.firewall_get_all() fw = self.neutron_cli.firewall_get_all()
@ -97,7 +97,7 @@ class FirewallDiscovery(_BaseServicesDiscovery):
class FirewallPolicyDiscovery(_BaseServicesDiscovery): class FirewallPolicyDiscovery(_BaseServicesDiscovery):
@plugin.check_keystone('network') @plugin.check_keystone('network')
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor.""" """Discover resources to monitor."""
return self.neutron_cli.fw_policy_get_all() return self.neutron_cli.fw_policy_get_all()

View File

@ -163,9 +163,10 @@ class PollsterBase(PluginBase):
@six.add_metaclass(abc.ABCMeta) @six.add_metaclass(abc.ABCMeta)
class DiscoveryBase(object): class DiscoveryBase(object):
@abc.abstractmethod @abc.abstractmethod
def discover(self, param=None): def discover(self, manager, param=None):
"""Discover resources to monitor. """Discover resources to monitor.
:param manager: The service manager class invoking the plugin.
:param param: an optional parameter to guide the discovery :param param: an optional parameter to guide the discovery
""" """

View File

@ -95,13 +95,13 @@ class TestPollsterException(TestPollster):
class TestDiscovery(plugin.DiscoveryBase): class TestDiscovery(plugin.DiscoveryBase):
def discover(self, param=None): def discover(self, manager, param=None):
self.params.append(param) self.params.append(param)
return self.resources return self.resources
class TestDiscoveryException(plugin.DiscoveryBase): class TestDiscoveryException(plugin.DiscoveryBase):
def discover(self, param=None): def discover(self, manager, param=None):
self.params.append(param) self.params.append(param)
raise Exception() raise Exception()

View File

@ -0,0 +1,46 @@
#
# Copyright 2014 Red Hat Inc.
#
# Author: Nejc Saje <nsaje@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.
"""Tests for ceilometer/central/manager.py
"""
import mock
from oslo.config import fixture as fixture_config
from oslotest import base
from ceilometer.central import discovery
class TestEndpointDiscovery(base.BaseTestCase):
def setUp(self):
super(TestEndpointDiscovery, self).setUp()
self.discovery = discovery.EndpointDiscovery()
self.manager = mock.MagicMock()
self.CONF = self.useFixture(fixture_config.Config()).conf
def test_keystone_called(self):
self.CONF.set_override('os_endpoint_type', 'test-endpoint-type',
group='service_credentials')
self.CONF.set_override('os_region_name', 'test-region-name',
group='service_credentials')
self.discovery.discover(self.manager, param='test-service-type')
expected = [mock.call(service_type='test-service-type',
endpoint_type='test-endpoint-type',
region_name='test-region-name')]
self.assertEqual(expected,
self.manager.keystone.service_catalog.get_urls
.call_args_list)

View File

@ -106,7 +106,7 @@ class TestFirewallPollster(_BaseTestFWPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_vpn_discovery(self): def test_vpn_discovery(self):
discovered_fws = discovery.FirewallDiscovery().discover() discovered_fws = discovery.FirewallDiscovery().discover(self.manager)
self.assertEqual(3, len(discovered_fws)) self.assertEqual(3, len(discovered_fws))
for vpn in self.fake_get_fw_service(): for vpn in self.fake_get_fw_service():
@ -165,6 +165,7 @@ class TestIPSecConnectionsPollster(_BaseTestFWPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_fw_policy_discovery(self): def test_fw_policy_discovery(self):
discovered_policy = discovery.FirewallPolicyDiscovery().discover() discovered_policy = discovery.FirewallPolicyDiscovery().discover(
self.manager)
self.assertEqual(1, len(discovered_policy)) self.assertEqual(1, len(discovered_policy))
self.assertEqual(self.fake_get_fw_policy(), discovered_policy) self.assertEqual(self.fake_get_fw_policy(), discovered_policy)

View File

@ -153,7 +153,7 @@ class TestLBPoolPollster(_BaseTestLBPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_pool_discovery(self): def test_pool_discovery(self):
discovered_pools = discovery.LBPoolsDiscovery().discover() discovered_pools = discovery.LBPoolsDiscovery().discover(self.manager)
self.assertEqual(4, len(discovered_pools)) self.assertEqual(4, len(discovered_pools))
for pool in self.fake_get_pools(): for pool in self.fake_get_pools():
if pool['status'] == 'error': if pool['status'] == 'error':
@ -276,7 +276,7 @@ class TestLBVipPollster(_BaseTestLBPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_vip_discovery(self): def test_vip_discovery(self):
discovered_vips = discovery.LBVipsDiscovery().discover() discovered_vips = discovery.LBVipsDiscovery().discover(self.manager)
self.assertEqual(4, len(discovered_vips)) self.assertEqual(4, len(discovered_vips))
for pool in self.fake_get_vips(): for pool in self.fake_get_vips():
if pool['status'] == 'error': if pool['status'] == 'error':
@ -369,7 +369,8 @@ class TestLBMemberPollster(_BaseTestLBPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_members_discovery(self): def test_members_discovery(self):
discovered_members = discovery.LBMembersDiscovery().discover() discovered_members = discovery.LBMembersDiscovery().discover(
self.manager)
self.assertEqual(4, len(discovered_members)) self.assertEqual(4, len(discovered_members))
for pool in self.fake_get_members(): for pool in self.fake_get_members():
if pool['status'] == 'error': if pool['status'] == 'error':
@ -417,7 +418,8 @@ class TestLBHealthProbePollster(_BaseTestLBPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_probes_discovery(self): def test_probes_discovery(self):
discovered_probes = discovery.LBHealthMonitorsDiscovery().discover() discovered_probes = discovery.LBHealthMonitorsDiscovery().discover(
self.manager)
self.assertEqual(discovered_probes, self.fake_get_health_monitor()) self.assertEqual(discovered_probes, self.fake_get_health_monitor())

View File

@ -110,7 +110,8 @@ class TestVPNServicesPollster(_BaseTestVPNPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_vpn_discovery(self): def test_vpn_discovery(self):
discovered_vpns = discovery.VPNServicesDiscovery().discover() discovered_vpns = discovery.VPNServicesDiscovery().discover(
self.manager)
self.assertEqual(3, len(discovered_vpns)) self.assertEqual(3, len(discovered_vpns))
for vpn in self.fake_get_vpn_service(): for vpn in self.fake_get_vpn_service():
@ -170,6 +171,7 @@ class TestIPSecConnectionsPollster(_BaseTestVPNPollster):
set([s.name for s in samples])) set([s.name for s in samples]))
def test_conns_discovery(self): def test_conns_discovery(self):
discovered_conns = discovery.IPSecConnectionsDiscovery().discover() discovered_conns = discovery.IPSecConnectionsDiscovery().discover(
self.manager)
self.assertEqual(1, len(discovered_conns)) self.assertEqual(1, len(discovered_conns))
self.assertEqual(self.fake_get_ipsec_connections(), discovered_conns) self.assertEqual(self.fake_get_ipsec_connections(), discovered_conns)