ZhiQiang Fan | 39f9722 | 2013-09-20 04:49:44 +0800 | [diff] [blame] | 1 | # Copyright 2012 OpenStack Foundation |
Jay Pipes | f38eaac | 2012-06-21 13:37:35 -0400 | [diff] [blame] | 2 | # All Rights Reserved. |
| 3 | # |
| 4 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 5 | # not use this file except in compliance with the License. You may obtain |
| 6 | # a copy of the License at |
| 7 | # |
| 8 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | # |
| 10 | # Unless required by applicable law or agreed to in writing, software |
| 11 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 12 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 13 | # License for the specific language governing permissions and limitations |
| 14 | # under the License. |
| 15 | |
Doug Hellmann | 583ce2c | 2015-03-11 14:55:46 +0000 | [diff] [blame] | 16 | from oslo_log import log as logging |
Matthew Treinish | 01472ff | 2015-02-20 17:26:52 -0500 | [diff] [blame] | 17 | from tempest_lib.common.utils import data_utils |
Masayuki Igawa | bfa0760 | 2015-01-20 18:47:17 +0900 | [diff] [blame] | 18 | from tempest_lib import exceptions as lib_exc |
Jay Pipes | f38eaac | 2012-06-21 13:37:35 -0400 | [diff] [blame] | 19 | |
Matthew Treinish | 481466b | 2012-12-20 17:16:01 -0500 | [diff] [blame] | 20 | from tempest import clients |
Andrea Frittoli | 878d5ab | 2015-01-30 13:22:50 +0000 | [diff] [blame] | 21 | from tempest.common import cred_provider |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 22 | from tempest import config |
Attila Fazekas | dc21642 | 2013-01-29 15:12:14 +0100 | [diff] [blame] | 23 | import tempest.test |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 24 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 25 | CONF = config.CONF |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 26 | LOG = logging.getLogger(__name__) |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 27 | |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 28 | |
Attila Fazekas | 0d0c616 | 2013-02-24 09:14:23 +0100 | [diff] [blame] | 29 | class BaseIdentityAdminTest(tempest.test.BaseTestCase): |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 30 | |
| 31 | @classmethod |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 32 | def setup_credentials(cls): |
| 33 | super(BaseIdentityAdminTest, cls).setup_credentials() |
Matthew Treinish | db9721d | 2015-03-18 14:21:28 -0400 | [diff] [blame] | 34 | cls.os = cls.get_client_manager() |
| 35 | cls.os_adm = clients.Manager(cls.isolated_creds.get_admin_creds()) |
Jay Pipes | f38eaac | 2012-06-21 13:37:35 -0400 | [diff] [blame] | 36 | |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 37 | @classmethod |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 38 | def disable_user(cls, user_name): |
| 39 | user = cls.get_user_by_name(user_name) |
| 40 | cls.client.enable_disable_user(user['id'], False) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 41 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 42 | @classmethod |
| 43 | def disable_tenant(cls, tenant_name): |
| 44 | tenant = cls.get_tenant_by_name(tenant_name) |
| 45 | cls.client.update_tenant(tenant['id'], enabled=False) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 46 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 47 | @classmethod |
| 48 | def get_user_by_name(cls, name): |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 49 | users = cls.client.get_users() |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 50 | user = [u for u in users if u['name'] == name] |
| 51 | if len(user) > 0: |
| 52 | return user[0] |
| 53 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 54 | @classmethod |
| 55 | def get_tenant_by_name(cls, name): |
| 56 | try: |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 57 | tenants = cls.client.list_tenants() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 58 | except AttributeError: |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 59 | tenants = cls.client.list_projects() |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 60 | tenant = [t for t in tenants if t['name'] == name] |
| 61 | if len(tenant) > 0: |
| 62 | return tenant[0] |
| 63 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 64 | @classmethod |
| 65 | def get_role_by_name(cls, name): |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 66 | roles = cls.client.list_roles() |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 67 | role = [r for r in roles if r['name'] == name] |
| 68 | if len(role) > 0: |
| 69 | return role[0] |
| 70 | |
| 71 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 72 | class BaseIdentityV2AdminTest(BaseIdentityAdminTest): |
| 73 | |
| 74 | @classmethod |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 75 | def skip_checks(cls): |
| 76 | super(BaseIdentityV2AdminTest, cls).skip_checks() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 77 | if not CONF.identity_feature_enabled.api_v2: |
| 78 | raise cls.skipException("Identity api v2 is not enabled") |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 79 | |
| 80 | @classmethod |
| 81 | def setup_clients(cls): |
| 82 | super(BaseIdentityV2AdminTest, cls).setup_clients() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 83 | cls.client = cls.os_adm.identity_client |
| 84 | cls.token_client = cls.os_adm.token_client |
| 85 | if not cls.client.has_admin_extensions(): |
| 86 | raise cls.skipException("Admin extensions disabled") |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 87 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 88 | cls.non_admin_client = cls.os.identity_client |
| 89 | |
| 90 | @classmethod |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 91 | def resource_setup(cls): |
| 92 | super(BaseIdentityV2AdminTest, cls).resource_setup() |
| 93 | cls.data = DataGenerator(cls.client) |
| 94 | |
| 95 | @classmethod |
Andrea Frittoli | 7688e74 | 2014-09-15 12:38:22 +0100 | [diff] [blame] | 96 | def resource_cleanup(cls): |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 97 | cls.data.teardown_all() |
Andrea Frittoli | 7688e74 | 2014-09-15 12:38:22 +0100 | [diff] [blame] | 98 | super(BaseIdentityV2AdminTest, cls).resource_cleanup() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 99 | |
| 100 | |
| 101 | class BaseIdentityV3AdminTest(BaseIdentityAdminTest): |
| 102 | |
| 103 | @classmethod |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 104 | def skip_checks(cls): |
| 105 | super(BaseIdentityV3AdminTest, cls).skip_checks() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 106 | if not CONF.identity_feature_enabled.api_v3: |
| 107 | raise cls.skipException("Identity api v3 is not enabled") |
Rohan Kanade | b645e17 | 2015-02-05 17:38:59 +0530 | [diff] [blame] | 108 | |
| 109 | @classmethod |
| 110 | def setup_clients(cls): |
| 111 | super(BaseIdentityV3AdminTest, cls).setup_clients() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 112 | cls.client = cls.os_adm.identity_v3_client |
| 113 | cls.token = cls.os_adm.token_v3_client |
| 114 | cls.endpoints_client = cls.os_adm.endpoints_client |
ravikumar-venkatesan | 3052e94 | 2014-05-12 18:25:17 +0000 | [diff] [blame] | 115 | cls.region_client = cls.os_adm.region_client |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 116 | cls.data = DataGenerator(cls.client) |
| 117 | cls.non_admin_client = cls.os.identity_v3_client |
| 118 | cls.service_client = cls.os_adm.service_client |
| 119 | cls.policy_client = cls.os_adm.policy_client |
| 120 | cls.creds_client = cls.os_adm.credentials_client |
| 121 | cls.non_admin_client = cls.os.identity_v3_client |
| 122 | |
| 123 | @classmethod |
Andrea Frittoli | 7688e74 | 2014-09-15 12:38:22 +0100 | [diff] [blame] | 124 | def resource_cleanup(cls): |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 125 | cls.data.teardown_all() |
Andrea Frittoli | 7688e74 | 2014-09-15 12:38:22 +0100 | [diff] [blame] | 126 | super(BaseIdentityV3AdminTest, cls).resource_cleanup() |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 127 | |
David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 128 | @classmethod |
| 129 | def get_user_by_name(cls, name): |
| 130 | users = cls.client.get_users() |
| 131 | user = [u for u in users if u['name'] == name] |
| 132 | if len(user) > 0: |
| 133 | return user[0] |
| 134 | |
| 135 | @classmethod |
| 136 | def get_tenant_by_name(cls, name): |
| 137 | tenants = cls.client.list_projects() |
| 138 | tenant = [t for t in tenants if t['name'] == name] |
| 139 | if len(tenant) > 0: |
| 140 | return tenant[0] |
| 141 | |
| 142 | @classmethod |
| 143 | def get_role_by_name(cls, name): |
| 144 | roles = cls.client.list_roles() |
| 145 | role = [r for r in roles if r['name'] == name] |
| 146 | if len(role) > 0: |
| 147 | return role[0] |
| 148 | |
Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 149 | |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 150 | class DataGenerator(object): |
| 151 | |
| 152 | def __init__(self, client): |
| 153 | self.client = client |
| 154 | self.users = [] |
| 155 | self.tenants = [] |
| 156 | self.roles = [] |
| 157 | self.role_name = None |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 158 | self.v3_users = [] |
| 159 | self.projects = [] |
| 160 | self.v3_roles = [] |
nayna-patel | 2db83b3 | 2014-05-15 11:41:03 +0000 | [diff] [blame] | 161 | self.domains = [] |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 162 | |
Andrea Frittoli | 422fbdf | 2014-03-20 10:05:18 +0000 | [diff] [blame] | 163 | @property |
| 164 | def test_credentials(self): |
Andrea Frittoli | 878d5ab | 2015-01-30 13:22:50 +0000 | [diff] [blame] | 165 | return cred_provider.get_credentials(username=self.test_user, |
| 166 | user_id=self.user['id'], |
| 167 | password=self.test_password, |
| 168 | tenant_name=self.test_tenant, |
| 169 | tenant_id=self.tenant['id']) |
Andrea Frittoli | 422fbdf | 2014-03-20 10:05:18 +0000 | [diff] [blame] | 170 | |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 171 | def setup_test_user(self): |
Sean Dague | f237ccb | 2013-01-04 15:19:14 -0500 | [diff] [blame] | 172 | """Set up a test user.""" |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 173 | self.setup_test_tenant() |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 174 | self.test_user = data_utils.rand_name('test_user_') |
| 175 | self.test_password = data_utils.rand_name('pass_') |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 176 | self.test_email = self.test_user + '@testmail.tm' |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 177 | self.user = self.client.create_user(self.test_user, |
| 178 | self.test_password, |
| 179 | self.tenant['id'], |
| 180 | self.test_email) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 181 | self.users.append(self.user) |
| 182 | |
| 183 | def setup_test_tenant(self): |
Sean Dague | f237ccb | 2013-01-04 15:19:14 -0500 | [diff] [blame] | 184 | """Set up a test tenant.""" |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 185 | self.test_tenant = data_utils.rand_name('test_tenant_') |
| 186 | self.test_description = data_utils.rand_name('desc_') |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 187 | self.tenant = self.client.create_tenant( |
Zhongyue Luo | a1343de | 2013-01-04 16:21:35 +0800 | [diff] [blame] | 188 | name=self.test_tenant, |
| 189 | description=self.test_description) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 190 | self.tenants.append(self.tenant) |
| 191 | |
| 192 | def setup_test_role(self): |
Sean Dague | f237ccb | 2013-01-04 15:19:14 -0500 | [diff] [blame] | 193 | """Set up a test role.""" |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 194 | self.test_role = data_utils.rand_name('role') |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 195 | self.role = self.client.create_role(self.test_role) |
Rohit Karajgi | 69e80a0 | 2012-05-15 03:54:04 -0700 | [diff] [blame] | 196 | self.roles.append(self.role) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 197 | |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 198 | def setup_test_v3_user(self): |
| 199 | """Set up a test v3 user.""" |
| 200 | self.setup_test_project() |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 201 | self.test_user = data_utils.rand_name('test_user_') |
| 202 | self.test_password = data_utils.rand_name('pass_') |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 203 | self.test_email = self.test_user + '@testmail.tm' |
David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 204 | self.v3_user = self.client.create_user( |
wanglianmin | b1ddea7 | 2014-02-25 17:17:30 +0800 | [diff] [blame] | 205 | self.test_user, |
| 206 | password=self.test_password, |
| 207 | project_id=self.project['id'], |
| 208 | email=self.test_email) |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 209 | self.v3_users.append(self.v3_user) |
| 210 | |
| 211 | def setup_test_project(self): |
| 212 | """Set up a test project.""" |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 213 | self.test_project = data_utils.rand_name('test_project_') |
| 214 | self.test_description = data_utils.rand_name('desc_') |
David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 215 | self.project = self.client.create_project( |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 216 | name=self.test_project, |
| 217 | description=self.test_description) |
| 218 | self.projects.append(self.project) |
| 219 | |
| 220 | def setup_test_v3_role(self): |
| 221 | """Set up a test v3 role.""" |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 222 | self.test_role = data_utils.rand_name('role') |
David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 223 | self.v3_role = self.client.create_role(self.test_role) |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 224 | self.v3_roles.append(self.v3_role) |
| 225 | |
nayna-patel | 2db83b3 | 2014-05-15 11:41:03 +0000 | [diff] [blame] | 226 | def setup_test_domain(self): |
| 227 | """Set up a test domain.""" |
| 228 | self.test_domain = data_utils.rand_name('test_domain') |
| 229 | self.test_description = data_utils.rand_name('desc') |
David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 230 | self.domain = self.client.create_domain( |
nayna-patel | 2db83b3 | 2014-05-15 11:41:03 +0000 | [diff] [blame] | 231 | name=self.test_domain, |
| 232 | description=self.test_description) |
| 233 | self.domains.append(self.domain) |
| 234 | |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 235 | @staticmethod |
| 236 | def _try_wrapper(func, item, **kwargs): |
| 237 | try: |
| 238 | if kwargs: |
David Kranz | 9e2ad37 | 2014-10-06 17:06:20 -0400 | [diff] [blame] | 239 | func(item['id'], **kwargs) |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 240 | else: |
| 241 | func(item['id']) |
Masayuki Igawa | bfa0760 | 2015-01-20 18:47:17 +0900 | [diff] [blame] | 242 | except lib_exc.NotFound: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 243 | pass |
| 244 | except Exception: |
| 245 | LOG.exception("Unexpected exception occurred in %s deletion." |
| 246 | " But ignored here." % item['id']) |
| 247 | |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 248 | def teardown_all(self): |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 249 | # NOTE(masayukig): v3 client doesn't have v2 method. |
| 250 | # (e.g. delete_tenant) So we need to check resources existence |
| 251 | # before using client methods. |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 252 | for user in self.users: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 253 | self._try_wrapper(self.client.delete_user, user) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 254 | for tenant in self.tenants: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 255 | self._try_wrapper(self.client.delete_tenant, tenant) |
Rohit Karajgi | 6b1e154 | 2012-05-14 05:55:54 -0700 | [diff] [blame] | 256 | for role in self.roles: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 257 | self._try_wrapper(self.client.delete_role, role) |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 258 | for v3_user in self.v3_users: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 259 | self._try_wrapper(self.client.delete_user, v3_user) |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 260 | for v3_project in self.projects: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 261 | self._try_wrapper(self.client.delete_project, v3_project) |
Nayna Patel | e633136 | 2013-08-12 06:59:48 +0000 | [diff] [blame] | 262 | for v3_role in self.v3_roles: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 263 | self._try_wrapper(self.client.delete_role, v3_role) |
nayna-patel | 2db83b3 | 2014-05-15 11:41:03 +0000 | [diff] [blame] | 264 | for domain in self.domains: |
Masayuki Igawa | 630a3fa | 2014-03-12 19:51:45 +0900 | [diff] [blame] | 265 | self._try_wrapper(self.client.update_domain, domain, |
| 266 | enabled=False) |
| 267 | self._try_wrapper(self.client.delete_domain, domain) |