Merge "Define 4 identity v2 clients as libraries"

This commit is contained in:
Jenkins 2016-06-29 04:09:41 +00:00 committed by Gerrit Code Review
commit 330f11dd91
14 changed files with 844 additions and 12 deletions

View File

@ -7,3 +7,7 @@ features:
any maintenance changes. any maintenance changes.
* endpoints_client(v2) * endpoints_client(v2)
* roles_client(v2)
* services_client(v2)
* tenants_client(v2)
* users_client(v2)

View File

@ -126,15 +126,15 @@ from tempest.lib.services.compute import floating_ips_client
from tempest.lib.services.compute import security_group_rules_client from tempest.lib.services.compute import security_group_rules_client
from tempest.lib.services.compute import security_groups_client from tempest.lib.services.compute import security_groups_client
from tempest.lib.services.compute import servers_client from tempest.lib.services.compute import servers_client
from tempest.lib.services.identity.v2 import roles_client
from tempest.lib.services.identity.v2 import tenants_client
from tempest.lib.services.identity.v2 import users_client
from tempest.lib.services.image.v2 import images_client from tempest.lib.services.image.v2 import images_client
from tempest.lib.services.network import networks_client from tempest.lib.services.network import networks_client
from tempest.lib.services.network import ports_client from tempest.lib.services.network import ports_client
from tempest.lib.services.network import routers_client from tempest.lib.services.network import routers_client
from tempest.lib.services.network import subnets_client from tempest.lib.services.network import subnets_client
from tempest.services.identity.v2.json import identity_client from tempest.services.identity.v2.json import identity_client
from tempest.services.identity.v2.json import roles_client
from tempest.services.identity.v2.json import tenants_client
from tempest.services.identity.v2.json import users_client
from tempest.services.object_storage import container_client from tempest.services.object_storage import container_client
from tempest.services.object_storage import object_client from tempest.services.object_storage import object_client
from tempest.services.volume.v1.json import volumes_client from tempest.services.volume.v1.json import volumes_client

View File

@ -0,0 +1,107 @@
# 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 oslo_serialization import jsonutils as json
from six.moves.urllib import parse as urllib
from tempest.lib.common import rest_client
class RolesClient(rest_client.RestClient):
api_version = "v2.0"
def create_role(self, **kwargs):
"""Create a role.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#createRole
"""
post_body = json.dumps({'role': kwargs})
resp, body = self.post('OS-KSADM/roles', post_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def show_role(self, role_id_or_name):
"""Get a role by its id or name.
Available params: see
http://developer.openstack.org/
api-ref-identity-v2-ext.html#showRoleByID
OR
http://developer.openstack.org/
api-ref-identity-v2-ext.html#showRoleByName
"""
resp, body = self.get('OS-KSADM/roles/%s' % role_id_or_name)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def list_roles(self, **params):
"""Returns roles.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#listRoles
"""
url = 'OS-KSADM/roles'
if params:
url += '?%s' % urllib.urlencode(params)
resp, body = self.get(url)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def delete_role(self, role_id):
"""Delete a role.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#deleteRole
"""
resp, body = self.delete('OS-KSADM/roles/%s' % str(role_id))
self.expected_success(204, resp.status)
return rest_client.ResponseBody(resp, body)
def create_user_role_on_project(self, tenant_id, user_id, role_id):
"""Add roles to a user on a tenant.
Available params: see
http://developer.openstack.org/
api-ref-identity-v2-ext.html#grantRoleToUserOnTenant
"""
resp, body = self.put('/tenants/%s/users/%s/roles/OS-KSADM/%s' %
(tenant_id, user_id, role_id), "")
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def list_user_roles_on_project(self, tenant_id, user_id, **params):
"""Returns a list of roles assigned to a user for a tenant."""
# TODO(gmann): Need to write API-ref link, Bug# 1592711
url = '/tenants/%s/users/%s/roles' % (tenant_id, user_id)
if params:
url += '?%s' % urllib.urlencode(params)
resp, body = self.get(url)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def delete_role_from_user_on_project(self, tenant_id, user_id, role_id):
"""Removes a role assignment for a user on a tenant.
Available params: see
http://developer.openstack.org/
api-ref-identity-v2-ext.html#revokeRoleFromUserOnTenant
"""
resp, body = self.delete('/tenants/%s/users/%s/roles/OS-KSADM/%s' %
(tenant_id, user_id, role_id))
self.expected_success(204, resp.status)
return rest_client.ResponseBody(resp, body)

View File

@ -0,0 +1,98 @@
# Copyright 2015 Red Hat, Inc.
#
# 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 oslo_serialization import jsonutils as json
from six.moves.urllib import parse as urllib
from tempest.lib.common import rest_client
class TenantsClient(rest_client.RestClient):
api_version = "v2.0"
def create_tenant(self, **kwargs):
"""Create a tenant
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#createTenant
"""
post_body = json.dumps({'tenant': kwargs})
resp, body = self.post('tenants', post_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def delete_tenant(self, tenant_id):
"""Delete a tenant.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#deleteTenant
"""
resp, body = self.delete('tenants/%s' % str(tenant_id))
self.expected_success(204, resp.status)
return rest_client.ResponseBody(resp, body)
def show_tenant(self, tenant_id):
"""Get tenant details.
Available params: see
http://developer.openstack.org/
api-ref-identity-v2-ext.html#admin-showTenantById
"""
resp, body = self.get('tenants/%s' % str(tenant_id))
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def list_tenants(self, **params):
"""Returns tenants.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#admin-listTenants
"""
url = 'tenants'
if params:
url += '?%s' % urllib.urlencode(params)
resp, body = self.get(url)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def update_tenant(self, tenant_id, **kwargs):
"""Updates a tenant.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#updateTenant
"""
if 'id' not in kwargs:
kwargs['id'] = tenant_id
post_body = json.dumps({'tenant': kwargs})
resp, body = self.post('tenants/%s' % tenant_id, post_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def list_tenant_users(self, tenant_id, **params):
"""List users for a Tenant.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#listUsersForTenant
"""
url = '/tenants/%s/users' % tenant_id
if params:
url += '?%s' % urllib.urlencode(params)
resp, body = self.get(url)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)

View File

@ -0,0 +1,152 @@
# 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 oslo_serialization import jsonutils as json
from six.moves.urllib import parse as urllib
from tempest.lib.common import rest_client
class UsersClient(rest_client.RestClient):
api_version = "v2.0"
def create_user(self, **kwargs):
"""Create a user.
Available params: see http://developer.openstack.org/
api-ref-identity-admin-v2.html#admin-createUser
"""
post_body = json.dumps({'user': kwargs})
resp, body = self.post('users', post_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def update_user(self, user_id, **kwargs):
"""Updates a user.
Available params: see http://developer.openstack.org/
api-ref-identity-admin-v2.html#admin-updateUser
"""
put_body = json.dumps({'user': kwargs})
resp, body = self.put('users/%s' % user_id, put_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def show_user(self, user_id):
"""GET a user.
Available params: see http://developer.openstack.org/
api-ref-identity-admin-v2.html#admin-showUser
"""
resp, body = self.get("users/%s" % user_id)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def delete_user(self, user_id):
"""Delete a user.
Available params: see http://developer.openstack.org/
api-ref-identity-admin-v2.html#admin-deleteUser
"""
resp, body = self.delete("users/%s" % user_id)
self.expected_success(204, resp.status)
return rest_client.ResponseBody(resp, body)
def list_users(self, **params):
"""Get the list of users.
Available params: see http://developer.openstack.org/
api-ref-identity-admin-v2.html#admin-listUsers
"""
url = "users"
if params:
url += '?%s' % urllib.urlencode(params)
resp, body = self.get(url)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def update_user_enabled(self, user_id, **kwargs):
"""Enables or disables a user.
Available params: see http://developer.openstack.org/
api-ref-identity-v2-ext.html#enableUser
"""
# NOTE: The URL (users/<id>/enabled) is different from the api-site
# one (users/<id>/OS-KSADM/enabled) , but they are the same API
# because of the fact that in keystone/contrib/admin_crud/core.py
# both api use same action='set_user_enabled'
put_body = json.dumps({'user': kwargs})
resp, body = self.put('users/%s/enabled' % user_id, put_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def update_user_password(self, user_id, **kwargs):
"""Update User Password."""
# TODO(piyush): Current api-site doesn't contain this API description.
# After fixing the api-site, we need to fix here also for putting the
# link to api-site.
# LP: https://bugs.launchpad.net/openstack-api-site/+bug/1524147
put_body = json.dumps({'user': kwargs})
resp, body = self.put('users/%s/OS-KSADM/password' % user_id, put_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def update_user_own_password(self, user_id, **kwargs):
"""User updates own password"""
# TODO(piyush): Current api-site doesn't contain this API description.
# After fixing the api-site, we need to fix here also for putting the
# link to api-site.
# LP: https://bugs.launchpad.net/openstack-api-site/+bug/1524153
# NOTE: This API is used for updating user password by itself.
# Ref: http://lists.openstack.org/pipermail/openstack-dev/2015-December
# /081803.html
patch_body = json.dumps({'user': kwargs})
resp, body = self.patch('OS-KSCRUD/users/%s' % user_id, patch_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def create_user_ec2_credential(self, user_id, **kwargs):
# TODO(piyush): Current api-site doesn't contain this API description.
# After fixing the api-site, we need to fix here also for putting the
# link to api-site.
post_body = json.dumps(kwargs)
resp, body = self.post('/users/%s/credentials/OS-EC2' % user_id,
post_body)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def delete_user_ec2_credential(self, user_id, access):
resp, body = self.delete('/users/%s/credentials/OS-EC2/%s' %
(user_id, access))
self.expected_success(204, resp.status)
return rest_client.ResponseBody(resp, body)
def list_user_ec2_credentials(self, user_id):
resp, body = self.get('/users/%s/credentials/OS-EC2' % user_id)
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)
def show_user_ec2_credential(self, user_id, access):
resp, body = self.get('/users/%s/credentials/OS-EC2/%s' %
(user_id, access))
self.expected_success(200, resp.status)
body = json.loads(body)
return rest_client.ResponseBody(resp, body)

View File

@ -13,12 +13,12 @@
# the License. # the License.
from tempest.lib.services.identity.v2.endpoints_client import EndpointsClient from tempest.lib.services.identity.v2.endpoints_client import EndpointsClient
from tempest.lib.services.identity.v2.roles_client import RolesClient
from tempest.lib.services.identity.v2.services_client import ServicesClient
from tempest.lib.services.identity.v2.tenants_client import TenantsClient
from tempest.lib.services.identity.v2.token_client import TokenClient from tempest.lib.services.identity.v2.token_client import TokenClient
from tempest.lib.services.identity.v2.users_client import UsersClient
from tempest.services.identity.v2.json.identity_client import IdentityClient from tempest.services.identity.v2.json.identity_client import IdentityClient
from tempest.services.identity.v2.json.roles_client import RolesClient
from tempest.services.identity.v2.json.services_client import ServicesClient
from tempest.services.identity.v2.json.tenants_client import TenantsClient
from tempest.services.identity.v2.json.users_client import UsersClient
__all__ = ['EndpointsClient', 'TokenClient', 'IdentityClient', 'RolesClient', __all__ = ['EndpointsClient', 'TokenClient', 'IdentityClient', 'RolesClient',
'ServicesClient', 'TenantsClient', 'UsersClient'] 'ServicesClient', 'TenantsClient', 'UsersClient']

View File

@ -22,14 +22,14 @@ from tempest import config
from tempest import exceptions from tempest import exceptions
from tempest.lib.common import rest_client from tempest.lib.common import rest_client
from tempest.lib import exceptions as lib_exc from tempest.lib import exceptions as lib_exc
from tempest.lib.services.identity.v2 import roles_client as v2_roles_client
from tempest.lib.services.identity.v2 import tenants_client as \
v2_tenants_client
from tempest.lib.services.identity.v2 import token_client as v2_token_client from tempest.lib.services.identity.v2 import token_client as v2_token_client
from tempest.lib.services.identity.v2 import users_client as v2_users_client
from tempest.lib.services.identity.v3 import token_client as v3_token_client from tempest.lib.services.identity.v3 import token_client as v3_token_client
from tempest.lib.services.network import routers_client from tempest.lib.services.network import routers_client
from tempest.services.identity.v2.json import identity_client as v2_iden_client from tempest.services.identity.v2.json import identity_client as v2_iden_client
from tempest.services.identity.v2.json import roles_client as v2_roles_client
from tempest.services.identity.v2.json import tenants_client as \
v2_tenants_client
from tempest.services.identity.v2.json import users_client as v2_users_client
from tempest.services.identity.v3.json import domains_client from tempest.services.identity.v3.json import domains_client
from tempest.services.identity.v3.json import identity_client as v3_iden_client from tempest.services.identity.v3.json import identity_client as v3_iden_client
from tempest.services.identity.v3.json import projects_client as \ from tempest.services.identity.v3.json import projects_client as \

View File

@ -12,7 +12,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from tempest.services.identity.v2.json import roles_client from tempest.lib.services.identity.v2 import roles_client
from tempest.tests.lib import fake_auth_provider from tempest.tests.lib import fake_auth_provider
from tempest.tests.lib.services import base from tempest.tests.lib.services import base

View File

@ -0,0 +1,97 @@
# Copyright 2016 NEC Corporation. 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 tempest.lib.services.identity.v2 import services_client
from tempest.tests.lib import fake_auth_provider
from tempest.tests.lib.services import base
class TestServicesClient(base.BaseServiceTest):
FAKE_SERVICE_INFO = {
"OS-KSADM:service": {
"id": "1",
"name": "test",
"type": "compute",
"description": "test_description"
}
}
FAKE_LIST_SERVICES = {
"OS-KSADM:services": [
{
"id": "1",
"name": "test",
"type": "compute",
"description": "test_description"
},
{
"id": "2",
"name": "test2",
"type": "compute",
"description": "test2_description"
}
]
}
def setUp(self):
super(TestServicesClient, self).setUp()
fake_auth = fake_auth_provider.FakeAuthProvider()
self.client = services_client.ServicesClient(fake_auth,
'identity', 'regionOne')
def _test_create_service(self, bytes_body=False):
self.check_service_client_function(
self.client.create_service,
'tempest.lib.common.rest_client.RestClient.post',
self.FAKE_SERVICE_INFO,
bytes_body,
id="1",
name="test",
type="compute",
description="test_description")
def _test_show_service(self, bytes_body=False):
self.check_service_client_function(
self.client.show_service,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_SERVICE_INFO,
bytes_body,
service_id="1")
def _test_list_services(self, bytes_body=False):
self.check_service_client_function(
self.client.list_services,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_LIST_SERVICES,
bytes_body)
def test_create_service_with_str_body(self):
self._test_create_service()
def test_create_service_with_bytes_body(self):
self._test_create_service(bytes_body=True)
def test_show_service_with_str_body(self):
self._test_show_service()
def test_show_service_with_bytes_body(self):
self._test_show_service(bytes_body=True)
def test_delete_service(self):
self.check_service_client_function(
self.client.delete_service,
'tempest.lib.common.rest_client.RestClient.delete',
{},
service_id="1",
status=204)

View File

@ -0,0 +1,131 @@
# Copyright 2016 NEC Corporation. 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 tempest.lib.services.identity.v2 import tenants_client
from tempest.tests.lib import fake_auth_provider
from tempest.tests.lib.services import base
class TestTenantsClient(base.BaseServiceTest):
FAKE_TENANT_INFO = {
"tenant": {
"id": "1",
"name": "test",
"description": "test_description",
"enabled": True
}
}
FAKE_LIST_TENANTS = {
"tenants": [
{
"id": "1",
"name": "test",
"description": "test_description",
"enabled": True
},
{
"id": "2",
"name": "test2",
"description": "test2_description",
"enabled": True
}
]
}
def setUp(self):
super(TestTenantsClient, self).setUp()
fake_auth = fake_auth_provider.FakeAuthProvider()
self.client = tenants_client.TenantsClient(fake_auth,
'identity', 'regionOne')
def _test_create_tenant(self, bytes_body=False):
self.check_service_client_function(
self.client.create_tenant,
'tempest.lib.common.rest_client.RestClient.post',
self.FAKE_TENANT_INFO,
bytes_body,
name="test",
description="test_description")
def _test_show_tenant(self, bytes_body=False):
self.check_service_client_function(
self.client.show_tenant,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_TENANT_INFO,
bytes_body,
tenant_id="1")
def _test_update_tenant(self, bytes_body=False):
self.check_service_client_function(
self.client.update_tenant,
'tempest.lib.common.rest_client.RestClient.post',
self.FAKE_TENANT_INFO,
bytes_body,
tenant_id="1",
name="test",
description="test_description")
def _test_list_tenants(self, bytes_body=False):
self.check_service_client_function(
self.client.list_tenants,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_LIST_TENANTS,
bytes_body)
def _test_list_tenant_users(self, bytes_body=False):
self.check_service_client_function(
self.client.list_tenant_users,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_LIST_TENANTS,
bytes_body,
tenant_id="1")
def test_create_tenant_with_str_body(self):
self._test_create_tenant()
def test_create_tenant_with_bytes_body(self):
self._test_create_tenant(bytes_body=True)
def test_show_tenant_with_str_body(self):
self._test_show_tenant()
def test_show_tenant_with_bytes_body(self):
self._test_show_tenant(bytes_body=True)
def test_update_tenant_with_str_body(self):
self._test_update_tenant()
def test_update_tenant_with_bytes_body(self):
self._test_update_tenant(bytes_body=True)
def test_list_tenants_with_str_body(self):
self._test_list_tenants()
def test_list_tenants_with_bytes_body(self):
self._test_list_tenants(bytes_body=True)
def test_delete_tenant(self):
self.check_service_client_function(
self.client.delete_tenant,
'tempest.lib.common.rest_client.RestClient.delete',
{},
tenant_id="1",
status=204)
def test_list_tenant_users_with_str_body(self):
self._test_list_tenant_users()
def test_list_tenant_users_with_bytes_body(self):
self._test_list_tenant_users(bytes_body=True)

View File

@ -0,0 +1,243 @@
# Copyright 2016 NEC Corporation. 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 tempest.lib.services.identity.v2 import users_client
from tempest.tests.lib import fake_auth_provider
from tempest.tests.lib.services import base
class TestUsersClient(base.BaseServiceTest):
FAKE_USER_INFO = {
"user": {
"id": "1",
"name": "test",
"email": "john.smith@example.org",
"enabled": True
}
}
FAKE_LIST_USERS = {
"users": [
{
"id": "1",
"name": "test",
"email": "john.smith@example.org",
"enabled": True
},
{
"id": "2",
"name": "test2",
"email": "john.smith@example.org",
"enabled": True
}
]
}
FAKE_USER_EC2_CREDENTIAL_INFO = {
"credential": {
'user_id': '9beb0e12f3e5416db8d7cccfc785db3b',
'access': '79abf59acc77492a86170cbe2f1feafa',
'secret': 'c4e7d3a691fd4563873d381a40320f46',
'trust_id': None,
'tenant_id': '596557269d7b4dd78631a602eb9f151d'
}
}
FAKE_LIST_USER_EC2_CREDENTIALS = {
"credentials": [
{
'user_id': '9beb0e12f3e5416db8d7cccfc785db3b',
'access': '79abf59acc77492a86170cbe2f1feafa',
'secret': 'c4e7d3a691fd4563873d381a40320f46',
'trust_id': None,
'tenant_id': '596557269d7b4dd78631a602eb9f151d'
},
{
'user_id': '3beb0e12f3e5416db8d7cccfc785de4r',
'access': '45abf59acc77492a86170cbe2f1fesde',
'secret': 'g4e7d3a691fd4563873d381a40320e45',
'trust_id': None,
'tenant_id': '123557269d7b4dd78631a602eb9f112f'
}
]
}
def setUp(self):
super(TestUsersClient, self).setUp()
fake_auth = fake_auth_provider.FakeAuthProvider()
self.client = users_client.UsersClient(fake_auth,
'identity', 'regionOne')
def _test_create_user(self, bytes_body=False):
self.check_service_client_function(
self.client.create_user,
'tempest.lib.common.rest_client.RestClient.post',
self.FAKE_USER_INFO,
bytes_body,
name="test",
email="john.smith@example.org")
def _test_update_user(self, bytes_body=False):
self.check_service_client_function(
self.client.update_user,
'tempest.lib.common.rest_client.RestClient.put',
self.FAKE_USER_INFO,
bytes_body,
user_id="1",
name="test")
def _test_show_user(self, bytes_body=False):
self.check_service_client_function(
self.client.show_user,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_USER_INFO,
bytes_body,
user_id="1")
def _test_list_users(self, bytes_body=False):
self.check_service_client_function(
self.client.list_users,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_LIST_USERS,
bytes_body)
def _test_update_user_enabled(self, bytes_body=False):
self.check_service_client_function(
self.client.update_user_enabled,
'tempest.lib.common.rest_client.RestClient.put',
self.FAKE_USER_INFO,
bytes_body,
user_id="1",
enabled=True)
def _test_update_user_password(self, bytes_body=False):
self.check_service_client_function(
self.client.update_user_password,
'tempest.lib.common.rest_client.RestClient.put',
self.FAKE_USER_INFO,
bytes_body,
user_id="1",
password="pass")
def _test_update_user_own_password(self, bytes_body=False):
self.check_service_client_function(
self.client.update_user_own_password,
'tempest.lib.common.rest_client.RestClient.patch',
self.FAKE_USER_INFO,
bytes_body,
user_id="1",
password="pass")
def _test_create_user_ec2_credential(self, bytes_body=False):
self.check_service_client_function(
self.client.create_user_ec2_credential,
'tempest.lib.common.rest_client.RestClient.post',
self.FAKE_USER_EC2_CREDENTIAL_INFO,
bytes_body,
user_id="1",
tenant_id="123")
def _test_show_user_ec2_credential(self, bytes_body=False):
self.check_service_client_function(
self.client.show_user_ec2_credential,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_USER_EC2_CREDENTIAL_INFO,
bytes_body,
user_id="1",
access="123")
def _test_list_user_ec2_credentials(self, bytes_body=False):
self.check_service_client_function(
self.client.list_user_ec2_credentials,
'tempest.lib.common.rest_client.RestClient.get',
self.FAKE_LIST_USER_EC2_CREDENTIALS,
bytes_body,
user_id="1")
def test_create_user_with_str_body(self):
self._test_create_user()
def test_create_user_with_bytes_body(self):
self._test_create_user(bytes_body=True)
def test_update_user_with_str_body(self):
self._test_update_user()
def test_update_user_with_bytes_body(self):
self._test_update_user(bytes_body=True)
def test_show_user_with_str_body(self):
self._test_show_user()
def test_show_user_with_bytes_body(self):
self._test_show_user(bytes_body=True)
def test_list_users_with_str_body(self):
self._test_list_users()
def test_list_users_with_bytes_body(self):
self._test_list_users(bytes_body=True)
def test_delete_user(self):
self.check_service_client_function(
self.client.delete_user,
'tempest.lib.common.rest_client.RestClient.delete',
{},
user_id="1",
status=204)
def test_update_user_enabled_with_str_body(self):
self._test_update_user_enabled()
def test_update_user_enabled_with_bytes_body(self):
self._test_update_user_enabled(bytes_body=True)
def test_update_user_password_with_str_body(self):
self._test_update_user_password()
def test_update_user_password_with_bytes_body(self):
self._test_update_user_password(bytes_body=True)
def test_update_user_own_password_with_str_body(self):
self._test_update_user_own_password()
def test_update_user_own_password_with_bytes_body(self):
self._test_update_user_own_password(bytes_body=True)
def test_create_user_ec2_credential_with_str_body(self):
self._test_create_user_ec2_credential()
def test_create_user_ec2_credential_with_bytes_body(self):
self._test_create_user_ec2_credential(bytes_body=True)
def test_show_user_ec2_credential_with_str_body(self):
self._test_show_user_ec2_credential()
def test_show_user_ec2_credential_with_bytes_body(self):
self._test_show_user_ec2_credential(bytes_body=True)
def test_list_user_ec2_credentials_with_str_body(self):
self._test_list_user_ec2_credentials()
def test_list_user_ec2_credentials_with_bytes_body(self):
self._test_list_user_ec2_credentials(bytes_body=True)
def test_delete_user_ec2_credential(self):
self.check_service_client_function(
self.client.delete_user_ec2_credential,
'tempest.lib.common.rest_client.RestClient.delete',
{},
user_id="123",
access="1234",
status=204)