Merge "Add attributes schema for OS::Keystone::User"

This commit is contained in:
Jenkins 2017-03-21 12:45:35 +00:00 committed by Gerrit Code Review
commit 30e6359517
3 changed files with 69 additions and 2 deletions

View File

@ -288,7 +288,7 @@ def format_resource_attributes(resource, with_attr=None):
return resolver._resolver(attr) return resolver._resolver(attr)
except Exception: except Exception:
return None return None
# if 'show' in attribute_schema, will resolve all attributes of resource # if 'show' in attributes_schema, will resolve all attributes of resource
# including the ones are not represented in response of show API, such as # including the ones are not represented in response of show API, such as
# 'console_urls' for nova server, user can view it by taking with_attr # 'console_urls' for nova server, user can view it by taking with_attr
# parameter # parameter

View File

@ -12,6 +12,7 @@
# under the License. # under the License.
from heat.common.i18n import _ from heat.common.i18n import _
from heat.engine import attributes
from heat.engine import constraints from heat.engine import constraints
from heat.engine import properties from heat.engine import properties
from heat.engine import resource from heat.engine import resource
@ -101,6 +102,41 @@ class KeystoneUser(resource.Resource,
properties_schema.update( properties_schema.update(
role_assignments.KeystoneRoleAssignmentMixin.mixin_properties_schema) role_assignments.KeystoneRoleAssignmentMixin.mixin_properties_schema)
ATTRIBUTES = (
NAME_ATTR, DEFAULT_PROJECT_ATTR, DOMAIN_ATTR, ENABLED_ATTR,
PASSWORD_EXPIRES_AT_ATTR
) = (
'name', 'default_project_id', 'domain_id',
'enabled', 'password_expires_at'
)
attributes_schema = {
NAME_ATTR: attributes.Schema(
_('User name.'),
support_status=support.SupportStatus(version='9.0.0'),
type=attributes.Schema.STRING
),
DEFAULT_PROJECT_ATTR: attributes.Schema(
_('Default project id for user.'),
support_status=support.SupportStatus(version='9.0.0'),
type=attributes.Schema.STRING
),
DOMAIN_ATTR: attributes.Schema(
_('Domain id for user.'),
support_status=support.SupportStatus(version='9.0.0'),
type=attributes.Schema.STRING
),
ENABLED_ATTR: attributes.Schema(
_('Flag of enable user.'),
support_status=support.SupportStatus(version='9.0.0'),
type=attributes.Schema.BOOLEAN
),
PASSWORD_EXPIRES_AT_ATTR: attributes.Schema(
_('Show user password expiration time.'),
support_status=support.SupportStatus(version='9.0.0'),
type=attributes.Schema.STRING
),
}
def translation_rules(self, properties): def translation_rules(self, properties):
return [ return [
translation.TranslationRule( translation.TranslationRule(
@ -188,6 +224,12 @@ class KeystoneUser(resource.Resource,
return new_group_ids, removed_group_ids return new_group_ids, removed_group_ids
def _resolve_attribute(self, name):
if self.resource_id is None:
return
user = self.client().users.get(self.resource_id)
return getattr(user, name, None)
def handle_create(self): def handle_create(self):
user_name = (self.properties[self.NAME] or user_name = (self.properties[self.NAME] or
self.physical_resource_name()) self.physical_resource_name())

View File

@ -83,12 +83,17 @@ class KeystoneUserTest(common.HeatTestCase):
value = mock.MagicMock() value = mock.MagicMock()
user_id = '477e8273-60a7-4c41-b683-fdb0bc7cd151' user_id = '477e8273-60a7-4c41-b683-fdb0bc7cd151'
value.id = user_id value.id = user_id
value.name = 'test_user_1'
value.default_project_id = 'project_1'
value.domain_id = 'default'
value.enabled = True
value.password_expires_at = '2016-12-10T17:28:49.000000'
return value return value
def test_user_handle_create(self): def test_user_handle_create(self):
mock_user = self._get_mock_user() mock_user = self._get_mock_user()
self.users.create.return_value = mock_user self.users.create.return_value = mock_user
self.users.get.return_value = mock_user
self.users.add_to_group = mock.MagicMock() self.users.add_to_group = mock.MagicMock()
# validate the properties # validate the properties
@ -316,3 +321,23 @@ class KeystoneUserTest(common.HeatTestCase):
self.assertEqual(set(expected.keys()), set(reality.keys())) self.assertEqual(set(expected.keys()), set(reality.keys()))
for key in expected: for key in expected:
self.assertEqual(expected[key], reality[key]) self.assertEqual(expected[key], reality[key])
def test_resolve_attributes(self):
mock_user = self._get_mock_user()
self.test_user.resource_id = mock_user['id']
self.users.get.return_value = mock_user
self.assertEqual(
mock_user.name,
self.test_user._resolve_attribute('name'))
self.assertEqual(
mock_user.default_project_id,
self.test_user._resolve_attribute('default_project_id'))
self.assertEqual(
mock_user.domain_id,
self.test_user._resolve_attribute('domain_id'))
self.assertEqual(
mock_user.enabled,
self.test_user._resolve_attribute('enabled'))
self.assertEqual(
mock_user.password_expires_at,
self.test_user._resolve_attribute('password_expires_at'))