Update resource_map() to inspect vmware context for any additional services to manage.

This commit is contained in:
Adam Gandelman 2013-10-16 15:13:33 -07:00
parent f0d2584389
commit 927565abcb
3 changed files with 50 additions and 13 deletions

View File

@ -183,6 +183,16 @@ def resource_map():
# nova-conductor for releases >= G. # nova-conductor for releases >= G.
if os_release('nova-common') not in ['essex', 'folsom']: if os_release('nova-common') not in ['essex', 'folsom']:
resource_map['/etc/nova/nova.conf']['services'] += ['nova-conductor'] resource_map['/etc/nova/nova.conf']['services'] += ['nova-conductor']
# also manage any configs that are being updated by subordinates.
vmware_ctxt = context.SubordinateConfigContext(interface='nova-vmware',
service='nova',
config_file=NOVA_CONF)
vmware_ctxt = vmware_ctxt()
if vmware_ctxt and 'services' in vmware_ctxt:
for s in vmware_ctxt['services']:
if s not in resource_map[NOVA_CONF]['services']:
resource_map[NOVA_CONF]['services'].append(s)
return resource_map return resource_map

View File

@ -1 +1 @@
306 307

View File

@ -119,9 +119,13 @@ class NovaCCUtilsTests(CharmTestCase):
self.neutron_plugin_attribute.side_effect = fake_plugin_attribute self.neutron_plugin_attribute.side_effect = fake_plugin_attribute
if volume_manager == 'nova-volume': if volume_manager == 'nova-volume':
self.relation_ids.return_value = 'nova-volume-service:0' self.relation_ids.return_value = 'nova-volume-service:0'
return utils.resource_map() with patch('charmhelpers.contrib.openstack.context.'
'SubordinateConfigContext'):
_map = utils.resource_map()
return _map
def test_resource_map_quantum(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_resource_map_quantum(self, subcontext):
self._resource_map(network_manager='quantum') self._resource_map(network_manager='quantum')
_map = utils.resource_map() _map = utils.resource_map()
confs = [ confs = [
@ -131,7 +135,8 @@ class NovaCCUtilsTests(CharmTestCase):
] ]
[self.assertIn(q_conf, _map.keys()) for q_conf in confs] [self.assertIn(q_conf, _map.keys()) for q_conf in confs]
def test_resource_map_neutron(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_resource_map_neutron(self, subcontext):
self._resource_map(network_manager='neutron') self._resource_map(network_manager='neutron')
_map = utils.resource_map() _map = utils.resource_map()
confs = [ confs = [
@ -139,7 +144,21 @@ class NovaCCUtilsTests(CharmTestCase):
] ]
[self.assertIn(q_conf, _map.keys()) for q_conf in confs] [self.assertIn(q_conf, _map.keys()) for q_conf in confs]
def test_resource_map_neutron_no_agent_installed(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_resource_map_vmware(self, subcontext):
fake_context = MagicMock()
fake_context.return_value = {
'sections': [] ,
'services': ['nova-compute', 'nova-network'],
}
subcontext.return_value = fake_context
_map = utils.resource_map()
for s in ['nova-compute', 'nova-network']:
self.assertIn(s, _map['/etc/nova/nova.conf']['services'])
@patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_resource_map_neutron_no_agent_installed(self, subcontext):
self._resource_map(network_manager='neutron') self._resource_map(network_manager='neutron')
_map = utils.resource_map() _map = utils.resource_map()
services = [] services = []
@ -147,22 +166,25 @@ class NovaCCUtilsTests(CharmTestCase):
for svc in services: for svc in services:
self.assertNotIn('agent', svc) self.assertNotIn('agent', svc)
def test_resource_map_nova_volume(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_resource_map_nova_volume(self, subcontext):
self.relation_ids.return_value = ['nova-volume-service:0'] self.relation_ids.return_value = ['nova-volume-service:0']
_map = utils.resource_map() _map = utils.resource_map()
self.assertIn('nova-api-os-volume', self.assertIn('nova-api-os-volume',
_map['/etc/nova/nova.conf']['services']) _map['/etc/nova/nova.conf']['services'])
@patch('os.path.exists') @patch('os.path.exists')
def test_restart_map_api_before_frontends(self, _exists): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_restart_map_api_before_frontends(self, subcontext, _exists):
_exists.return_value = False _exists.return_value = False
self._resource_map(network_manager='neutron') self._resource_map(network_manager='neutron')
_map = utils.restart_map() _map = utils.restart_map()
self.assertTrue(isinstance(_map, OrderedDict)) self.assertTrue(isinstance(_map, OrderedDict))
self.assertEquals(_map, RESTART_MAP) self.assertEquals(_map, RESTART_MAP)
@patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
@patch('os.path.exists') @patch('os.path.exists')
def test_restart_map_apache24(self, _exists): def test_restart_map_apache24(self, _exists, subcontext):
_exists.return_Value = True _exists.return_Value = True
self._resource_map(network_manager='neutron') self._resource_map(network_manager='neutron')
_map = utils.restart_map() _map = utils.restart_map()
@ -171,29 +193,34 @@ class NovaCCUtilsTests(CharmTestCase):
self.assertTrue('/etc/apache2/sites-available/' self.assertTrue('/etc/apache2/sites-available/'
'openstack_https_frontend' not in _map) 'openstack_https_frontend' not in _map)
def test_determine_packages_quantum(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_determine_packages_quantum(self, subcontext):
self._resource_map(network_manager='quantum') self._resource_map(network_manager='quantum')
pkgs = utils.determine_packages() pkgs = utils.determine_packages()
self.assertIn('quantum-server', pkgs) self.assertIn('quantum-server', pkgs)
def test_determine_packages_neutron(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_determine_packages_neutron(self, subcontext):
self._resource_map(network_manager='neutron') self._resource_map(network_manager='neutron')
pkgs = utils.determine_packages() pkgs = utils.determine_packages()
self.assertIn('neutron-server', pkgs) self.assertIn('neutron-server', pkgs)
def test_determine_packages_nova_volume(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_determine_packages_nova_volume(self, subcontext):
self.relation_ids.return_value = ['nova-volume-service:0'] self.relation_ids.return_value = ['nova-volume-service:0']
pkgs = utils.determine_packages() pkgs = utils.determine_packages()
self.assertIn('nova-api-os-volume', pkgs) self.assertIn('nova-api-os-volume', pkgs)
def test_determine_packages_base(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_determine_packages_base(self, subcontext):
self.relation_ids.return_value = [] self.relation_ids.return_value = []
self.os_release.return_value = 'folsom' self.os_release.return_value = 'folsom'
pkgs = utils.determine_packages() pkgs = utils.determine_packages()
ex = list(set(utils.BASE_PACKAGES + utils.BASE_SERVICES)) ex = list(set(utils.BASE_PACKAGES + utils.BASE_SERVICES))
self.assertEquals(ex, pkgs) self.assertEquals(ex, pkgs)
def test_determine_packages_base_grizzly_beyond(self): @patch('charmhelpers.contrib.openstack.context.SubordinateConfigContext')
def test_determine_packages_base_grizzly_beyond(self, subcontext):
self.relation_ids.return_value = [] self.relation_ids.return_value = []
self.os_release.return_value = 'grizzly' self.os_release.return_value = 'grizzly'
pkgs = utils.determine_packages() pkgs = utils.determine_packages()