| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 1 | # Copyright 2013 OpenStack Foundation |
| 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. |
| ghanshyam | 9507e6b | 2016-09-15 17:34:24 +0900 | [diff] [blame] | 15 | from oslo_serialization import jsonutils as json |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 16 | |
| 17 | from tempest.api.identity import base |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 18 | from tempest import config |
| Ken'ichi Ohmichi | 7bd2575 | 2017-03-10 10:45:39 -0800 | [diff] [blame] | 19 | from tempest.lib.common.utils import data_utils |
| Ken'ichi Ohmichi | eeabdd2 | 2017-01-27 17:46:00 -0800 | [diff] [blame] | 20 | from tempest.lib import decorators |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 21 | |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 22 | CONF = config.CONF |
| 23 | |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 24 | |
| Matthew Treinish | db2c597 | 2014-01-31 22:18:59 +0000 | [diff] [blame] | 25 | class CredentialsTestJSON(base.BaseIdentityV3AdminTest): |
| zhufl | 2392588 | 2020-04-29 08:42:40 +0800 | [diff] [blame] | 26 | """Test keystone credentials""" |
| 27 | |
| mccasland, trevor (tm2086) | c59d113 | 2018-07-11 16:36:04 -0500 | [diff] [blame] | 28 | # NOTE: force_tenant_isolation is true in the base class by default but |
| 29 | # overridden to false here to allow test execution for clouds using the |
| 30 | # pre-provisioned credentials provider. |
| 31 | force_tenant_isolation = False |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 32 | |
| 33 | @classmethod |
| Andrea Frittoli | 7688e74 | 2014-09-15 12:38:22 +0100 | [diff] [blame] | 34 | def resource_setup(cls): |
| 35 | super(CredentialsTestJSON, cls).resource_setup() |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 36 | cls.projects = list() |
| 37 | cls.creds_list = [['project_id', 'user_id', 'id'], |
| 38 | ['access', 'secret']] |
| zhufl | 8e9a073 | 2017-01-26 16:15:21 +0800 | [diff] [blame] | 39 | for _ in range(2): |
| Andrea Frittoli | 7f60fa6 | 2017-09-09 16:31:34 +0200 | [diff] [blame] | 40 | project = cls.projects_client.create_project( |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 41 | data_utils.rand_name( |
| 42 | name='project', prefix=CONF.resource_name_prefix), |
| 43 | description=data_utils.rand_name( |
| 44 | name='project-desc', |
| 45 | prefix=CONF.resource_name_prefix))['project'] |
| Andrea Frittoli | 7f60fa6 | 2017-09-09 16:31:34 +0200 | [diff] [blame] | 46 | cls.addClassResourceCleanup( |
| 47 | cls.projects_client.delete_project, project['id']) |
| 48 | cls.projects.append(project['id']) |
| mccasland, trevor (tm2086) | c59d113 | 2018-07-11 16:36:04 -0500 | [diff] [blame] | 49 | cls.user_body = cls.users_client.show_user( |
| 50 | cls.os_primary.credentials.user_id)['user'] |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 51 | |
| 52 | def _delete_credential(self, cred_id): |
| David Kranz | 2aaf531 | 2014-08-29 09:22:10 -0400 | [diff] [blame] | 53 | self.creds_client.delete_credential(cred_id) |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 54 | |
| Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 55 | @decorators.attr(type='smoke') |
| Ken'ichi Ohmichi | eeabdd2 | 2017-01-27 17:46:00 -0800 | [diff] [blame] | 56 | @decorators.idempotent_id('7cd59bf9-bda4-4c72-9467-d21cab278355') |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 57 | def test_credentials_create_get_update_delete(self): |
| zhufl | 2392588 | 2020-04-29 08:42:40 +0800 | [diff] [blame] | 58 | """Test creating, getting, updating, deleting of credentials""" |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 59 | prefix = CONF.resource_name_prefix |
| Yaroslav Lobankov | 17e8c85 | 2015-11-09 14:03:50 +0300 | [diff] [blame] | 60 | blob = '{"access": "%s", "secret": "%s"}' % ( |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 61 | data_utils.rand_name(name='Access', prefix=prefix), |
| 62 | data_utils.rand_name(name='Secret', prefix=prefix)) |
| David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 63 | cred = self.creds_client.create_credential( |
| Yaroslav Lobankov | 17e8c85 | 2015-11-09 14:03:50 +0300 | [diff] [blame] | 64 | user_id=self.user_body['id'], project_id=self.projects[0], |
| 65 | blob=blob, type='ec2')['credential'] |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 66 | self.addCleanup(self._delete_credential, cred['id']) |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 67 | for value1 in self.creds_list[0]: |
| 68 | self.assertIn(value1, cred) |
| 69 | for value2 in self.creds_list[1]: |
| 70 | self.assertIn(value2, cred['blob']) |
| 71 | |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 72 | new_keys = [data_utils.rand_name(name='NewAccess', prefix=prefix), |
| 73 | data_utils.rand_name(name='NewSecret', prefix=prefix)] |
| Yaroslav Lobankov | 17e8c85 | 2015-11-09 14:03:50 +0300 | [diff] [blame] | 74 | blob = '{"access": "%s", "secret": "%s"}' % (new_keys[0], new_keys[1]) |
| David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 75 | update_body = self.creds_client.update_credential( |
| Yaroslav Lobankov | 17e8c85 | 2015-11-09 14:03:50 +0300 | [diff] [blame] | 76 | cred['id'], blob=blob, project_id=self.projects[1], |
| 77 | type='ec2')['credential'] |
| ghanshyam | 9507e6b | 2016-09-15 17:34:24 +0900 | [diff] [blame] | 78 | update_body['blob'] = json.loads(update_body['blob']) |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 79 | self.assertEqual(cred['id'], update_body['id']) |
| 80 | self.assertEqual(self.projects[1], update_body['project_id']) |
| 81 | self.assertEqual(self.user_body['id'], update_body['user_id']) |
| 82 | self.assertEqual(update_body['blob']['access'], new_keys[0]) |
| 83 | self.assertEqual(update_body['blob']['secret'], new_keys[1]) |
| 84 | |
| lei zhang | f7169e2 | 2015-11-28 22:51:36 +0800 | [diff] [blame] | 85 | get_body = self.creds_client.show_credential(cred['id'])['credential'] |
| ghanshyam | 9507e6b | 2016-09-15 17:34:24 +0900 | [diff] [blame] | 86 | get_body['blob'] = json.loads(get_body['blob']) |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 87 | for value1 in self.creds_list[0]: |
| 88 | self.assertEqual(update_body[value1], |
| 89 | get_body[value1]) |
| 90 | for value2 in self.creds_list[1]: |
| 91 | self.assertEqual(update_body['blob'][value2], |
| 92 | get_body['blob'][value2]) |
| 93 | |
| Ken'ichi Ohmichi | eeabdd2 | 2017-01-27 17:46:00 -0800 | [diff] [blame] | 94 | @decorators.idempotent_id('13202c00-0021-42a1-88d4-81b44d448aab') |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 95 | def test_credentials_list_delete(self): |
| zhufl | 2392588 | 2020-04-29 08:42:40 +0800 | [diff] [blame] | 96 | """Test listing credentials""" |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 97 | created_cred_ids = list() |
| 98 | fetched_cred_ids = list() |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 99 | prefix = CONF.resource_name_prefix |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 100 | |
| zhufl | 8e9a073 | 2017-01-26 16:15:21 +0800 | [diff] [blame] | 101 | for _ in range(2): |
| Yaroslav Lobankov | 17e8c85 | 2015-11-09 14:03:50 +0300 | [diff] [blame] | 102 | blob = '{"access": "%s", "secret": "%s"}' % ( |
| Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 103 | data_utils.rand_name(name='Access', prefix=prefix), |
| 104 | data_utils.rand_name(name='Secret', prefix=prefix)) |
| David Kranz | d8ccb79 | 2014-12-29 11:32:05 -0500 | [diff] [blame] | 105 | cred = self.creds_client.create_credential( |
| Yaroslav Lobankov | 17e8c85 | 2015-11-09 14:03:50 +0300 | [diff] [blame] | 106 | user_id=self.user_body['id'], project_id=self.projects[0], |
| 107 | blob=blob, type='ec2')['credential'] |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 108 | created_cred_ids.append(cred['id']) |
| 109 | self.addCleanup(self._delete_credential, cred['id']) |
| 110 | |
| John Warren | f3ac5cc | 2015-08-10 18:06:43 +0000 | [diff] [blame] | 111 | creds = self.creds_client.list_credentials()['credentials'] |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 112 | |
| 113 | for i in creds: |
| 114 | fetched_cred_ids.append(i['id']) |
| 115 | missing_creds = [c for c in created_cred_ids |
| 116 | if c not in fetched_cred_ids] |
| Masayuki Igawa | f9009b4 | 2017-04-10 14:49:29 +0900 | [diff] [blame] | 117 | self.assertEmpty(missing_creds, |
| nayna-patel | 914b471 | 2013-07-16 08:29:05 +0000 | [diff] [blame] | 118 | "Failed to find cred %s in fetched list" % |
| DennyZhang | b432bac | 2013-09-17 16:24:12 +0000 | [diff] [blame] | 119 | ', '.join(m_cred for m_cred in missing_creds)) |