Merge "identity/v3 user resource"

This commit is contained in:
Jenkins 2014-09-19 17:29:40 +00:00 committed by Gerrit Code Review
commit 406838e70b
2 changed files with 91 additions and 0 deletions

View File

@ -0,0 +1,37 @@
# 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.
from openstack.identity import identity_service
from openstack import resource
class User(resource.Resource):
resource_key = 'user'
resources_key = 'users'
base_path = '/users'
service = identity_service.IdentityService()
# capabilities
allow_create = True
allow_retrieve = True
allow_update = True
allow_delete = True
allow_list = True
# Properties
default_project_id = resource.prop('default_project_id')
description = resource.prop('description')
domain_id = resource.prop('domain_id')
email = resource.prop('email')
enabled = resource.prop('enabled', type=bool)
name = resource.prop('name')
password = resource.prop('password')

View File

@ -0,0 +1,54 @@
# 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 testtools
from openstack.identity.v3 import user
IDENTIFIER = 'IDENTIFIER'
EXAMPLE = {
'default_project_id': '1',
'description': '2',
'domain_id': '3',
'email': '4',
'enabled': True,
'id': IDENTIFIER,
'name': '6',
'password': '7',
}
class TestUser(testtools.TestCase):
def test_basic(self):
sot = user.User()
self.assertEqual('user', sot.resource_key)
self.assertEqual('users', sot.resources_key)
self.assertEqual('/users', sot.base_path)
self.assertEqual('identity', sot.service.service_type)
self.assertTrue(sot.allow_create)
self.assertTrue(sot.allow_retrieve)
self.assertTrue(sot.allow_update)
self.assertTrue(sot.allow_delete)
self.assertTrue(sot.allow_list)
def test_make_it(self):
sot = user.User(EXAMPLE)
self.assertEqual(EXAMPLE['default_project_id'],
sot.default_project_id)
self.assertEqual(EXAMPLE['description'], sot.description)
self.assertEqual(EXAMPLE['domain_id'], sot.domain_id)
self.assertEqual(EXAMPLE['email'], sot.email)
self.assertEqual(EXAMPLE['enabled'], sot.enabled)
self.assertEqual(EXAMPLE['id'], sot.id)
self.assertEqual(EXAMPLE['name'], sot.name)
self.assertEqual(EXAMPLE['password'], sot.password)