blob: 66a1737a93965f6562b687682412fd0c6b2cd0a9 [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
Masayuki Igawaa2ccca02013-09-17 15:32:46 +090019from 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):
Attila Fazekas0d0c6162013-02-24 09:14:23 +010024 _interface = 'json'
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070025
Adalberto Medeiros081464b2013-08-16 09:41:29 -040026 @classmethod
Andrea Frittoli7688e742014-09-15 12:38:22 +010027 def resource_setup(cls):
28 super(UsersTestJSON, cls).resource_setup()
Masayuki Igawaa2ccca02013-09-17 15:32:46 +090029 cls.alt_user = data_utils.rand_name('test_user_')
30 cls.alt_password = data_utils.rand_name('pass_')
Adalberto Medeiros081464b2013-08-16 09:41:29 -040031 cls.alt_email = cls.alt_user + '@testmail.tm'
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070032
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090033 @test.attr(type='smoke')
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 Kranze9d2f422014-07-02 13:57:41 -040037 _, 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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090043 @test.attr(type='smoke')
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()
Masayuki Igawaa2ccca02013-09-17 15:32:46 +090047 name = data_utils.rand_name('test_user_')
David Kranze9d2f422014-07-02 13:57:41 -040048 _, 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'])
53 self.assertEqual('false', str(user['enabled']).lower())
54 self.assertEqual(self.alt_email, user['email'])
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070055
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090056 @test.attr(type='smoke')
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.
Masayuki Igawaa2ccca02013-09-17 15:32:46 +090059 test_user = data_utils.rand_name('test_user_')
Chang Bo Guob36b2f12013-09-13 04:52:00 -070060 self.data.setup_test_tenant()
David Kranze9d2f422014-07-02 13:57:41 -040061 _, 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
Masayuki Igawaa2ccca02013-09-17 15:32:46 +090067 u_name2 = data_utils.rand_name('user2-')
Chang Bo Guob36b2f12013-09-13 04:52:00 -070068 u_email2 = u_name2 + '@testmail.tm'
David Kranze9d2f422014-07-02 13:57:41 -040069 _, 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'])
74 self.assertEqual('false', str(update_user['enabled']).lower())
75 # GET by id after updating
David Kranze9d2f422014-07-02 13:57:41 -040076 _, 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'])
80 self.assertEqual('false', str(updated_user['enabled']).lower())
81
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090082 @test.attr(type='smoke')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070083 def test_delete_user(self):
Sean Dague46c4a2b2013-01-03 17:54:17 -050084 # Delete a user
Masayuki Igawaa2ccca02013-09-17 15:32:46 +090085 test_user = data_utils.rand_name('test_user_')
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070086 self.data.setup_test_tenant()
David Kranze9d2f422014-07-02 13:57:41 -040087 _, user = self.client.create_user(test_user, self.alt_password,
88 self.data.tenant['id'],
89 self.alt_email)
90 self.client.delete_user(user['id'])
Rohit Karajgi6b1e1542012-05-14 05:55:54 -070091
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090092 @test.attr(type='smoke')
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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900104 @test.attr(type='gate')
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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900120 @test.attr(type='smoke')
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 Kranze9d2f422014-07-02 13:57:41 -0400124 _, 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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900129 @test.attr(type='gate')
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()
Masayuki Igawaa2ccca02013-09-17 15:32:46 +0900135 alt_tenant_user1 = data_utils.rand_name('tenant_user1_')
David Kranze9d2f422014-07-02 13:57:41 -0400136 _, 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
Masayuki Igawaa2ccca02013-09-17 15:32:46 +0900142 alt_tenant_user2 = data_utils.rand_name('tenant_user2_')
David Kranze9d2f422014-07-02 13:57:41 -0400143 _, 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 Kranze9d2f422014-07-02 13:57:41 -0400149 _, 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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900159 @test.attr(type='gate')
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 Kranze9d2f422014-07-02 13:57:41 -0400171 _, role = self.client.assign_user_role(tenant['id'], user['id'],
172 role['id'])
Adalberto Medeiros081464b2013-08-16 09:41:29 -0400173
Masayuki Igawaa2ccca02013-09-17 15:32:46 +0900174 alt_user2 = data_utils.rand_name('second_user_')
David Kranze9d2f422014-07-02 13:57:41 -0400175 _, 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 Kranze9d2f422014-07-02 13:57:41 -0400180 _, 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 Kranze9d2f422014-07-02 13:57:41 -0400184 _, 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
Abhijeet.Jainff5c3542014-05-06 16:07:30 +0530194 @test.attr(type='smoke')
195 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
199 new_pass = data_utils.rand_name('pass-')
David Kranze9d2f422014-07-02 13:57:41 -0400200 _, 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 Kranzfb3efa72014-08-28 16:58:25 -0400206 _, 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'])
209
Vincent Hou6b8a7b72012-08-25 01:24:33 +0800210
Attila Fazekas0d0c6162013-02-24 09:14:23 +0100211class UsersTestXML(UsersTestJSON):
212 _interface = 'xml'