identity/v2 role resource
Change-Id: Ia07f6b091fa752c5dab7e6a5653dfb4b47b34df7
This commit is contained in:
parent
2a72304692
commit
b1cda8e7e2
33
openstack/identity/v2/role.py
Normal file
33
openstack/identity/v2/role.py
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
# 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 Role(resource.Resource):
|
||||||
|
resource_key = 'role'
|
||||||
|
resources_key = 'roles'
|
||||||
|
base_path = '/OS-KSADM/roles'
|
||||||
|
service = identity_service.IdentityService()
|
||||||
|
|
||||||
|
# capabilities
|
||||||
|
allow_create = True
|
||||||
|
allow_retrieve = True
|
||||||
|
allow_update = True
|
||||||
|
allow_delete = True
|
||||||
|
allow_list = True
|
||||||
|
|
||||||
|
# Properties
|
||||||
|
description = resource.prop('description')
|
||||||
|
name = resource.prop('name')
|
||||||
|
enabled = resource.prop('enabled') # API implements as string
|
45
openstack/tests/identity/v2/test_role.py
Normal file
45
openstack/tests/identity/v2/test_role.py
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
# 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.v2 import role
|
||||||
|
|
||||||
|
IDENTIFIER = 'IDENTIFIER'
|
||||||
|
EXAMPLE = {
|
||||||
|
'enabled': 'True',
|
||||||
|
'description': '1',
|
||||||
|
'id': IDENTIFIER,
|
||||||
|
'name': '3',
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class TestRole(testtools.TestCase):
|
||||||
|
|
||||||
|
def test_basic(self):
|
||||||
|
sot = role.Role()
|
||||||
|
self.assertEqual('role', sot.resource_key)
|
||||||
|
self.assertEqual('roles', sot.resources_key)
|
||||||
|
self.assertEqual('/OS-KSADM/roles', 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 = role.Role(EXAMPLE)
|
||||||
|
self.assertEqual(EXAMPLE['enabled'], sot.enabled)
|
||||||
|
self.assertEqual(EXAMPLE['description'], sot.description)
|
||||||
|
self.assertEqual(EXAMPLE['id'], sot.id)
|
||||||
|
self.assertEqual(EXAMPLE['name'], sot.name)
|
Loading…
Reference in New Issue
Block a user