blob: bfbcfe7678823b925915fe95dda44eb6e3e4a773 [file] [log] [blame]
ZhiQiang Fan39f97222013-09-20 04:49:44 +08001# Copyright 2012 OpenStack Foundation
Jay Pipesf38eaac2012-06-21 13:37:35 -04002# 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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090016from testtools import matchers
Sean Dague1937d092013-05-17 16:36:38 -040017
18from tempest.api.identity import base
Fei Long Wangd39431f2015-05-14 11:30:48 +120019from tempest.common.utils import data_utils
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090020from tempest import test
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070021
22
Matthew Treinishdb2c5972014-01-31 22:18:59 +000023class UsersTestJSON(base.BaseIdentityV2AdminTest):
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070024
Adalberto Medeiros081464b2013-08-16 09:41:29 -040025 @classmethod
Andrea Frittoli7688e742014-09-15 12:38:22 +010026 def resource_setup(cls):
27 super(UsersTestJSON, cls).resource_setup()
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +000028 cls.alt_user = data_utils.rand_name('test_user')
29 cls.alt_password = data_utils.rand_name('pass')
Adalberto Medeiros081464b2013-08-16 09:41:29 -040030 cls.alt_email = cls.alt_user + '@testmail.tm'
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070031
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090032 @test.attr(type='smoke')
Chris Hoge7579c1a2015-02-26 14:12:15 -080033 @test.idempotent_id('2d55a71e-da1d-4b43-9c03-d269fd93d905')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070034 def test_create_user(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -050035 # Create a user
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070036 self.data.setup_test_tenant()
David Kranzb7afa922014-12-30 10:56:26 -050037 user = self.client.create_user(self.alt_user, self.alt_password,
38 self.data.tenant['id'],
39 self.alt_email)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070040 self.data.users.append(user)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070041 self.assertEqual(self.alt_user, user['name'])
42
Chris Hoge7579c1a2015-02-26 14:12:15 -080043 @test.idempotent_id('89d9fdb8-15c2-4304-a429-48715d0af33d')
huangtianhuafc8db4f2013-10-08 12:05:58 +080044 def test_create_user_with_enabled(self):
45 # Create a user with enabled : False
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070046 self.data.setup_test_tenant()
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +000047 name = data_utils.rand_name('test_user')
David Kranzb7afa922014-12-30 10:56:26 -050048 user = self.client.create_user(name, self.alt_password,
49 self.data.tenant['id'],
50 self.alt_email, enabled=False)
huangtianhuafc8db4f2013-10-08 12:05:58 +080051 self.data.users.append(user)
huangtianhuafc8db4f2013-10-08 12:05:58 +080052 self.assertEqual(name, user['name'])
Ken'ichi Ohmichi73cb70b2015-04-17 02:31:12 +000053 self.assertEqual(False, user['enabled'])
huangtianhuafc8db4f2013-10-08 12:05:58 +080054 self.assertEqual(self.alt_email, user['email'])
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070055
Chris Hoge7579c1a2015-02-26 14:12:15 -080056 @test.idempotent_id('39d05857-e8a5-4ed4-ba83-0b52d3ab97ee')
Chang Bo Guob36b2f12013-09-13 04:52:00 -070057 def test_update_user(self):
58 # Test case to check if updating of user attributes is successful.
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +000059 test_user = data_utils.rand_name('test_user')
Chang Bo Guob36b2f12013-09-13 04:52:00 -070060 self.data.setup_test_tenant()
David Kranzb7afa922014-12-30 10:56:26 -050061 user = self.client.create_user(test_user, self.alt_password,
62 self.data.tenant['id'],
63 self.alt_email)
Chang Bo Guob36b2f12013-09-13 04:52:00 -070064 # Delete the User at the end of this method
65 self.addCleanup(self.client.delete_user, user['id'])
66 # Updating user details with new values
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +000067 u_name2 = data_utils.rand_name('user2')
Chang Bo Guob36b2f12013-09-13 04:52:00 -070068 u_email2 = u_name2 + '@testmail.tm'
David Kranzb7afa922014-12-30 10:56:26 -050069 update_user = self.client.update_user(user['id'], name=u_name2,
70 email=u_email2,
71 enabled=False)
Chang Bo Guob36b2f12013-09-13 04:52:00 -070072 self.assertEqual(u_name2, update_user['name'])
73 self.assertEqual(u_email2, update_user['email'])
Ken'ichi Ohmichi73cb70b2015-04-17 02:31:12 +000074 self.assertEqual(False, update_user['enabled'])
Chang Bo Guob36b2f12013-09-13 04:52:00 -070075 # GET by id after updating
David Kranzb7afa922014-12-30 10:56:26 -050076 updated_user = self.client.get_user(user['id'])
Chang Bo Guob36b2f12013-09-13 04:52:00 -070077 # Assert response body of GET after updating
78 self.assertEqual(u_name2, updated_user['name'])
79 self.assertEqual(u_email2, updated_user['email'])
Ken'ichi Ohmichi73cb70b2015-04-17 02:31:12 +000080 self.assertEqual(False, update_user['enabled'])
Chang Bo Guob36b2f12013-09-13 04:52:00 -070081
Chris Hoge7579c1a2015-02-26 14:12:15 -080082 @test.idempotent_id('29ed26f4-a74e-4425-9a85-fdb49fa269d2')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070083 def test_delete_user(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -050084 # Delete a user
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +000085 test_user = data_utils.rand_name('test_user')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070086 self.data.setup_test_tenant()
David Kranzb7afa922014-12-30 10:56:26 -050087 user = self.client.create_user(test_user, self.alt_password,
88 self.data.tenant['id'],
89 self.alt_email)
David Kranze9d2f422014-07-02 13:57:41 -040090 self.client.delete_user(user['id'])
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070091
Chris Hoge7579c1a2015-02-26 14:12:15 -080092 @test.idempotent_id('aca696c3-d645-4f45-b728-63646045beb1')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070093 def test_user_authentication(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -050094 # Valid user's token is authenticated
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070095 self.data.setup_test_user()
96 # Get a token
97 self.token_client.auth(self.data.test_user, self.data.test_password,
Zhongyue Luo79d8d362012-09-25 13:49:27 +080098 self.data.test_tenant)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070099 # Re-auth
David Kranzfb3efa72014-08-28 16:58:25 -0400100 self.token_client.auth(self.data.test_user,
101 self.data.test_password,
102 self.data.test_tenant)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700103
Chris Hoge7579c1a2015-02-26 14:12:15 -0800104 @test.idempotent_id('5d1fa498-4c2d-4732-a8fe-2b054598cfdd')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700105 def test_authentication_request_without_token(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -0500106 # Request for token authentication with a valid token in header
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700107 self.data.setup_test_user()
108 self.token_client.auth(self.data.test_user, self.data.test_password,
109 self.data.test_tenant)
110 # Get the token of the current client
Andrea Frittoli8bbdb162014-01-06 11:06:13 +0000111 token = self.client.auth_provider.get_token()
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700112 # Delete the token from database
113 self.client.delete_token(token)
114 # Re-auth
David Kranzfb3efa72014-08-28 16:58:25 -0400115 self.token_client.auth(self.data.test_user,
116 self.data.test_password,
117 self.data.test_tenant)
Andrea Frittoli8bbdb162014-01-06 11:06:13 +0000118 self.client.auth_provider.clear_auth()
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700119
Chris Hoge7579c1a2015-02-26 14:12:15 -0800120 @test.idempotent_id('a149c02e-e5e0-4b89-809e-7e8faf33ccda')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700121 def test_get_users(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -0500122 # Get a list of users and find the test user
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700123 self.data.setup_test_user()
David Kranzb7afa922014-12-30 10:56:26 -0500124 users = self.client.get_users()
ivan-zhu1feeb382013-01-24 10:14:39 +0800125 self.assertThat([u['name'] for u in users],
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900126 matchers.Contains(self.data.test_user),
ivan-zhu1feeb382013-01-24 10:14:39 +0800127 "Could not find %s" % self.data.test_user)
Rohit Karajgi6b1e1542012-05-14 05:55:54 -0700128
Chris Hoge7579c1a2015-02-26 14:12:15 -0800129 @test.idempotent_id('6e317209-383a-4bed-9f10-075b7c82c79a')
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530130 def test_list_users_for_tenant(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -0500131 # Return a list of all users for a tenant
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530132 self.data.setup_test_tenant()
133 user_ids = list()
134 fetched_user_ids = list()
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +0000135 alt_tenant_user1 = data_utils.rand_name('tenant_user1')
David Kranzb7afa922014-12-30 10:56:26 -0500136 user1 = self.client.create_user(alt_tenant_user1, 'password1',
137 self.data.tenant['id'],
138 'user1@123')
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530139 user_ids.append(user1['id'])
140 self.data.users.append(user1)
Adalberto Medeiros081464b2013-08-16 09:41:29 -0400141
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +0000142 alt_tenant_user2 = data_utils.rand_name('tenant_user2')
David Kranzb7afa922014-12-30 10:56:26 -0500143 user2 = self.client.create_user(alt_tenant_user2, 'password2',
144 self.data.tenant['id'],
145 'user2@123')
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530146 user_ids.append(user2['id'])
147 self.data.users.append(user2)
Attila Fazekasf7f34f92013-08-01 17:01:44 +0200148 # List of users for the respective tenant ID
David Kranzb7afa922014-12-30 10:56:26 -0500149 body = self.client.list_users_for_tenant(self.data.tenant['id'])
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530150 for i in body:
151 fetched_user_ids.append(i['id'])
Attila Fazekasf7f34f92013-08-01 17:01:44 +0200152 # verifying the user Id in the list
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530153 missing_users =\
154 [user for user in user_ids if user not in fetched_user_ids]
155 self.assertEqual(0, len(missing_users),
Zhongyue Luoe0884a32012-09-25 17:24:17 +0800156 "Failed to find user %s in fetched list" %
157 ', '.join(m_user for m_user in missing_users))
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530158
Chris Hoge7579c1a2015-02-26 14:12:15 -0800159 @test.idempotent_id('a8b54974-40e1-41c0-b812-50fc90827971')
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530160 def test_list_users_with_roles_for_tenant(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -0500161 # Return list of users on tenant when roles are assigned to users
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530162 self.data.setup_test_user()
163 self.data.setup_test_role()
164 user = self.get_user_by_name(self.data.test_user)
165 tenant = self.get_tenant_by_name(self.data.test_tenant)
166 role = self.get_role_by_name(self.data.test_role)
Attila Fazekasf7f34f92013-08-01 17:01:44 +0200167 # Assigning roles to two users
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530168 user_ids = list()
169 fetched_user_ids = list()
170 user_ids.append(user['id'])
David Kranzb7afa922014-12-30 10:56:26 -0500171 role = self.client.assign_user_role(tenant['id'], user['id'],
172 role['id'])
Adalberto Medeiros081464b2013-08-16 09:41:29 -0400173
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +0000174 alt_user2 = data_utils.rand_name('second_user')
David Kranzb7afa922014-12-30 10:56:26 -0500175 second_user = self.client.create_user(alt_user2, 'password1',
176 self.data.tenant['id'],
177 'user2@123')
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530178 user_ids.append(second_user['id'])
179 self.data.users.append(second_user)
David Kranzb7afa922014-12-30 10:56:26 -0500180 role = self.client.assign_user_role(tenant['id'],
181 second_user['id'],
182 role['id'])
Attila Fazekasf7f34f92013-08-01 17:01:44 +0200183 # List of users with roles for the respective tenant ID
David Kranzb7afa922014-12-30 10:56:26 -0500184 body = self.client.list_users_for_tenant(self.data.tenant['id'])
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530185 for i in body:
186 fetched_user_ids.append(i['id'])
Attila Fazekasf7f34f92013-08-01 17:01:44 +0200187 # verifying the user Id in the list
Monty Taylorb2ca5ca2013-04-28 18:00:21 -0700188 missing_users = [missing_user for missing_user in user_ids
189 if missing_user not in fetched_user_ids]
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530190 self.assertEqual(0, len(missing_users),
Zhongyue Luoe0884a32012-09-25 17:24:17 +0800191 "Failed to find user %s in fetched list" %
192 ', '.join(m_user for m_user in missing_users))
rajalakshmi-ganesanefc8bd72012-05-30 17:52:11 +0530193
Chris Hoge7579c1a2015-02-26 14:12:15 -0800194 @test.idempotent_id('1aeb25ac-6ec5-4d8b-97cb-7ac3567a989f')
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530195 def test_update_user_password(self):
196 # Test case to check if updating of user password is successful.
197 self.data.setup_test_user()
198 # Updating the user with new password
Ken'ichi Ohmichi96508472015-03-23 01:43:42 +0000199 new_pass = data_utils.rand_name('pass')
David Kranzb7afa922014-12-30 10:56:26 -0500200 update_user = self.client.update_user_password(
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530201 self.data.user['id'], new_pass)
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530202 self.assertEqual(update_user['id'], self.data.user['id'])
203
204 # Validate the updated password
205 # Get a token
David Kranzb7afa922014-12-30 10:56:26 -0500206 body = self.token_client.auth(self.data.test_user, new_pass,
207 self.data.test_tenant)
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530208 self.assertTrue('id' in body['token'])