| # Copyright 2012 OpenStack Foundation |
| # All Rights Reserved. |
| # |
| # 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. |
| |
| from testtools.matchers import Contains |
| |
| from tempest.api.identity import base |
| from tempest.common.utils import data_utils |
| from tempest.test import attr |
| |
| |
| class UsersTestJSON(base.BaseIdentityAdminTest): |
| _interface = 'json' |
| |
| @classmethod |
| def setUpClass(cls): |
| super(UsersTestJSON, cls).setUpClass() |
| cls.alt_user = data_utils.rand_name('test_user_') |
| cls.alt_password = data_utils.rand_name('pass_') |
| cls.alt_email = cls.alt_user + '@testmail.tm' |
| |
| @attr(type='smoke') |
| def test_create_user(self): |
| # Create a user |
| self.data.setup_test_tenant() |
| resp, user = self.client.create_user(self.alt_user, self.alt_password, |
| self.data.tenant['id'], |
| self.alt_email) |
| self.data.users.append(user) |
| self.assertEqual('200', resp['status']) |
| self.assertEqual(self.alt_user, user['name']) |
| |
| @attr(type='smoke') |
| def test_create_user_with_enabled(self): |
| # Create a user with enabled : False |
| self.data.setup_test_tenant() |
| name = data_utils.rand_name('test_user_') |
| resp, user = self.client.create_user(name, self.alt_password, |
| self.data.tenant['id'], |
| self.alt_email, enabled=False) |
| self.data.users.append(user) |
| self.assertEqual('200', resp['status']) |
| self.assertEqual(name, user['name']) |
| self.assertEqual('false', str(user['enabled']).lower()) |
| self.assertEqual(self.alt_email, user['email']) |
| |
| @attr(type='smoke') |
| def test_update_user(self): |
| # Test case to check if updating of user attributes is successful. |
| test_user = data_utils.rand_name('test_user_') |
| self.data.setup_test_tenant() |
| resp, user = self.client.create_user(test_user, self.alt_password, |
| self.data.tenant['id'], |
| self.alt_email) |
| # Delete the User at the end of this method |
| self.addCleanup(self.client.delete_user, user['id']) |
| # Updating user details with new values |
| u_name2 = data_utils.rand_name('user2-') |
| u_email2 = u_name2 + '@testmail.tm' |
| resp, update_user = self.client.update_user(user['id'], name=u_name2, |
| email=u_email2, |
| enabled=False) |
| # Assert response body of update user. |
| self.assertEqual(200, resp.status) |
| self.assertEqual(u_name2, update_user['name']) |
| self.assertEqual(u_email2, update_user['email']) |
| self.assertEqual('false', str(update_user['enabled']).lower()) |
| # GET by id after updating |
| resp, updated_user = self.client.get_user(user['id']) |
| # Assert response body of GET after updating |
| self.assertEqual(u_name2, updated_user['name']) |
| self.assertEqual(u_email2, updated_user['email']) |
| self.assertEqual('false', str(updated_user['enabled']).lower()) |
| |
| @attr(type='smoke') |
| def test_delete_user(self): |
| # Delete a user |
| test_user = data_utils.rand_name('test_user_') |
| self.data.setup_test_tenant() |
| resp, user = self.client.create_user(test_user, self.alt_password, |
| self.data.tenant['id'], |
| self.alt_email) |
| self.assertEqual('200', resp['status']) |
| resp, body = self.client.delete_user(user['id']) |
| self.assertEqual('204', resp['status']) |
| |
| @attr(type='smoke') |
| def test_user_authentication(self): |
| # Valid user's token is authenticated |
| self.data.setup_test_user() |
| # Get a token |
| self.token_client.auth(self.data.test_user, self.data.test_password, |
| self.data.test_tenant) |
| # Re-auth |
| resp, body = self.token_client.auth(self.data.test_user, |
| self.data.test_password, |
| self.data.test_tenant) |
| self.assertEqual('200', resp['status']) |
| |
| @attr(type='gate') |
| def test_authentication_request_without_token(self): |
| # Request for token authentication with a valid token in header |
| self.data.setup_test_user() |
| self.token_client.auth(self.data.test_user, self.data.test_password, |
| self.data.test_tenant) |
| # Get the token of the current client |
| token = self.client.get_auth() |
| # Delete the token from database |
| self.client.delete_token(token) |
| # Re-auth |
| resp, body = self.token_client.auth(self.data.test_user, |
| self.data.test_password, |
| self.data.test_tenant) |
| self.assertEqual('200', resp['status']) |
| self.client.clear_auth() |
| |
| @attr(type='smoke') |
| def test_get_users(self): |
| # Get a list of users and find the test user |
| self.data.setup_test_user() |
| resp, users = self.client.get_users() |
| self.assertThat([u['name'] for u in users], |
| Contains(self.data.test_user), |
| "Could not find %s" % self.data.test_user) |
| |
| @attr(type='gate') |
| def test_list_users_for_tenant(self): |
| # Return a list of all users for a tenant |
| self.data.setup_test_tenant() |
| user_ids = list() |
| fetched_user_ids = list() |
| alt_tenant_user1 = data_utils.rand_name('tenant_user1_') |
| resp, user1 = self.client.create_user(alt_tenant_user1, 'password1', |
| self.data.tenant['id'], |
| 'user1@123') |
| self.assertEqual('200', resp['status']) |
| user_ids.append(user1['id']) |
| self.data.users.append(user1) |
| |
| alt_tenant_user2 = data_utils.rand_name('tenant_user2_') |
| resp, user2 = self.client.create_user(alt_tenant_user2, 'password2', |
| self.data.tenant['id'], |
| 'user2@123') |
| self.assertEqual('200', resp['status']) |
| user_ids.append(user2['id']) |
| self.data.users.append(user2) |
| # List of users for the respective tenant ID |
| resp, body = self.client.list_users_for_tenant(self.data.tenant['id']) |
| self.assertIn(resp['status'], ('200', '203')) |
| for i in body: |
| fetched_user_ids.append(i['id']) |
| # verifying the user Id in the list |
| missing_users =\ |
| [user for user in user_ids if user not in fetched_user_ids] |
| self.assertEqual(0, len(missing_users), |
| "Failed to find user %s in fetched list" % |
| ', '.join(m_user for m_user in missing_users)) |
| |
| @attr(type='gate') |
| def test_list_users_with_roles_for_tenant(self): |
| # Return list of users on tenant when roles are assigned to users |
| self.data.setup_test_user() |
| self.data.setup_test_role() |
| user = self.get_user_by_name(self.data.test_user) |
| tenant = self.get_tenant_by_name(self.data.test_tenant) |
| role = self.get_role_by_name(self.data.test_role) |
| # Assigning roles to two users |
| user_ids = list() |
| fetched_user_ids = list() |
| user_ids.append(user['id']) |
| resp, role = self.client.assign_user_role(tenant['id'], user['id'], |
| role['id']) |
| self.assertEqual('200', resp['status']) |
| |
| alt_user2 = data_utils.rand_name('second_user_') |
| resp, second_user = self.client.create_user(alt_user2, 'password1', |
| self.data.tenant['id'], |
| 'user2@123') |
| self.assertEqual('200', resp['status']) |
| user_ids.append(second_user['id']) |
| self.data.users.append(second_user) |
| resp, role = self.client.assign_user_role(tenant['id'], |
| second_user['id'], |
| role['id']) |
| self.assertEqual('200', resp['status']) |
| # List of users with roles for the respective tenant ID |
| resp, body = self.client.list_users_for_tenant(self.data.tenant['id']) |
| self.assertEqual('200', resp['status']) |
| for i in body: |
| fetched_user_ids.append(i['id']) |
| # verifying the user Id in the list |
| missing_users = [missing_user for missing_user in user_ids |
| if missing_user not in fetched_user_ids] |
| self.assertEqual(0, len(missing_users), |
| "Failed to find user %s in fetched list" % |
| ', '.join(m_user for m_user in missing_users)) |
| |
| |
| class UsersTestXML(UsersTestJSON): |
| _interface = 'xml' |