diff options
author | Nisha Yadav <ynisha11@gmail.com> | 2016-07-05 00:01:26 +0530 |
---|---|---|
committer | Nisha Yadav <ynisha11@gmail.com> | 2016-07-06 05:03:42 +0000 |
commit | f461dab938ff311f1399b38b3681d949b325fc67 (patch) | |
tree | 7030cd528fd35208519f4c85846dd2acf73218d6 | |
parent | 339cd20ee7df43d802c77eacd8b1bbe2ccb1bf12 (diff) | |
download | python-keystoneclient-f461dab938ff311f1399b38b3681d949b325fc67.tar.gz |
Add service functional tests
Adds functional tests for services.
Change-Id: Ied0ad0455799072d1e283024f12ea83e5603bce6
-rw-r--r-- | keystoneclient/tests/functional/v3/client_fixtures.py | 40 | ||||
-rw-r--r-- | keystoneclient/tests/functional/v3/test_services.py | 106 |
2 files changed, 146 insertions, 0 deletions
diff --git a/keystoneclient/tests/functional/v3/client_fixtures.py b/keystoneclient/tests/functional/v3/client_fixtures.py index 9467643..dbf24ab 100644 --- a/keystoneclient/tests/functional/v3/client_fixtures.py +++ b/keystoneclient/tests/functional/v3/client_fixtures.py @@ -67,3 +67,43 @@ class Domain(Base): # Only disabled domains can be deleted self.addCleanup(self.client.domains.delete, self.entity) self.addCleanup(self.client.domains.update, self.entity, enabled=False) + + +class Project(Base): + + def __init__(self, client, domain_id=None, parent=None): + super(Project, self).__init__(client, domain_id) + self.parent = parent + + def setUp(self): + super(Project, self).setUp() + + self.ref = {'name': RESOURCE_NAME_PREFIX + uuid.uuid4().hex, + 'domain': self.domain_id, + 'enabled': True, + 'parent': self.parent} + self.entity = self.client.projects.create(**self.ref) + self.addCleanup(self.client.projects.delete, self.entity) + + +class Role(Base): + + def setUp(self): + super(Role, self).setUp() + + self.ref = {'name': RESOURCE_NAME_PREFIX + uuid.uuid4().hex} + self.entity = self.client.roles.create(**self.ref) + self.addCleanup(self.client.roles.delete, self.entity) + + +class Service(Base): + + def setUp(self): + super(Service, self).setUp() + + self.ref = {'name': RESOURCE_NAME_PREFIX + uuid.uuid4().hex, + 'type': uuid.uuid4().hex, + 'enabled': True, + 'description': uuid.uuid4().hex} + self.entity = self.client.services.create(**self.ref) + self.addCleanup(self.client.services.delete, self.entity) diff --git a/keystoneclient/tests/functional/v3/test_services.py b/keystoneclient/tests/functional/v3/test_services.py new file mode 100644 index 0000000..c17747d --- /dev/null +++ b/keystoneclient/tests/functional/v3/test_services.py @@ -0,0 +1,106 @@ +# 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 uuid + +from keystoneauth1.exceptions import http + +from keystoneclient.tests.functional import base +from keystoneclient.tests.functional.v3 import client_fixtures as fixtures + + +class ServicesTestCase(base.V3ClientTestCase): + + def check_service(self, service, service_ref=None): + self.assertIsNotNone(service.id) + self.assertIn('self', service.links) + self.assertIn('/services/' + service.id, service.links['self']) + + if service_ref: + self.assertEqual(service_ref['name'], service.name) + self.assertEqual(service_ref['enabled'], service.enabled) + self.assertEqual(service_ref['type'], service.type) + + # There is no guarantee description is present in service + if hasattr(service_ref, 'description'): + self.assertEqual(service_ref['description'], + service.description) + + else: + # Only check remaining mandatory attributes + self.assertIsNotNone(service.name) + self.assertIsNotNone(service.enabled) + self.assertIsNotNone(service.type) + + def test_create_service(self): + service_ref = { + 'name': fixtures.RESOURCE_NAME_PREFIX + uuid.uuid4().hex, + 'type': uuid.uuid4().hex, + 'enabled': True, + 'description': uuid.uuid4().hex} + + service = self.client.services.create(**service_ref) + + self.addCleanup(self.client.services.delete, service) + self.check_service(service, service_ref) + + def test_get_service(self): + service = fixtures.Service(self.client) + self.useFixture(service) + + service_ret = self.client.services.get(service.id) + self.check_service(service_ret, service.ref) + + def test_list_services(self): + service_one = fixtures.Service(self.client) + self.useFixture(service_one) + + service_two = fixtures.Service(self.client) + self.useFixture(service_two) + + services = self.client.services.list() + + # All services are valid + for service in services: + self.check_service(service) + + self.assertIn(service_one.entity, services) + self.assertIn(service_two.entity, services) + + def test_update_service(self): + service = fixtures.Service(self.client) + self.useFixture(service) + + new_name = fixtures.RESOURCE_NAME_PREFIX + uuid.uuid4().hex + new_type = uuid.uuid4().hex + new_enabled = False + new_description = uuid.uuid4().hex + + service_ret = self.client.services.update(service.id, + name=new_name, + type=new_type, + enabled=new_enabled, + description=new_description) + + service.ref.update({'name': new_name, 'type': new_type, + 'enabled': new_enabled, + 'description': new_description}) + self.check_service(service_ret, service.ref) + + def test_delete_service(self): + service = self.client.services.create(name=uuid.uuid4().hex, + type=uuid.uuid4().hex) + + self.client.services.delete(service.id) + self.assertRaises(http.NotFound, + self.client.services.get, + service.id) |