Add 'enabled' property for keystone service

Allow user to specify whether the keystone
service enabled.

Change-Id: Ib2a332df9700027b1d02c9be9c917cb6828a8f40
Closes-Bug: #1505165
This commit is contained in:
huangtianhua 2015-10-15 10:26:10 +08:00
parent 7f33380327
commit 10439f0c69
2 changed files with 90 additions and 67 deletions

View File

@ -29,9 +29,9 @@ class KeystoneService(resource.Resource):
entity = 'services' entity = 'services'
PROPERTIES = ( PROPERTIES = (
NAME, DESCRIPTION, TYPE NAME, DESCRIPTION, TYPE, ENABLED,
) = ( ) = (
'name', 'description', 'type' 'name', 'description', 'type', 'enabled',
) )
properties_schema = { properties_schema = {
@ -50,6 +50,13 @@ class KeystoneService(resource.Resource):
_('Type of keystone Service.'), _('Type of keystone Service.'),
update_allowed=True, update_allowed=True,
required=True required=True
),
ENABLED: properties.Schema(
properties.Schema.BOOLEAN,
_('This service is enabled or disabled.'),
default=True,
update_allowed=True,
support_status=support.SupportStatus(version='6.0.0')
) )
} }
@ -61,11 +68,13 @@ class KeystoneService(resource.Resource):
self.physical_resource_name()) self.physical_resource_name())
description = self.properties[self.DESCRIPTION] description = self.properties[self.DESCRIPTION]
type = self.properties[self.TYPE] type = self.properties[self.TYPE]
enabled = self.properties[self.ENABLED]
service = self.client().services.create( service = self.client().services.create(
name=name, name=name,
description=description, description=description,
type=type) type=type,
enabled=enabled)
self.resource_id_set(service.id) self.resource_id_set(service.id)
@ -75,12 +84,14 @@ class KeystoneService(resource.Resource):
self.physical_resource_name()) self.physical_resource_name())
description = prop_diff.get(self.DESCRIPTION) description = prop_diff.get(self.DESCRIPTION)
type = prop_diff.get(self.TYPE) type = prop_diff.get(self.TYPE)
enabled = prop_diff.get(self.ENABLED)
self.client().services.update( self.client().services.update(
service=self.resource_id, service=self.resource_id,
name=name, name=name,
description=description, description=description,
type=type) type=type,
enabled=enabled)
def resource_mapping(): def resource_mapping():

View File

@ -28,7 +28,8 @@ keystone_service_template = {
'properties': { 'properties': {
'name': 'test_service_1', 'name': 'test_service_1',
'description': 'Test service', 'description': 'Test service',
'type': 'orchestration' 'type': 'orchestration',
'enabled': False
} }
} }
} }
@ -43,23 +44,30 @@ class KeystoneServiceTest(common.HeatTestCase):
self.ctx = utils.dummy_context() self.ctx = utils.dummy_context()
self.stack = stack.Stack(
self.ctx, 'test_stack_keystone',
template.Template(keystone_service_template)
)
self.test_service = self.stack['test_service']
# Mock client # Mock client
self.keystoneclient = mock.MagicMock() self.keystoneclient = mock.MagicMock()
self.test_service.client = mock.MagicMock()
self.test_service.client.return_value = self.keystoneclient
self.services = self.keystoneclient.services self.services = self.keystoneclient.services
# Mock client plugin # Mock client plugin
keystone_client_plugin = mock.MagicMock() self.keystone_client_plugin = mock.MagicMock()
self.test_service.client_plugin = mock.MagicMock()
self.test_service.client_plugin.return_value = keystone_client_plugin def _setup_service_resource(self, stack_name, use_default=False):
test_stack = stack.Stack(
self.ctx, stack_name,
template.Template(keystone_service_template)
)
r_service = test_stack['test_service']
r_service.client = mock.MagicMock()
r_service.client.return_value = self.keystoneclient
r_service.client_plugin = mock.MagicMock()
r_service.client_plugin.return_value = self.keystone_client_plugin
if use_default:
del r_service.t['Properties']['name']
del r_service.t['Properties']['enabled']
del r_service.t['Properties']['description']
return r_service
def _get_mock_service(self): def _get_mock_service(self):
value = mock.MagicMock() value = mock.MagicMock()
@ -68,119 +76,122 @@ class KeystoneServiceTest(common.HeatTestCase):
return value return value
def test_service_handle_create(self): def test_service_handle_create(self):
rsrc = self._setup_service_resource('test_service_create')
mock_service = self._get_mock_service() mock_service = self._get_mock_service()
self.services.create.return_value = mock_service self.services.create.return_value = mock_service
# validate the properties # validate the properties
self.assertEqual( self.assertEqual(
'test_service_1', 'test_service_1',
self.test_service.properties.get(service.KeystoneService.NAME)) rsrc.properties.get(service.KeystoneService.NAME))
self.assertEqual( self.assertEqual(
'Test service', 'Test service',
self.test_service.properties.get( rsrc.properties.get(
service.KeystoneService.DESCRIPTION)) service.KeystoneService.DESCRIPTION))
self.assertEqual( self.assertEqual(
'orchestration', 'orchestration',
self.test_service.properties.get(service.KeystoneService.TYPE)) rsrc.properties.get(service.KeystoneService.TYPE))
self.assertFalse(rsrc.properties.get(
service.KeystoneService.ENABLED))
self.test_service.handle_create() rsrc.handle_create()
# validate service creation # validate service creation
self.services.create.assert_called_once_with( self.services.create.assert_called_once_with(
name='test_service_1', name='test_service_1',
description='Test service', description='Test service',
type='orchestration') type='orchestration',
enabled=False)
# validate physical resource id # validate physical resource id
self.assertEqual(mock_service.id, self.test_service.resource_id) self.assertEqual(mock_service.id, rsrc.resource_id)
def test_service_handle_create_default(self): def test_service_handle_create_default(self):
values = { rsrc = self._setup_service_resource('test_create_with_defaults',
service.KeystoneService.NAME: None, use_default=True)
service.KeystoneService.DESCRIPTION: None,
service.KeystoneService.TYPE: 'orchestration'
}
def _side_effect(key):
return values[key]
mock_service = self._get_mock_service() mock_service = self._get_mock_service()
self.services.create.return_value = mock_service self.services.create.return_value = mock_service
self.test_service.properties = mock.MagicMock()
self.test_service.properties.get.side_effect = _side_effect
self.test_service.properties.__getitem__.side_effect = _side_effect
self.test_service.physical_resource_name = mock.MagicMock() rsrc.physical_resource_name = mock.MagicMock()
self.test_service.physical_resource_name.return_value = 'foo' rsrc.physical_resource_name.return_value = 'foo'
# validate the properties # validate the properties
self.assertIsNone( self.assertIsNone(
self.test_service.properties.get(service.KeystoneService.NAME)) rsrc.properties.get(service.KeystoneService.NAME))
self.assertIsNone( self.assertIsNone(rsrc.properties.get(
self.test_service.properties.get( service.KeystoneService.DESCRIPTION))
service.KeystoneService.DESCRIPTION))
self.assertEqual( self.assertEqual(
'orchestration', 'orchestration',
self.test_service.properties.get(service.KeystoneService.TYPE)) rsrc.properties.get(service.KeystoneService.TYPE))
self.assertTrue(rsrc.properties.get(service.KeystoneService.ENABLED))
self.test_service.handle_create() rsrc.handle_create()
# validate service creation with physical resource name # validate service creation with physical resource name
self.services.create.assert_called_once_with( self.services.create.assert_called_once_with(
name='foo', name='foo',
description=None, description=None,
type='orchestration') type='orchestration',
enabled=True)
def test_service_handle_update(self): def test_service_handle_update(self):
self.test_service.resource_id = '477e8273-60a7-4c41-b683-fdb0bc7cd151' rsrc = self._setup_service_resource('test_update')
rsrc.resource_id = '477e8273-60a7-4c41-b683-fdb0bc7cd151'
prop_diff = {service.KeystoneService.NAME: 'test_service_1_updated', prop_diff = {service.KeystoneService.NAME: 'test_service_1_updated',
service.KeystoneService.DESCRIPTION: service.KeystoneService.DESCRIPTION:
'Test Service updated', 'Test Service updated',
service.KeystoneService.TYPE: 'heat_updated'} service.KeystoneService.TYPE: 'heat_updated',
service.KeystoneService.ENABLED: False}
self.test_service.handle_update(json_snippet=None, rsrc.handle_update(json_snippet=None,
tmpl_diff=None, tmpl_diff=None,
prop_diff=prop_diff) prop_diff=prop_diff)
self.services.update.assert_called_once_with( self.services.update.assert_called_once_with(
service=self.test_service.resource_id, service=rsrc.resource_id,
name=prop_diff[service.KeystoneService.NAME], name=prop_diff[service.KeystoneService.NAME],
description=prop_diff[service.KeystoneService.DESCRIPTION], description=prop_diff[service.KeystoneService.DESCRIPTION],
type=prop_diff[service.KeystoneService.TYPE] type=prop_diff[service.KeystoneService.TYPE],
enabled=prop_diff[service.KeystoneService.ENABLED]
) )
def test_service_handle_update_default(self): def test_service_handle_update_default_name(self):
self.test_service.resource_id = '477e8273-60a7-4c41-b683-fdb0bc7cd151' rsrc = self._setup_service_resource('test_update_default_name')
self.test_service.physical_resource_name = mock.MagicMock() rsrc.resource_id = '477e8273-60a7-4c41-b683-fdb0bc7cd151'
self.test_service.physical_resource_name.return_value = 'foo' rsrc.physical_resource_name = mock.MagicMock()
rsrc.physical_resource_name.return_value = 'foo'
# Name is reset to None, so default to physical resource name # Name is reset to None, so default to physical resource name
prop_diff = {service.KeystoneService.NAME: None} prop_diff = {service.KeystoneService.NAME: None}
self.test_service.handle_update(json_snippet=None, rsrc.handle_update(json_snippet=None,
tmpl_diff=None, tmpl_diff=None,
prop_diff=prop_diff) prop_diff=prop_diff)
# validate default name to physical resource name # validate default name to physical resource name
self.services.update.assert_called_once_with( self.services.update.assert_called_once_with(
service=self.test_service.resource_id, service=rsrc.resource_id,
name='foo', name='foo',
type=None, type=None,
description=None description=None,
enabled=None
) )
def test_resource_mapping(self): def test_resource_mapping(self):
rsrc = self._setup_service_resource(
'test_resource_mapping')
mapping = service.resource_mapping() mapping = service.resource_mapping()
self.assertEqual(1, len(mapping)) self.assertEqual(1, len(mapping))
self.assertEqual(service.KeystoneService, mapping[RESOURCE_TYPE]) self.assertEqual(service.KeystoneService, mapping[RESOURCE_TYPE])
self.assertIsInstance(self.test_service, service.KeystoneService) self.assertIsInstance(rsrc, service.KeystoneService)
def test_properties_title(self): def test_properties_title(self):
property_title_map = { property_title_map = {
service.KeystoneService.NAME: 'name', service.KeystoneService.NAME: 'name',
service.KeystoneService.DESCRIPTION: 'description', service.KeystoneService.DESCRIPTION: 'description',
service.KeystoneService.TYPE: 'type' service.KeystoneService.TYPE: 'type',
service.KeystoneService.ENABLED: 'enabled'
} }
for actual_title, expected_title in property_title_map.items(): for actual_title, expected_title in property_title_map.items():
@ -250,8 +261,9 @@ class KeystoneServiceTest(common.HeatTestCase):
service.KeystoneService.TYPE) service.KeystoneService.TYPE)
def test_show_resource(self): def test_show_resource(self):
service = mock.Mock() rsrc = self._setup_service_resource('test_show_resource')
service.to_dict.return_value = {'attr': 'val'} moc_service = mock.Mock()
self.services.get.return_value = service moc_service.to_dict.return_value = {'attr': 'val'}
res = self.test_service._show_resource() self.services.get.return_value = moc_service
self.assertEqual({'attr': 'val'}, res) attributes = rsrc._show_resource()
self.assertEqual({'attr': 'val'}, attributes)