Merge "Port all keystone scenarios to Identity Service"
This commit is contained in:
commit
ba931be4ed
@ -253,7 +253,6 @@ class UserGenerator(UserContextMixin, context.Context):
|
|||||||
clients, name_generator=self.generate_random_name)
|
clients, name_generator=self.generate_random_name)
|
||||||
client = cache["client"]
|
client = cache["client"]
|
||||||
user = client.create_user(username, password=password,
|
user = client.create_user(username, password=password,
|
||||||
email="%s@email.me" % username,
|
|
||||||
project_id=tenant_id,
|
project_id=tenant_id,
|
||||||
domain_name=user_dom,
|
domain_name=user_dom,
|
||||||
default_role=default_role)
|
default_role=default_role)
|
||||||
|
@ -12,17 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
"""
|
||||||
|
Scenarios for Ceilometer Events API.
|
||||||
|
"""
|
||||||
|
|
||||||
from rally import consts
|
from rally import consts
|
||||||
from rally import exceptions
|
from rally import exceptions
|
||||||
from rally.plugins.openstack import scenario
|
from rally.plugins.openstack import scenario
|
||||||
from rally.plugins.openstack.scenarios.ceilometer import utils as cutils
|
from rally.plugins.openstack.scenarios.ceilometer import utils as cutils
|
||||||
from rally.plugins.openstack.scenarios.keystone import utils as kutils
|
from rally.plugins.openstack.scenarios.keystone import basic as kbasic
|
||||||
from rally.task import validation
|
from rally.task import validation
|
||||||
|
|
||||||
|
|
||||||
"""Scenarios for Ceilometer Events API."""
|
|
||||||
|
|
||||||
|
|
||||||
# NOTE(idegtiarov): to work with event we need to create it, there are
|
# NOTE(idegtiarov): to work with event we need to create it, there are
|
||||||
# no other way except emit suitable notification from one of services,
|
# no other way except emit suitable notification from one of services,
|
||||||
# for example create new user in keystone.
|
# for example create new user in keystone.
|
||||||
@ -34,7 +35,7 @@ from rally.task import validation
|
|||||||
"cleanup": ["ceilometer"]},
|
"cleanup": ["ceilometer"]},
|
||||||
name="CeilometerEvents.create_user_and_list_events")
|
name="CeilometerEvents.create_user_and_list_events")
|
||||||
class CeilometerEventsCreateUserAndListEvents(cutils.CeilometerScenario,
|
class CeilometerEventsCreateUserAndListEvents(cutils.CeilometerScenario,
|
||||||
kutils.KeystoneScenario):
|
kbasic.KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create user and fetch all events.
|
"""Create user and fetch all events.
|
||||||
@ -42,7 +43,7 @@ class CeilometerEventsCreateUserAndListEvents(cutils.CeilometerScenario,
|
|||||||
This scenario creates user to store new event and
|
This scenario creates user to store new event and
|
||||||
fetches list of all events using GET /v2/events.
|
fetches list of all events using GET /v2/events.
|
||||||
"""
|
"""
|
||||||
self._user_create()
|
self.admin_keystone.create_user()
|
||||||
events = self._list_events()
|
events = self._list_events()
|
||||||
if not events:
|
if not events:
|
||||||
raise exceptions.RallyException(
|
raise exceptions.RallyException(
|
||||||
@ -57,7 +58,7 @@ class CeilometerEventsCreateUserAndListEvents(cutils.CeilometerScenario,
|
|||||||
"cleanup": ["ceilometer"]},
|
"cleanup": ["ceilometer"]},
|
||||||
name="CeilometerEvents.create_user_and_list_event_types")
|
name="CeilometerEvents.create_user_and_list_event_types")
|
||||||
class CeilometerEventsCreateUserAndListEventTypes(cutils.CeilometerScenario,
|
class CeilometerEventsCreateUserAndListEventTypes(cutils.CeilometerScenario,
|
||||||
kutils.KeystoneScenario):
|
kbasic.KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create user and fetch all event types.
|
"""Create user and fetch all event types.
|
||||||
@ -65,7 +66,7 @@ class CeilometerEventsCreateUserAndListEventTypes(cutils.CeilometerScenario,
|
|||||||
This scenario creates user to store new event and
|
This scenario creates user to store new event and
|
||||||
fetches list of all events types using GET /v2/event_types.
|
fetches list of all events types using GET /v2/event_types.
|
||||||
"""
|
"""
|
||||||
self._user_create()
|
self.admin_keystone.create_user()
|
||||||
event_types = self._list_event_types()
|
event_types = self._list_event_types()
|
||||||
if not event_types:
|
if not event_types:
|
||||||
raise exceptions.RallyException(
|
raise exceptions.RallyException(
|
||||||
@ -80,7 +81,7 @@ class CeilometerEventsCreateUserAndListEventTypes(cutils.CeilometerScenario,
|
|||||||
"cleanup": ["ceilometer"]},
|
"cleanup": ["ceilometer"]},
|
||||||
name="CeilometerEvents.create_user_and_get_event")
|
name="CeilometerEvents.create_user_and_get_event")
|
||||||
class CeilometerEventsCreateUserAndGetEvent(cutils.CeilometerScenario,
|
class CeilometerEventsCreateUserAndGetEvent(cutils.CeilometerScenario,
|
||||||
kutils.KeystoneScenario):
|
kbasic.KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create user and gets event.
|
"""Create user and gets event.
|
||||||
@ -88,7 +89,7 @@ class CeilometerEventsCreateUserAndGetEvent(cutils.CeilometerScenario,
|
|||||||
This scenario creates user to store new event and
|
This scenario creates user to store new event and
|
||||||
fetches one event using GET /v2/events/<message_id>.
|
fetches one event using GET /v2/events/<message_id>.
|
||||||
"""
|
"""
|
||||||
self._user_create()
|
self.admin_keystone.create_user()
|
||||||
events = self._list_events()
|
events = self._list_events()
|
||||||
if not events:
|
if not events:
|
||||||
raise exceptions.RallyException(
|
raise exceptions.RallyException(
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
from rally import consts
|
from rally import consts
|
||||||
from rally.plugins.openstack import scenario
|
from rally.plugins.openstack import scenario
|
||||||
from rally.plugins.openstack.scenarios.ceilometer import utils as cutils
|
from rally.plugins.openstack.scenarios.ceilometer import utils as cutils
|
||||||
from rally.plugins.openstack.scenarios.keystone import utils as kutils
|
from rally.plugins.openstack.scenarios.keystone import basic as kbasic
|
||||||
from rally.task import validation
|
from rally.task import validation
|
||||||
|
|
||||||
|
|
||||||
@ -33,7 +33,7 @@ from rally.task import validation
|
|||||||
"cleanup": ["ceilometer"]},
|
"cleanup": ["ceilometer"]},
|
||||||
name="CeilometerTraits.create_user_and_list_traits")
|
name="CeilometerTraits.create_user_and_list_traits")
|
||||||
class CreateUserAndListTraits(cutils.CeilometerScenario,
|
class CreateUserAndListTraits(cutils.CeilometerScenario,
|
||||||
kutils.KeystoneScenario):
|
kbasic.KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create user and fetch all event traits.
|
"""Create user and fetch all event traits.
|
||||||
@ -42,7 +42,7 @@ class CreateUserAndListTraits(cutils.CeilometerScenario,
|
|||||||
fetches list of all traits for certain event type and
|
fetches list of all traits for certain event type and
|
||||||
trait name using GET /v2/event_types/<event_type>/traits/<trait_name>.
|
trait name using GET /v2/event_types/<event_type>/traits/<trait_name>.
|
||||||
"""
|
"""
|
||||||
self._user_create()
|
self.admin_keystone.create_user()
|
||||||
event = self._list_events()[0]
|
event = self._list_events()[0]
|
||||||
trait_name = event.traits[0]["name"]
|
trait_name = event.traits[0]["name"]
|
||||||
self._list_event_traits(event_type=event.event_type,
|
self._list_event_traits(event_type=event.event_type,
|
||||||
@ -57,7 +57,7 @@ class CreateUserAndListTraits(cutils.CeilometerScenario,
|
|||||||
name="CeilometerTraits.create_user_and"
|
name="CeilometerTraits.create_user_and"
|
||||||
"_list_trait_descriptions")
|
"_list_trait_descriptions")
|
||||||
class CreateUserAndListTraitDescriptions(
|
class CreateUserAndListTraitDescriptions(
|
||||||
cutils.CeilometerScenario, kutils.KeystoneScenario):
|
cutils.CeilometerScenario, kbasic.KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create user and fetch all trait descriptions.
|
"""Create user and fetch all trait descriptions.
|
||||||
@ -66,6 +66,6 @@ class CreateUserAndListTraitDescriptions(
|
|||||||
fetches list of all traits for certain event type using
|
fetches list of all traits for certain event type using
|
||||||
GET /v2/event_types/<event_type>/traits.
|
GET /v2/event_types/<event_type>/traits.
|
||||||
"""
|
"""
|
||||||
self._user_create()
|
self.admin_keystone.create_user()
|
||||||
event = self._list_events()[0]
|
event = self._list_events()[0]
|
||||||
self._list_event_trait_descriptions(event_type=event.event_type)
|
self._list_event_trait_descriptions(event_type=event.event_type)
|
@ -19,14 +19,29 @@ Benchmark scenarios for Keystone.
|
|||||||
|
|
||||||
from rally.common import logging
|
from rally.common import logging
|
||||||
from rally.plugins.openstack import scenario
|
from rally.plugins.openstack import scenario
|
||||||
from rally.plugins.openstack.scenarios.keystone import utils as kutils
|
from rally.plugins.openstack.services.identity import identity
|
||||||
from rally.task import validation
|
from rally.task import validation
|
||||||
|
|
||||||
|
|
||||||
|
class KeystoneBasic(scenario.OpenStackScenario):
|
||||||
|
"""Base class for Keystone scenarios with initialized service object."""
|
||||||
|
|
||||||
|
def __init__(self, context=None, admin_clients=None, clients=None):
|
||||||
|
super(KeystoneBasic, self).__init__(context, admin_clients, clients)
|
||||||
|
if hasattr(self, "_admin_clients"):
|
||||||
|
self.admin_keystone = identity.Identity(
|
||||||
|
self._admin_clients, name_generator=self.generate_random_name,
|
||||||
|
atomic_inst=self.atomic_actions())
|
||||||
|
if hasattr(self, "_clients"):
|
||||||
|
self.keystone = identity.Identity(
|
||||||
|
self._clients, name_generator=self.generate_random_name,
|
||||||
|
atomic_inst=self.atomic_actions())
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_user")
|
name="KeystoneBasic.create_user")
|
||||||
class CreateUser(kutils.KeystoneScenario):
|
class CreateUser(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_user is ignored",
|
"The 'name_length' argument to create_user is ignored",
|
||||||
@ -37,13 +52,13 @@ class CreateUser(kutils.KeystoneScenario):
|
|||||||
:param kwargs: Other optional parameters to create users like
|
:param kwargs: Other optional parameters to create users like
|
||||||
"tenant_id", "enabled".
|
"tenant_id", "enabled".
|
||||||
"""
|
"""
|
||||||
self._user_create(**kwargs)
|
self.admin_keystone.create_user(**kwargs)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_delete_user")
|
name="KeystoneBasic.create_delete_user")
|
||||||
class CreateDeleteUser(kutils.KeystoneScenario):
|
class CreateDeleteUser(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_delete_user is ignored",
|
"The 'name_length' argument to create_delete_user is ignored",
|
||||||
@ -54,14 +69,14 @@ class CreateDeleteUser(kutils.KeystoneScenario):
|
|||||||
:param kwargs: Other optional parameters to create users like
|
:param kwargs: Other optional parameters to create users like
|
||||||
"tenant_id", "enabled".
|
"tenant_id", "enabled".
|
||||||
"""
|
"""
|
||||||
user = self._user_create(**kwargs)
|
user = self.admin_keystone.create_user(**kwargs)
|
||||||
self._resource_delete(user)
|
self.admin_keystone.delete_user(user.id)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_user_set_enabled_and_delete")
|
name="KeystoneBasic.create_user_set_enabled_and_delete")
|
||||||
class CreateUserSetEnabledAndDelete(kutils.KeystoneScenario):
|
class CreateUserSetEnabledAndDelete(KeystoneBasic):
|
||||||
|
|
||||||
def run(self, enabled=True, **kwargs):
|
def run(self, enabled=True, **kwargs):
|
||||||
"""Create a keystone user, enable or disable it, and delete it.
|
"""Create a keystone user, enable or disable it, and delete it.
|
||||||
@ -71,16 +86,15 @@ class CreateUserSetEnabledAndDelete(kutils.KeystoneScenario):
|
|||||||
value, and then it will be toggled.
|
value, and then it will be toggled.
|
||||||
:param kwargs: Other optional parameters to create user.
|
:param kwargs: Other optional parameters to create user.
|
||||||
"""
|
"""
|
||||||
user = self._user_create(enabled=enabled, **kwargs)
|
user = self.admin_keystone.create_user(enabled=enabled, **kwargs)
|
||||||
self._update_user_enabled(user, not enabled)
|
self.admin_keystone.update_user(user.id, enabled=(not enabled))
|
||||||
self._resource_delete(user)
|
self.admin_keystone.delete_user(user.id)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@validation.required_api_versions(component="keystone", versions=[2.0])
|
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_tenant")
|
name="KeystoneBasic.create_tenant")
|
||||||
class CreateTenant(kutils.KeystoneScenario):
|
class CreateTenant(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_tenant is ignored",
|
"The 'name_length' argument to create_tenant is ignored",
|
||||||
@ -90,33 +104,26 @@ class CreateTenant(kutils.KeystoneScenario):
|
|||||||
|
|
||||||
:param kwargs: Other optional parameters
|
:param kwargs: Other optional parameters
|
||||||
"""
|
"""
|
||||||
self._tenant_create(**kwargs)
|
self.admin_keystone.create_project(**kwargs)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@validation.required_api_versions(component="keystone", versions=[2.0])
|
@validation.required_api_versions(component="keystone", versions=[2.0])
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.authenticate_user_and_validate_token")
|
name="KeystoneBasic.authenticate_user_and_validate_token")
|
||||||
class AuthenticateUserAndValidateToken(kutils.KeystoneScenario):
|
class AuthenticateUserAndValidateToken(KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Authenticate and validate a keystone token."""
|
"""Authenticate and validate a keystone token."""
|
||||||
name = self.context["user"]["credential"].username
|
token = self.admin_keystone.fetch_token()
|
||||||
password = self.context["user"]["credential"].password
|
self.admin_keystone.validate_token(token)
|
||||||
tenant_id = self.context["tenant"]["id"]
|
|
||||||
tenant_name = self.context["tenant"]["name"]
|
|
||||||
|
|
||||||
token = self._authenticate_token(name, password, tenant_id,
|
|
||||||
tenant_name, atomic_action=False)
|
|
||||||
self._token_validate(token.id)
|
|
||||||
|
|
||||||
|
|
||||||
@validation.number("users_per_tenant", minval=1)
|
@validation.number("users_per_tenant", minval=1)
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@validation.required_api_versions(component="keystone", versions=[2.0])
|
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_tenant_with_users")
|
name="KeystoneBasic.create_tenant_with_users")
|
||||||
class CreateTenantWithUsers(kutils.KeystoneScenario):
|
class CreateTenantWithUsers(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_tenant_with_users is ignored",
|
"The 'name_length' argument to create_tenant_with_users is ignored",
|
||||||
@ -128,14 +135,15 @@ class CreateTenantWithUsers(kutils.KeystoneScenario):
|
|||||||
:param kwargs: Other optional parameters for tenant creation
|
:param kwargs: Other optional parameters for tenant creation
|
||||||
:returns: keystone tenant instance
|
:returns: keystone tenant instance
|
||||||
"""
|
"""
|
||||||
tenant = self._tenant_create(**kwargs)
|
tenant = self.admin_keystone.create_project(**kwargs)
|
||||||
self._users_create(tenant, users_per_tenant=users_per_tenant)
|
self.admin_keystone.create_users(tenant.id,
|
||||||
|
number_of_users=users_per_tenant)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_list_users")
|
name="KeystoneBasic.create_and_list_users")
|
||||||
class CreateAndListUsers(kutils.KeystoneScenario):
|
class CreateAndListUsers(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_and_list_users is ignored",
|
"The 'name_length' argument to create_and_list_users is ignored",
|
||||||
@ -146,15 +154,15 @@ class CreateAndListUsers(kutils.KeystoneScenario):
|
|||||||
:param kwargs: Other optional parameters to create users like
|
:param kwargs: Other optional parameters to create users like
|
||||||
"tenant_id", "enabled".
|
"tenant_id", "enabled".
|
||||||
"""
|
"""
|
||||||
self._user_create(**kwargs)
|
kwargs.pop("name", None)
|
||||||
self._list_users()
|
self.admin_keystone.create_user(**kwargs)
|
||||||
|
self.admin_keystone.list_users()
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@validation.required_api_versions(component="keystone", versions=[2.0])
|
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_list_tenants")
|
name="KeystoneBasic.create_and_list_tenants")
|
||||||
class CreateAndListTenants(kutils.KeystoneScenario):
|
class CreateAndListTenants(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_and_list_tenants is ignored",
|
"The 'name_length' argument to create_and_list_tenants is ignored",
|
||||||
@ -164,14 +172,14 @@ class CreateAndListTenants(kutils.KeystoneScenario):
|
|||||||
|
|
||||||
:param kwargs: Other optional parameters
|
:param kwargs: Other optional parameters
|
||||||
"""
|
"""
|
||||||
self._tenant_create(**kwargs)
|
self.admin_keystone.create_project(**kwargs)
|
||||||
self._list_tenants()
|
self.admin_keystone.list_projects()
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True, users=True)
|
@validation.required_openstack(admin=True, users=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.add_and_remove_user_role")
|
name="KeystoneBasic.add_and_remove_user_role")
|
||||||
class AddAndRemoveUserRole(kutils.KeystoneScenario):
|
class AddAndRemoveUserRole(KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create a user role add to a user and disassociate."""
|
"""Create a user role add to a user and disassociate."""
|
||||||
@ -187,7 +195,7 @@ class AddAndRemoveUserRole(kutils.KeystoneScenario):
|
|||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_delete_role")
|
name="KeystoneBasic.create_and_delete_role")
|
||||||
class CreateAndDeleteRole(kutils.KeystoneScenario):
|
class CreateAndDeleteRole(KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create a user role and delete it."""
|
"""Create a user role and delete it."""
|
||||||
@ -198,7 +206,7 @@ class CreateAndDeleteRole(kutils.KeystoneScenario):
|
|||||||
@validation.required_openstack(admin=True, users=True)
|
@validation.required_openstack(admin=True, users=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_add_and_list_user_roles")
|
name="KeystoneBasic.create_add_and_list_user_roles")
|
||||||
class CreateAddAndListUserRoles(kutils.KeystoneScenario):
|
class CreateAddAndListUserRoles(KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create user role, add it and list user roles for given user."""
|
"""Create user role, add it and list user roles for given user."""
|
||||||
@ -211,10 +219,9 @@ class CreateAddAndListUserRoles(kutils.KeystoneScenario):
|
|||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@validation.required_api_versions(component="keystone", versions=[2.0])
|
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.get_entities")
|
name="KeystoneBasic.get_entities")
|
||||||
class GetEntities(kutils.KeystoneScenario):
|
class GetEntities(KeystoneBasic):
|
||||||
|
|
||||||
def run(self, service_name="keystone"):
|
def run(self, service_name="keystone"):
|
||||||
"""Get instance of a tenant, user, role and service by id's.
|
"""Get instance of a tenant, user, role and service by id's.
|
||||||
@ -230,23 +237,23 @@ class GetEntities(kutils.KeystoneScenario):
|
|||||||
None, to create an ephemeral service and
|
None, to create an ephemeral service and
|
||||||
get it by ID.
|
get it by ID.
|
||||||
"""
|
"""
|
||||||
tenant = self._tenant_create()
|
project = self.admin_keystone.create_project()
|
||||||
user = self._user_create()
|
user = self.admin_keystone.create_user(project_id=project.id)
|
||||||
role = self.admin_keystone.create_role()
|
role = self.admin_keystone.create_role()
|
||||||
self._get_tenant(tenant.id)
|
self.admin_keystone.get_project(project.id)
|
||||||
self._get_user(user.id)
|
self.admin_keystone.get_user(user.id)
|
||||||
self._get_role(role.id)
|
self.admin_keystone.get_role(role.id)
|
||||||
if service_name is None:
|
if service_name is None:
|
||||||
service = self._service_create()
|
service = self.admin_keystone.create_service()
|
||||||
else:
|
else:
|
||||||
service = self._get_service_by_name(service_name)
|
service = self.admin_keystone.get_service_by_name(service_name)
|
||||||
self._get_service(service.id)
|
self.admin_keystone.get_service(service.id)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_delete_service")
|
name="KeystoneBasic.create_and_delete_service")
|
||||||
class CreateAndDeleteService(kutils.KeystoneScenario):
|
class CreateAndDeleteService(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name' argument to create_and_delete_service will be ignored",
|
"The 'name' argument to create_and_delete_service will be ignored",
|
||||||
@ -257,15 +264,15 @@ class CreateAndDeleteService(kutils.KeystoneScenario):
|
|||||||
:param service_type: type of the service
|
:param service_type: type of the service
|
||||||
:param description: description of the service
|
:param description: description of the service
|
||||||
"""
|
"""
|
||||||
service = self._service_create(service_type, description)
|
service = self.admin_keystone.create_service(service_type=service_type,
|
||||||
self._delete_service(service.id)
|
description=description)
|
||||||
|
self.admin_keystone.delete_service(service.id)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@validation.required_api_versions(component="keystone", versions=[2.0])
|
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_update_and_delete_tenant")
|
name="KeystoneBasic.create_update_and_delete_tenant")
|
||||||
class CreateUpdateAndDeleteTenant(kutils.KeystoneScenario):
|
class CreateUpdateAndDeleteTenant(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' argument to create_update_and_delete_tenant is "
|
"The 'name_length' argument to create_update_and_delete_tenant is "
|
||||||
@ -275,15 +282,18 @@ class CreateUpdateAndDeleteTenant(kutils.KeystoneScenario):
|
|||||||
|
|
||||||
:param kwargs: Other optional parameters for tenant creation
|
:param kwargs: Other optional parameters for tenant creation
|
||||||
"""
|
"""
|
||||||
tenant = self._tenant_create(**kwargs)
|
project = self.admin_keystone.create_project(**kwargs)
|
||||||
self._update_tenant(tenant)
|
new_name = self.generate_random_name()
|
||||||
self._resource_delete(tenant)
|
new_description = self.generate_random_name()
|
||||||
|
self.admin_keystone.update_project(project.id, name=new_name,
|
||||||
|
description=new_description)
|
||||||
|
self.admin_keystone.delete_project(project.id)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_user_update_password")
|
name="KeystoneBasic.create_user_update_password")
|
||||||
class CreateUserUpdatePassword(kutils.KeystoneScenario):
|
class CreateUserUpdatePassword(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name_length' and 'password_length' arguments to "
|
"The 'name_length' and 'password_length' arguments to "
|
||||||
@ -291,15 +301,15 @@ class CreateUserUpdatePassword(kutils.KeystoneScenario):
|
|||||||
"0.1.2", ["name_length", "password_length"], once=True)
|
"0.1.2", ["name_length", "password_length"], once=True)
|
||||||
def run(self, name_length=None, password_length=None):
|
def run(self, name_length=None, password_length=None):
|
||||||
"""Create user and update password for that user."""
|
"""Create user and update password for that user."""
|
||||||
|
user = self.admin_keystone.create_user()
|
||||||
password = self.generate_random_name()
|
password = self.generate_random_name()
|
||||||
user = self._user_create()
|
self.admin_keystone.update_user(user.id, password=password)
|
||||||
self._update_user_password(user.id, password)
|
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_list_services")
|
name="KeystoneBasic.create_and_list_services")
|
||||||
class CreateAndListServices(kutils.KeystoneScenario):
|
class CreateAndListServices(KeystoneBasic):
|
||||||
|
|
||||||
@logging.log_deprecated_args(
|
@logging.log_deprecated_args(
|
||||||
"The 'name' argument to create_and_list_services will be ignored",
|
"The 'name' argument to create_and_list_services will be ignored",
|
||||||
@ -310,38 +320,42 @@ class CreateAndListServices(kutils.KeystoneScenario):
|
|||||||
:param service_type: type of the service
|
:param service_type: type of the service
|
||||||
:param description: description of the service
|
:param description: description of the service
|
||||||
"""
|
"""
|
||||||
self._service_create(service_type, description)
|
self.admin_keystone.create_service(service_type=service_type,
|
||||||
self._list_services()
|
description=description)
|
||||||
|
self.admin_keystone.list_services()
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(users=True)
|
@validation.required_openstack(users=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_list_ec2credentials")
|
name="KeystoneBasic.create_and_list_ec2credentials")
|
||||||
class CreateAndListEc2Credentials(kutils.KeystoneScenario):
|
class CreateAndListEc2Credentials(KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create and List all keystone ec2-credentials."""
|
"""Create and List all keystone ec2-credentials."""
|
||||||
self._create_ec2credentials(self.context["user"]["id"],
|
self.keystone.create_ec2credentials(
|
||||||
self.context["tenant"]["id"])
|
self.context["user"]["id"],
|
||||||
self._list_ec2credentials(self.context["user"]["id"])
|
project_id=self.context["tenant"]["id"])
|
||||||
|
self.keystone.list_ec2credentials(self.context["user"]["id"])
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(users=True)
|
@validation.required_openstack(users=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_delete_ec2credential")
|
name="KeystoneBasic.create_and_delete_ec2credential")
|
||||||
class CreateAndDeleteEc2Credential(kutils.KeystoneScenario):
|
class CreateAndDeleteEc2Credential(KeystoneBasic):
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
"""Create and delete keystone ec2-credential."""
|
"""Create and delete keystone ec2-credential."""
|
||||||
creds = self._create_ec2credentials(self.context["user"]["id"],
|
creds = self.keystone.create_ec2credentials(
|
||||||
self.context["tenant"]["id"])
|
self.context["user"]["id"],
|
||||||
self._delete_ec2credential(self.context["user"]["id"], creds.access)
|
project_id=self.context["tenant"]["id"])
|
||||||
|
self.keystone.delete_ec2credential(
|
||||||
|
self.context["user"]["id"], access=creds.access)
|
||||||
|
|
||||||
|
|
||||||
@validation.required_openstack(admin=True)
|
@validation.required_openstack(admin=True)
|
||||||
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
@scenario.configure(context={"admin_cleanup": ["keystone"]},
|
||||||
name="KeystoneBasic.create_and_get_role")
|
name="KeystoneBasic.create_and_get_role")
|
||||||
class CreateAndGetRole(kutils.KeystoneScenario):
|
class CreateAndGetRole(KeystoneBasic):
|
||||||
|
|
||||||
def run(self, **kwargs):
|
def run(self, **kwargs):
|
||||||
"""Create a user role and get it detailed information.
|
"""Create a user role and get it detailed information.
|
||||||
|
@ -15,25 +15,26 @@
|
|||||||
|
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
|
from rally.common.i18n import _LW
|
||||||
|
from rally.common import logging
|
||||||
from rally.plugins.openstack import scenario
|
from rally.plugins.openstack import scenario
|
||||||
from rally.plugins.openstack.services.identity import identity
|
|
||||||
from rally.plugins.openstack.wrappers import keystone as keystone_wrapper
|
from rally.plugins.openstack.wrappers import keystone as keystone_wrapper
|
||||||
from rally.task import atomic
|
from rally.task import atomic
|
||||||
|
|
||||||
|
|
||||||
|
LOG = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class KeystoneScenario(scenario.OpenStackScenario):
|
class KeystoneScenario(scenario.OpenStackScenario):
|
||||||
"""Base class for Keystone scenarios with basic atomic actions."""
|
"""Base class for Keystone scenarios with basic atomic actions."""
|
||||||
|
|
||||||
def __init__(self, context=None, admin_clients=None, clients=None):
|
def __init__(self, context=None, admin_clients=None, clients=None):
|
||||||
super(KeystoneScenario, self).__init__(context, admin_clients, clients)
|
super(KeystoneScenario, self).__init__(context, admin_clients, clients)
|
||||||
if hasattr(self, "_admin_clients"):
|
LOG.warning(_LW(
|
||||||
self.admin_keystone = identity.Identity(
|
"Class %s is deprecated since Rally 0.8.0 and will be removed "
|
||||||
self._admin_clients, name_generator=self.generate_random_name,
|
"soon. Use "
|
||||||
atomic_inst=self.atomic_actions())
|
"rally.plugins.openstack.services.identity.identity.Identity "
|
||||||
if hasattr(self, "_clients"):
|
"instead.") % self.__class__)
|
||||||
self.keystone = identity.Identity(
|
|
||||||
self._clients, name_generator=self.generate_random_name,
|
|
||||||
atomic_inst=self.atomic_actions())
|
|
||||||
|
|
||||||
@atomic.action_timer("keystone.create_user")
|
@atomic.action_timer("keystone.create_user")
|
||||||
def _user_create(self, email=None, **kwargs):
|
def _user_create(self, email=None, **kwargs):
|
||||||
|
@ -42,6 +42,19 @@ class Identity(service.UnifiedOpenStackService):
|
|||||||
return self._impl.create_project(project_name,
|
return self._impl.create_project(project_name,
|
||||||
domain_name=domain_name)
|
domain_name=domain_name)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def update_project(self, project_id, name=None, enabled=None,
|
||||||
|
description=None):
|
||||||
|
"""Update project name, enabled and description
|
||||||
|
|
||||||
|
:param project_id: Id of project to update
|
||||||
|
:param name: project name to be set
|
||||||
|
:param enabled: enabled status of project
|
||||||
|
:param description: project description to be set
|
||||||
|
"""
|
||||||
|
self._impl.update_project(project_id, name=name, enabled=enabled,
|
||||||
|
description=description)
|
||||||
|
|
||||||
@service.should_be_overridden
|
@service.should_be_overridden
|
||||||
def delete_project(self, project_id):
|
def delete_project(self, project_id):
|
||||||
"""Deletes project."""
|
"""Deletes project."""
|
||||||
@ -53,29 +66,45 @@ class Identity(service.UnifiedOpenStackService):
|
|||||||
return self._impl.list_projects()
|
return self._impl.list_projects()
|
||||||
|
|
||||||
@service.should_be_overridden
|
@service.should_be_overridden
|
||||||
def create_user(self, username=None, password=None, email=None,
|
def get_project(self, project_id):
|
||||||
project_id=None, domain_name="Default",
|
"""Get project."""
|
||||||
|
return self._impl.get_project(project_id)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def create_user(self, username=None, password=None, project_id=None,
|
||||||
|
domain_name="Default", enabled=True,
|
||||||
default_role="member"):
|
default_role="member"):
|
||||||
"""Create user.
|
"""Create user.
|
||||||
|
|
||||||
:param username: name of user
|
:param username: name of user
|
||||||
:param password: user password
|
:param password: user password
|
||||||
:param email: user's email
|
|
||||||
:param project_id: user's default project
|
:param project_id: user's default project
|
||||||
:param domain_name: Name or id of domain where to create user, for
|
:param domain_name: Name or id of domain where to create user, for
|
||||||
those service implementations that don't support
|
those service implementations that don't support
|
||||||
domains you should use None or 'Default' value.
|
domains you should use None or 'Default' value.
|
||||||
|
:param enabled: whether the user is enabled.
|
||||||
:param default_role: Name of role, for implementations that don't
|
:param default_role: Name of role, for implementations that don't
|
||||||
support domains this argument must be None or
|
support domains this argument must be None or
|
||||||
'member'.
|
'member'.
|
||||||
"""
|
"""
|
||||||
return self._impl.create_user(username=username,
|
return self._impl.create_user(username=username,
|
||||||
password=password,
|
password=password,
|
||||||
email=email,
|
|
||||||
project_id=project_id,
|
project_id=project_id,
|
||||||
domain_name=domain_name,
|
domain_name=domain_name,
|
||||||
default_role=default_role)
|
default_role=default_role)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def create_users(self, owner_id, number_of_users, user_create_args=None):
|
||||||
|
"""Create specified amount of users.
|
||||||
|
|
||||||
|
:param owner_id: Id of tenant/project
|
||||||
|
:param number_of_users: number of users to create
|
||||||
|
:param user_create_args: additional user creation arguments
|
||||||
|
"""
|
||||||
|
return self._impl.create_users(owner_id,
|
||||||
|
number_of_users=number_of_users,
|
||||||
|
user_create_args=user_create_args)
|
||||||
|
|
||||||
@service.should_be_overridden
|
@service.should_be_overridden
|
||||||
def delete_user(self, user_id):
|
def delete_user(self, user_id):
|
||||||
"""Deletes user by its id."""
|
"""Deletes user by its id."""
|
||||||
@ -86,6 +115,28 @@ class Identity(service.UnifiedOpenStackService):
|
|||||||
"""List all users."""
|
"""List all users."""
|
||||||
return self._impl.list_users()
|
return self._impl.list_users()
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def update_user(self, user_id, enabled=None, name=None, email=None,
|
||||||
|
password=None):
|
||||||
|
return self._impl.update_user(user_id, enabled=enabled, name=name,
|
||||||
|
email=email, password=password)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def get_user(self, user_id):
|
||||||
|
"""Get user."""
|
||||||
|
return self._impl.get_user(user_id)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def create_service(self, name=None, service_type=None, description=None):
|
||||||
|
"""Creates keystone service with random name.
|
||||||
|
|
||||||
|
:param name: name of service to create
|
||||||
|
:param service_type: type of the service
|
||||||
|
:param description: description of the service
|
||||||
|
"""
|
||||||
|
return self._impl.create_service(name=name, service_type=service_type,
|
||||||
|
description=description)
|
||||||
|
|
||||||
@service.should_be_overridden
|
@service.should_be_overridden
|
||||||
def delete_service(self, service_id):
|
def delete_service(self, service_id):
|
||||||
"""Deletes service."""
|
"""Deletes service."""
|
||||||
@ -96,6 +147,11 @@ class Identity(service.UnifiedOpenStackService):
|
|||||||
"""List all services."""
|
"""List all services."""
|
||||||
return self._impl.list_services()
|
return self._impl.list_services()
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def get_service(self, service_id):
|
||||||
|
"""Get service."""
|
||||||
|
return self._impl.get_service(service_id)
|
||||||
|
|
||||||
@service.should_be_overridden
|
@service.should_be_overridden
|
||||||
def create_role(self, name=None, domain_name="Default"):
|
def create_role(self, name=None, domain_name="Default"):
|
||||||
"""Create role with specific name
|
"""Create role with specific name
|
||||||
@ -143,10 +199,51 @@ class Identity(service.UnifiedOpenStackService):
|
|||||||
"""Get role."""
|
"""Get role."""
|
||||||
return self._impl.get_role(role_id)
|
return self._impl.get_role(role_id)
|
||||||
|
|
||||||
@staticmethod
|
@service.should_be_overridden
|
||||||
def _unify_service(service):
|
def get_service_by_name(self, name):
|
||||||
return Service(id=service.id, name=service.name)
|
"""List all services to find proper one."""
|
||||||
|
return self._impl.get_service_by_name(name)
|
||||||
|
|
||||||
@staticmethod
|
@service.should_be_overridden
|
||||||
def _unify_role(role):
|
def create_ec2credentials(self, user_id, project_id):
|
||||||
return Role(id=role.id, name=role.name)
|
"""Create ec2credentials.
|
||||||
|
|
||||||
|
:param user_id: User ID for which to create credentials
|
||||||
|
:param project_id: Project ID for which to create credentials
|
||||||
|
|
||||||
|
:returns: Created ec2-credentials object
|
||||||
|
"""
|
||||||
|
return self._impl.create_ec2credentials(user_id=user_id,
|
||||||
|
project_id=project_id)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def list_ec2credentials(self, user_id):
|
||||||
|
"""List of access/secret pairs for a user_id.
|
||||||
|
|
||||||
|
:param user_id: List all ec2-credentials for User ID
|
||||||
|
|
||||||
|
:returns: Return ec2-credentials list
|
||||||
|
"""
|
||||||
|
return self._impl.list_ec2credentials(user_id)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def delete_ec2credential(self, user_id, access):
|
||||||
|
"""Delete ec2credential.
|
||||||
|
|
||||||
|
:param user_id: User ID for which to delete credential
|
||||||
|
:param access: access key for ec2credential to delete
|
||||||
|
"""
|
||||||
|
return self._impl.delete_ec2credential(user_id=user_id, access=access)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def fetch_token(self):
|
||||||
|
"""Authenticate user token."""
|
||||||
|
return self._impl.fetch_token()
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def validate_token(self, token):
|
||||||
|
"""Validate user token.
|
||||||
|
|
||||||
|
:param token: Auth token to validate
|
||||||
|
"""
|
||||||
|
return self._impl.validate_token(token)
|
||||||
|
192
rally/plugins/openstack/services/identity/keystone_common.py
Normal file
192
rally/plugins/openstack/services/identity/keystone_common.py
Normal file
@ -0,0 +1,192 @@
|
|||||||
|
# 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 rally import osclients
|
||||||
|
from rally.plugins.openstack.services.identity import identity
|
||||||
|
from rally.task import atomic
|
||||||
|
|
||||||
|
|
||||||
|
class UnifiedKeystoneMixin(object):
|
||||||
|
@staticmethod
|
||||||
|
def _unify_service(service):
|
||||||
|
return identity.Service(id=service.id, name=service.name)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _unify_role(role):
|
||||||
|
return identity.Role(id=role.id, name=role.name)
|
||||||
|
|
||||||
|
def delete_user(self, user_id):
|
||||||
|
"""Deletes user by its id."""
|
||||||
|
return self._impl.delete_user(user_id)
|
||||||
|
|
||||||
|
def get_user(self, user_id):
|
||||||
|
"""Get user."""
|
||||||
|
return self._unify_user(self._impl.get_user(user_id))
|
||||||
|
|
||||||
|
def create_service(self, name=None, service_type=None, description=None):
|
||||||
|
"""Creates keystone service."""
|
||||||
|
|
||||||
|
return self._unify_service(self._impl.create_service(
|
||||||
|
name=name, service_type=service_type, description=description))
|
||||||
|
|
||||||
|
def delete_service(self, service_id):
|
||||||
|
"""Deletes service."""
|
||||||
|
return self._impl.delete_service(service_id)
|
||||||
|
|
||||||
|
def get_service(self, service_id):
|
||||||
|
"""Get service."""
|
||||||
|
return self._unify_service(self._impl.get_service(service_id))
|
||||||
|
|
||||||
|
def get_service_by_name(self, name):
|
||||||
|
"""List all services to find proper one."""
|
||||||
|
return self._unify_service(self._impl.get_service_by_name(name))
|
||||||
|
|
||||||
|
def get_role(self, role_id):
|
||||||
|
"""Get role."""
|
||||||
|
return self._unify_role(self._impl.get_role(role_id))
|
||||||
|
|
||||||
|
def delete_role(self, role_id):
|
||||||
|
"""Deletes role."""
|
||||||
|
return self._impl.delete_role(role_id)
|
||||||
|
|
||||||
|
def list_ec2credentials(self, user_id):
|
||||||
|
"""List of access/secret pairs for a user_id.
|
||||||
|
|
||||||
|
:param user_id: List all ec2-credentials for User ID
|
||||||
|
|
||||||
|
:returns: Return ec2-credentials list
|
||||||
|
"""
|
||||||
|
return self._impl.list_ec2credentials(user_id)
|
||||||
|
|
||||||
|
def delete_ec2credential(self, user_id, access):
|
||||||
|
"""Delete ec2credential.
|
||||||
|
|
||||||
|
:param user_id: User ID for which to delete credential
|
||||||
|
:param access: access key for ec2credential to delete
|
||||||
|
"""
|
||||||
|
return self._impl.delete_ec2credential(user_id=user_id, access=access)
|
||||||
|
|
||||||
|
def fetch_token(self):
|
||||||
|
"""Authenticate user token."""
|
||||||
|
return self._impl.fetch_token()
|
||||||
|
|
||||||
|
def validate_token(self, token):
|
||||||
|
"""Validate user token.
|
||||||
|
|
||||||
|
:param token: Auth token to validate
|
||||||
|
"""
|
||||||
|
return self._impl.validate_token(token)
|
||||||
|
|
||||||
|
|
||||||
|
class KeystoneMixin(object):
|
||||||
|
|
||||||
|
def list_users(self):
|
||||||
|
aname = "keystone_v%s.list_users" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).users.list()
|
||||||
|
|
||||||
|
def delete_user(self, user_id):
|
||||||
|
"""Deletes user by its id."""
|
||||||
|
aname = "keystone_v%s.delete_user" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
self._clients.keystone(self.version).users.delete(user_id)
|
||||||
|
|
||||||
|
def get_user(self, user_id):
|
||||||
|
"""Get user by its id."""
|
||||||
|
aname = "keystone_v%s.get_user" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).users.get(user_id)
|
||||||
|
|
||||||
|
def delete_service(self, service_id):
|
||||||
|
"""Deletes service."""
|
||||||
|
aname = "keystone_v%s.delete_service" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
self._clients.keystone(self.version).services.delete(service_id)
|
||||||
|
|
||||||
|
def list_services(self):
|
||||||
|
"""List all services."""
|
||||||
|
aname = "keystone_v%s.list_services" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).services.list()
|
||||||
|
|
||||||
|
def get_service(self, service_id):
|
||||||
|
"""Get service."""
|
||||||
|
aname = "keystone_v%s.get_services" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).services.get(
|
||||||
|
service_id)
|
||||||
|
|
||||||
|
def get_service_by_name(self, name):
|
||||||
|
"""List all services to find proper one."""
|
||||||
|
for s in self.list_services():
|
||||||
|
if s.name == name:
|
||||||
|
return s
|
||||||
|
|
||||||
|
def delete_role(self, role_id):
|
||||||
|
"""Deletes role."""
|
||||||
|
aname = "keystone_v%s.delete_role" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
self._clients.keystone(self.version).roles.delete(role_id)
|
||||||
|
|
||||||
|
def list_roles(self):
|
||||||
|
"""List all roles."""
|
||||||
|
aname = "keystone_v%s.list_roles" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).roles.list()
|
||||||
|
|
||||||
|
def get_role(self, role_id):
|
||||||
|
"""Get role."""
|
||||||
|
aname = "keystone_v%s.get_role" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).roles.get(role_id)
|
||||||
|
|
||||||
|
def list_ec2credentials(self, user_id):
|
||||||
|
"""List of access/secret pairs for a user_id.
|
||||||
|
|
||||||
|
:param user_id: List all ec2-credentials for User ID
|
||||||
|
|
||||||
|
:returns: Return ec2-credentials list
|
||||||
|
"""
|
||||||
|
aname = "keystone_v%s.list_ec2creds" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
return self._clients.keystone(self.version).ec2.list(user_id)
|
||||||
|
|
||||||
|
def delete_ec2credential(self, user_id, access):
|
||||||
|
"""Delete ec2credential.
|
||||||
|
|
||||||
|
:param user_id: User ID for which to delete credential
|
||||||
|
:param access: access key for ec2credential to delete
|
||||||
|
"""
|
||||||
|
aname = "keystone_v%s.delete_ec2creds" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
self._clients.keystone(self.version).ec2.delete(user_id=user_id,
|
||||||
|
access=access)
|
||||||
|
|
||||||
|
def fetch_token(self):
|
||||||
|
"""Authenticate user token."""
|
||||||
|
cred = self._clients.credential
|
||||||
|
aname = "keystone_v%s.fetch_token" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
clients = osclients.Clients(credential=cred,
|
||||||
|
api_info=self._clients.api_info)
|
||||||
|
return clients.keystone.auth_ref.auth_token
|
||||||
|
|
||||||
|
def validate_token(self, token):
|
||||||
|
"""Validate user token.
|
||||||
|
|
||||||
|
:param token: Auth token to validate
|
||||||
|
"""
|
||||||
|
aname = "keystone_v%s.validate_token" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
self._clients.keystone(self.version).tokens.validate(token)
|
@ -12,19 +12,41 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
import uuid
|
||||||
|
|
||||||
from rally.plugins.openstack import service
|
from rally.plugins.openstack import service
|
||||||
from rally.plugins.openstack.services.identity import identity
|
from rally.plugins.openstack.services.identity import identity
|
||||||
|
from rally.plugins.openstack.services.identity import keystone_common
|
||||||
from rally.task import atomic
|
from rally.task import atomic
|
||||||
|
|
||||||
|
|
||||||
@service.service("keystone", service_type="identity", version="2")
|
@service.service("keystone", service_type="identity", version="2")
|
||||||
class KeystoneV2Service(service.Service):
|
class KeystoneV2Service(service.Service, keystone_common.KeystoneMixin):
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.create_tenant")
|
@atomic.action_timer("keystone_v2.create_tenant")
|
||||||
def create_tenant(self, tenant_name=None):
|
def create_tenant(self, tenant_name=None):
|
||||||
tenant_name = tenant_name or self.generate_random_name()
|
tenant_name = tenant_name or self.generate_random_name()
|
||||||
return self._clients.keystone("2").tenants.create(tenant_name)
|
return self._clients.keystone("2").tenants.create(tenant_name)
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v2.update_tenant")
|
||||||
|
def update_tenant(self, tenant_id, name=None, enabled=None,
|
||||||
|
description=None):
|
||||||
|
"""Update tenant name and description.
|
||||||
|
|
||||||
|
:param tenant_id: Id of tenant to update
|
||||||
|
:param name: tenant name to be set (if boolean True, random name will
|
||||||
|
be set)
|
||||||
|
:param enabled: enabled status of project
|
||||||
|
:param description: tenant description to be set (if boolean True,
|
||||||
|
random description will be set)
|
||||||
|
"""
|
||||||
|
if name is True:
|
||||||
|
name = self.generate_random_name()
|
||||||
|
if description is True:
|
||||||
|
description = self.generate_random_name()
|
||||||
|
self._clients.keystone("2").tenants.update(
|
||||||
|
tenant_id, name=name, description=description, enabled=enabled)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.delete_tenant")
|
@atomic.action_timer("keystone_v2.delete_tenant")
|
||||||
def delete_tenant(self, tenant_id):
|
def delete_tenant(self, tenant_id):
|
||||||
return self._clients.keystone("2").tenants.delete(tenant_id)
|
return self._clients.keystone("2").tenants.delete(tenant_id)
|
||||||
@ -33,31 +55,69 @@ class KeystoneV2Service(service.Service):
|
|||||||
def list_tenants(self):
|
def list_tenants(self):
|
||||||
return self._clients.keystone("2").tenants.list()
|
return self._clients.keystone("2").tenants.list()
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v2.get_tenant")
|
||||||
|
def get_tenant(self, tenant_id):
|
||||||
|
"""Get tenant."""
|
||||||
|
return self._clients.keystone("2").tenants.get(tenant_id)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.create_user")
|
@atomic.action_timer("keystone_v2.create_user")
|
||||||
def create_user(self, username, password, email=None, tenant_id=None):
|
def create_user(self, username=None, password=None, email=None,
|
||||||
|
tenant_id=None, enabled=True):
|
||||||
|
username = username or self.generate_random_name()
|
||||||
|
password = password or str(uuid.uuid4())
|
||||||
|
email = email or (username + "@rally.me")
|
||||||
return self._clients.keystone("2").users.create(name=username,
|
return self._clients.keystone("2").users.create(name=username,
|
||||||
password=password,
|
password=password,
|
||||||
email=email,
|
email=email,
|
||||||
tenant_id=tenant_id)
|
tenant_id=tenant_id,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.list_users")
|
@atomic.action_timer("keystone_v2.create_users")
|
||||||
def list_users(self):
|
def create_users(self, tenant_id, number_of_users, user_create_args=None):
|
||||||
return self._clients.keystone("2").users.list()
|
"""Create specified amount of users.
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.delete_user")
|
:param tenant_id: Id of tenant
|
||||||
def delete_user(self, user_id):
|
:param number_of_users: number of users to create
|
||||||
"""Deletes user by its id."""
|
:param user_create_args: additional user creation arguments
|
||||||
self._clients.keystone("2").users.delete(user_id)
|
"""
|
||||||
|
users = []
|
||||||
|
for _i in range(number_of_users):
|
||||||
|
users.append(self.create_user(tenant_id=tenant_id,
|
||||||
|
**(user_create_args or {})))
|
||||||
|
return users
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.delete_service")
|
@atomic.action_timer("keystone_v2.update_user")
|
||||||
def delete_service(self, service_id):
|
def update_user(self, user_id, **kwargs):
|
||||||
"""Deletes service."""
|
allowed_args = ("name", "email", "enabled")
|
||||||
self._clients.keystone("2").services.delete(service_id)
|
restricted = set(kwargs) - set(allowed_args)
|
||||||
|
if restricted:
|
||||||
|
raise NotImplementedError(
|
||||||
|
"Failed to update '%s', since Keystone V2 allows to update "
|
||||||
|
"only '%s'." % ("', '".join(restricted),
|
||||||
|
"', '".join(allowed_args)))
|
||||||
|
self._clients.keystone("2").users.update(user_id, **kwargs)
|
||||||
|
|
||||||
@atomic.action_timer("keystone.list_services")
|
@atomic.action_timer("keystone_v2.update_user_password")
|
||||||
def list_services(self):
|
def update_user_password(self, user_id, password):
|
||||||
"""List all services."""
|
self._clients.keystone("2").users.update_password(user_id,
|
||||||
return self._clients.keystone("2").services.list()
|
password=password)
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v2.create_service")
|
||||||
|
def create_service(self, name=None, service_type=None, description=None):
|
||||||
|
"""Creates keystone service.
|
||||||
|
|
||||||
|
:param name: name of service to create
|
||||||
|
:param service_type: type of the service
|
||||||
|
:param description: description of the service
|
||||||
|
:returns: keystone service instance
|
||||||
|
"""
|
||||||
|
name = name or self.generate_random_name()
|
||||||
|
service_type = service_type or "rally_test_type"
|
||||||
|
description = description or self.generate_random_name()
|
||||||
|
return self._clients.keystone("2").services.create(
|
||||||
|
name,
|
||||||
|
service_type=service_type,
|
||||||
|
description=description)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.create_role")
|
@atomic.action_timer("keystone_v2.create_role")
|
||||||
def create_role(self, name=None):
|
def create_role(self, name=None):
|
||||||
@ -66,14 +126,9 @@ class KeystoneV2Service(service.Service):
|
|||||||
|
|
||||||
@atomic.action_timer("keystone_v2.add_role")
|
@atomic.action_timer("keystone_v2.add_role")
|
||||||
def add_role(self, role_id, user_id, tenant_id):
|
def add_role(self, role_id, user_id, tenant_id):
|
||||||
return self._clients.keystone("2").roles.add_user_role(
|
self._clients.keystone("2").roles.add_user_role(
|
||||||
user=user_id, role=role_id, tenant=tenant_id)
|
user=user_id, role=role_id, tenant=tenant_id)
|
||||||
|
|
||||||
@atomic.action_timer("keystone.delete_role")
|
|
||||||
def delete_role(self, role_id):
|
|
||||||
"""Deletes role."""
|
|
||||||
self._clients.keystone("2").roles.delete(role_id)
|
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.list_roles")
|
@atomic.action_timer("keystone_v2.list_roles")
|
||||||
def list_roles(self):
|
def list_roles(self):
|
||||||
"""List all roles."""
|
"""List all roles."""
|
||||||
@ -90,14 +145,22 @@ class KeystoneV2Service(service.Service):
|
|||||||
role=role_id,
|
role=role_id,
|
||||||
tenant=tenant_id)
|
tenant=tenant_id)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v2.get_role")
|
@atomic.action_timer("keystone_v2.create_ec2creds")
|
||||||
def get_role(self, role_id):
|
def create_ec2credentials(self, user_id, tenant_id):
|
||||||
"""Get role."""
|
"""Create ec2credentials.
|
||||||
return self._clients.keystone("2").roles.get(role_id)
|
|
||||||
|
:param user_id: User ID for which to create credentials
|
||||||
|
:param tenant_id: Tenant ID for which to create credentials
|
||||||
|
|
||||||
|
:returns: Created ec2-credentials object
|
||||||
|
"""
|
||||||
|
return self._clients.keystone("2").ec2.create(user_id,
|
||||||
|
tenant_id=tenant_id)
|
||||||
|
|
||||||
|
|
||||||
@service.compat_layer(KeystoneV2Service)
|
@service.compat_layer(KeystoneV2Service)
|
||||||
class UnifiedKeystoneV2Service(identity.Identity):
|
class UnifiedKeystoneV2Service(keystone_common.UnifiedKeystoneMixin,
|
||||||
|
identity.Identity):
|
||||||
"""Compatibility layer for Keystone V2."""
|
"""Compatibility layer for Keystone V2."""
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
@ -128,6 +191,18 @@ class UnifiedKeystoneV2Service(identity.Identity):
|
|||||||
tenant = self._impl.create_tenant(project_name)
|
tenant = self._impl.create_tenant(project_name)
|
||||||
return self._unify_tenant(tenant)
|
return self._unify_tenant(tenant)
|
||||||
|
|
||||||
|
def update_project(self, project_id, name=None, enabled=None,
|
||||||
|
description=None):
|
||||||
|
"""Update project name, enabled and description
|
||||||
|
|
||||||
|
:param project_id: Id of project to update
|
||||||
|
:param name: project name to be set
|
||||||
|
:param enabled: enabled status of project
|
||||||
|
:param description: project description to be set
|
||||||
|
"""
|
||||||
|
self._impl.update_tenant(tenant_id=project_id, name=name,
|
||||||
|
enabled=enabled, description=description)
|
||||||
|
|
||||||
def delete_project(self, project_id):
|
def delete_project(self, project_id):
|
||||||
"""Deletes project."""
|
"""Deletes project."""
|
||||||
return self._impl.delete_tenant(project_id)
|
return self._impl.delete_tenant(project_id)
|
||||||
@ -136,37 +211,64 @@ class UnifiedKeystoneV2Service(identity.Identity):
|
|||||||
"""List all projects."""
|
"""List all projects."""
|
||||||
return [self._unify_tenant(t) for t in self._impl.list_tenants()]
|
return [self._unify_tenant(t) for t in self._impl.list_tenants()]
|
||||||
|
|
||||||
def create_user(self, username, password, email=None, project_id=None,
|
def get_project(self, project_id):
|
||||||
domain_name="Default", default_role="member"):
|
"""Get project."""
|
||||||
|
return self._unify_tenant(self._impl.get_tenant(project_id))
|
||||||
|
|
||||||
|
def create_user(self, username=None, password=None, project_id=None,
|
||||||
|
domain_name="Default", enabled=True,
|
||||||
|
default_role="member"):
|
||||||
"""Create user.
|
"""Create user.
|
||||||
|
|
||||||
:param username: name of user
|
:param username: name of user
|
||||||
:param password: user password
|
:param password: user password
|
||||||
:param email: user's email
|
|
||||||
:param project_id: user's default project
|
:param project_id: user's default project
|
||||||
:param domain_name: Restricted for Keystone V2. Should not be set or
|
:param domain_name: Restricted for Keystone V2. Should not be set or
|
||||||
"Default" is expected.
|
"Default" is expected.
|
||||||
|
:param enabled: whether the user is enabled.
|
||||||
:param default_role: Restricted for Keystone V2. Should not be set or
|
:param default_role: Restricted for Keystone V2. Should not be set or
|
||||||
"member" is expected.
|
"member" is expected.
|
||||||
"""
|
"""
|
||||||
self._check_domain(domain_name)
|
self._check_domain(domain_name)
|
||||||
user = self._impl.create_user(username=username,
|
user = self._impl.create_user(username=username,
|
||||||
password=password,
|
password=password,
|
||||||
email=email,
|
tenant_id=project_id,
|
||||||
tenant_id=project_id)
|
enabled=enabled)
|
||||||
return self._unify_user(user)
|
return self._unify_user(user)
|
||||||
|
|
||||||
def delete_user(self, user_id):
|
def create_users(self, tenant_id, number_of_users, user_create_args=None):
|
||||||
"""Deletes user by its id."""
|
"""Create specified amount of users.
|
||||||
return self._impl.delete_user(user_id)
|
|
||||||
|
:param tenant_id: Id of tenant
|
||||||
|
:param number_of_users: number of users to create
|
||||||
|
:param user_create_args: additional user creation arguments
|
||||||
|
"""
|
||||||
|
if user_create_args and "domain_name" in user_create_args:
|
||||||
|
self._check_domain(user_create_args["domain_name"])
|
||||||
|
return [self._unify_user(u)
|
||||||
|
for u in self._impl.create_users(
|
||||||
|
tenant_id=tenant_id, number_of_users=number_of_users,
|
||||||
|
user_create_args=user_create_args)]
|
||||||
|
|
||||||
def list_users(self):
|
def list_users(self):
|
||||||
"""List all users."""
|
"""List all users."""
|
||||||
return [self._unify_user(u) for u in self._impl.list_users()]
|
return [self._unify_user(u) for u in self._impl.list_users()]
|
||||||
|
|
||||||
def delete_service(self, service_id):
|
def update_user(self, user_id, enabled=None, name=None, email=None,
|
||||||
"""Deletes service."""
|
password=None):
|
||||||
return self._impl.delete_service(service_id)
|
if password is not None:
|
||||||
|
self._impl.update_user_password(user_id=user_id, password=password)
|
||||||
|
|
||||||
|
update_args = {}
|
||||||
|
if enabled is not None:
|
||||||
|
update_args["enabled"] = enabled
|
||||||
|
if name is not None:
|
||||||
|
update_args["name"] = name
|
||||||
|
if email is not None:
|
||||||
|
update_args["email"] = email
|
||||||
|
|
||||||
|
if update_args:
|
||||||
|
self._impl.update_user(user_id, **update_args)
|
||||||
|
|
||||||
def list_services(self):
|
def list_services(self):
|
||||||
"""List all services."""
|
"""List all services."""
|
||||||
@ -179,12 +281,8 @@ class UnifiedKeystoneV2Service(identity.Identity):
|
|||||||
|
|
||||||
def add_role(self, role_id, user_id, project_id):
|
def add_role(self, role_id, user_id, project_id):
|
||||||
"""Add role to user."""
|
"""Add role to user."""
|
||||||
return self._unify_role(self._impl.add_role(
|
self._impl.add_role(role_id=role_id, user_id=user_id,
|
||||||
role_id=role_id, user_id=user_id, tenant_id=project_id))
|
tenant_id=project_id)
|
||||||
|
|
||||||
def delete_role(self, role_id):
|
|
||||||
"""Deletes role."""
|
|
||||||
return self._impl.delete_role(role_id)
|
|
||||||
|
|
||||||
def revoke_role(self, role_id, user_id, project_id):
|
def revoke_role(self, role_id, user_id, project_id):
|
||||||
"""Revokes a role from a user."""
|
"""Revokes a role from a user."""
|
||||||
@ -203,6 +301,13 @@ class UnifiedKeystoneV2Service(identity.Identity):
|
|||||||
roles = self._impl.list_roles()
|
roles = self._impl.list_roles()
|
||||||
return [self._unify_role(role) for role in roles]
|
return [self._unify_role(role) for role in roles]
|
||||||
|
|
||||||
def get_role(self, role_id):
|
def create_ec2credentials(self, user_id, project_id):
|
||||||
"""Get role."""
|
"""Create ec2credentials.
|
||||||
return self._unify_role(self._impl.get_role(role_id))
|
|
||||||
|
:param user_id: User ID for which to create credentials
|
||||||
|
:param project_id: Project ID for which to create credentials
|
||||||
|
|
||||||
|
:returns: Created ec2-credentials object
|
||||||
|
"""
|
||||||
|
return self._impl.create_ec2credentials(user_id=user_id,
|
||||||
|
tenant_id=project_id)
|
||||||
|
@ -16,6 +16,7 @@ from rally.common import logging
|
|||||||
from rally import exceptions
|
from rally import exceptions
|
||||||
from rally.plugins.openstack import service
|
from rally.plugins.openstack import service
|
||||||
from rally.plugins.openstack.services.identity import identity
|
from rally.plugins.openstack.services.identity import identity
|
||||||
|
from rally.plugins.openstack.services.identity import keystone_common
|
||||||
from rally.task import atomic
|
from rally.task import atomic
|
||||||
|
|
||||||
|
|
||||||
@ -23,7 +24,7 @@ LOG = logging.getLogger(__name__)
|
|||||||
|
|
||||||
|
|
||||||
@service.service("keystone", service_type="identity", version="3")
|
@service.service("keystone", service_type="identity", version="3")
|
||||||
class KeystoneV3Service(service.Service):
|
class KeystoneV3Service(service.Service, keystone_common.KeystoneMixin):
|
||||||
|
|
||||||
def _get_domain_id(self, domain_name_or_id):
|
def _get_domain_id(self, domain_name_or_id):
|
||||||
from keystoneclient import exceptions as kc_exceptions
|
from keystoneclient import exceptions as kc_exceptions
|
||||||
@ -49,6 +50,25 @@ class KeystoneV3Service(service.Service):
|
|||||||
return self._clients.keystone("3").projects.create(name=project_name,
|
return self._clients.keystone("3").projects.create(name=project_name,
|
||||||
domain=domain_id)
|
domain=domain_id)
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v3.update_project")
|
||||||
|
def update_project(self, project_id, name=None, enabled=None,
|
||||||
|
description=None):
|
||||||
|
"""Update tenant name and description.
|
||||||
|
|
||||||
|
:param project_id: Id of project to update
|
||||||
|
:param name: project name to be set (if boolean True, random name will
|
||||||
|
be set)
|
||||||
|
:param enabled: enabled status of project
|
||||||
|
:param description: project description to be set (if boolean True,
|
||||||
|
random description will be set)
|
||||||
|
"""
|
||||||
|
if name is True:
|
||||||
|
name = self.generate_random_name()
|
||||||
|
if description is True:
|
||||||
|
description = self.generate_random_name()
|
||||||
|
self._clients.keystone("3").projects.update(
|
||||||
|
project_id, name=name, description=description, enabled=enabled)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.delete_project")
|
@atomic.action_timer("keystone_v3.delete_project")
|
||||||
def delete_project(self, project_id):
|
def delete_project(self, project_id):
|
||||||
self._clients.keystone("3").projects.delete(project_id)
|
self._clients.keystone("3").projects.delete(project_id)
|
||||||
@ -57,23 +77,33 @@ class KeystoneV3Service(service.Service):
|
|||||||
def list_projects(self):
|
def list_projects(self):
|
||||||
return self._clients.keystone("3").projects.list()
|
return self._clients.keystone("3").projects.list()
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v3.get_project")
|
||||||
|
def get_project(self, project_id):
|
||||||
|
"""Get project."""
|
||||||
|
return self._clients.keystone("3").projects.get(project_id)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.create_user")
|
@atomic.action_timer("keystone_v3.create_user")
|
||||||
def create_user(self, username, password, email=None, project_id=None,
|
def create_user(self, username=None, password=None, project_id=None,
|
||||||
domain_name="Default", default_role="member"):
|
domain_name="Default", enabled=True,
|
||||||
|
default_role="member"):
|
||||||
"""Create user.
|
"""Create user.
|
||||||
|
|
||||||
|
|
||||||
:param username: name of user
|
:param username: name of user
|
||||||
:param password: user password
|
:param password: user password
|
||||||
:param email: user'ss email
|
|
||||||
:param project_id: user's default project
|
:param project_id: user's default project
|
||||||
:param domain_name: Name or id of domain where to create project.
|
:param domain_name: Name or id of domain where to create project.
|
||||||
|
:param enabled: whether the user is enabled.
|
||||||
:param default_role: user's default role
|
:param default_role: user's default role
|
||||||
"""
|
"""
|
||||||
domain_id = self._get_domain_id(domain_name)
|
domain_id = self._get_domain_id(domain_name)
|
||||||
|
username = username or self.generate_random_name()
|
||||||
user = self._clients.keystone("3").users.create(
|
user = self._clients.keystone("3").users.create(
|
||||||
name=username, password=password, default_project=project_id,
|
name=username, password=password, default_project=project_id,
|
||||||
email=email, domain=domain_id)
|
domain=domain_id, enabled=enabled)
|
||||||
|
|
||||||
|
if project_id:
|
||||||
|
# we can't setup role without project_id
|
||||||
for role in self.list_roles():
|
for role in self.list_roles():
|
||||||
if default_role in role.name.lower():
|
if default_role in role.name.lower():
|
||||||
self.add_role(role_id=role.id,
|
self.add_role(role_id=role.id,
|
||||||
@ -85,24 +115,49 @@ class KeystoneV3Service(service.Service):
|
|||||||
default_role)
|
default_role)
|
||||||
return user
|
return user
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.list_users")
|
@atomic.action_timer("keystone_v3.create_users")
|
||||||
def list_users(self):
|
def create_users(self, project_id, number_of_users, user_create_args=None):
|
||||||
return self._clients.keystone("3").users.list()
|
"""Create specified amount of users.
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.delete_user")
|
:param project_id: Id of project
|
||||||
def delete_user(self, user_id):
|
:param number_of_users: number of users to create
|
||||||
"""Deletes user by its id."""
|
:param user_create_args: additional user creation arguments
|
||||||
self._clients.keystone("3").users.delete(user_id)
|
"""
|
||||||
|
users = []
|
||||||
|
for _i in range(number_of_users):
|
||||||
|
users.append(self.create_user(project_id=project_id,
|
||||||
|
**(user_create_args or {})))
|
||||||
|
return users
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.delete_service")
|
@atomic.action_timer("keystone_v3.update_user")
|
||||||
def delete_service(self, service_id):
|
def update_user(self, user_id, name=None, domain_name=None,
|
||||||
"""Deletes service."""
|
project_id=None, password=None, email=None,
|
||||||
self._clients.keystone("3").services.delete(service_id)
|
description=None, enabled=None, default_project=None):
|
||||||
|
domain = None
|
||||||
|
if domain_name:
|
||||||
|
domain = self._get_domain_id(domain_name)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.list_services")
|
self._clients.keystone("3").users.update(
|
||||||
def list_services(self):
|
user_id, name=name, domain=domain, project=project_id,
|
||||||
"""List all services."""
|
password=password, email=email, description=description,
|
||||||
return self._clients.keystone("3").services.list()
|
enabled=enabled, default_project=default_project)
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v3.create_service")
|
||||||
|
def create_service(self, name=None, service_type=None, description=None,
|
||||||
|
enabled=True):
|
||||||
|
"""Creates keystone service.
|
||||||
|
|
||||||
|
:param name: name of service to create
|
||||||
|
:param service_type: type of the service
|
||||||
|
:param description: description of the service
|
||||||
|
:param enabled: whether the service appears in the catalog
|
||||||
|
:returns: keystone service instance
|
||||||
|
"""
|
||||||
|
name = name or self.generate_random_name()
|
||||||
|
service_type = service_type or "rally_test_type"
|
||||||
|
description = description or self.generate_random_name()
|
||||||
|
return self._clients.keystone("3").services.create(
|
||||||
|
name, type=service_type, description=description, enabled=enabled)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.create_role")
|
@atomic.action_timer("keystone_v3.create_role")
|
||||||
def create_role(self, name=None, domain_name="Default"):
|
def create_role(self, name=None, domain_name="Default"):
|
||||||
@ -112,15 +167,10 @@ class KeystoneV3Service(service.Service):
|
|||||||
|
|
||||||
@atomic.action_timer("keystone_v3.add_role")
|
@atomic.action_timer("keystone_v3.add_role")
|
||||||
def add_role(self, role_id, user_id, project_id):
|
def add_role(self, role_id, user_id, project_id):
|
||||||
return self._clients.keystone("3").roles.grant(role=role_id,
|
self._clients.keystone("3").roles.grant(role=role_id,
|
||||||
user=user_id,
|
user=user_id,
|
||||||
project=project_id)
|
project=project_id)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.delete_role")
|
|
||||||
def delete_role(self, role_id):
|
|
||||||
"""Deletes role."""
|
|
||||||
self._clients.keystone("3").roles.delete(role_id)
|
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.list_roles")
|
@atomic.action_timer("keystone_v3.list_roles")
|
||||||
def list_roles(self, user_id=None, project_id=None, domain_name=None):
|
def list_roles(self, user_id=None, project_id=None, domain_name=None):
|
||||||
"""List all roles."""
|
"""List all roles."""
|
||||||
@ -137,19 +187,27 @@ class KeystoneV3Service(service.Service):
|
|||||||
user=user_id,
|
user=user_id,
|
||||||
project=project_id)
|
project=project_id)
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.get_role")
|
|
||||||
def get_role(self, role_id):
|
|
||||||
"""Get role."""
|
|
||||||
return self._clients.keystone("3").roles.get(role_id)
|
|
||||||
|
|
||||||
@atomic.action_timer("keystone_v3.create_domain")
|
@atomic.action_timer("keystone_v3.create_domain")
|
||||||
def create_domain(self, name, description=None, enabled=True):
|
def create_domain(self, name, description=None, enabled=True):
|
||||||
return self._clients.keystone("3").domains.create(
|
return self._clients.keystone("3").domains.create(
|
||||||
name, description=description, enabled=enabled)
|
name, description=description, enabled=enabled)
|
||||||
|
|
||||||
|
@atomic.action_timer("keystone_v3.create_ec2creds")
|
||||||
|
def create_ec2credentials(self, user_id, project_id):
|
||||||
|
"""Create ec2credentials.
|
||||||
|
|
||||||
|
:param user_id: User ID for which to create credentials
|
||||||
|
:param project_id: Tenant ID for which to create credentials
|
||||||
|
|
||||||
|
:returns: Created ec2-credentials object
|
||||||
|
"""
|
||||||
|
return self._clients.keystone("3").ec2.create(user_id,
|
||||||
|
project_id=project_id)
|
||||||
|
|
||||||
|
|
||||||
@service.compat_layer(KeystoneV3Service)
|
@service.compat_layer(KeystoneV3Service)
|
||||||
class UnifiedKeystoneV3Service(identity.Identity):
|
class UnifiedKeystoneV3Service(keystone_common.UnifiedKeystoneMixin,
|
||||||
|
identity.Identity):
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _unify_project(project):
|
def _unify_project(project):
|
||||||
@ -160,7 +218,8 @@ class UnifiedKeystoneV3Service(identity.Identity):
|
|||||||
def _unify_user(user):
|
def _unify_user(user):
|
||||||
# When user has default_project_id that is None user.default_project_id
|
# When user has default_project_id that is None user.default_project_id
|
||||||
# will raise AttributeError
|
# will raise AttributeError
|
||||||
project_id = getattr(user, "default_project_id", None)
|
project_id = getattr(user, "project_id",
|
||||||
|
getattr(user, "default_project_id", None))
|
||||||
return identity.User(id=user.id, name=user.name, project_id=project_id,
|
return identity.User(id=user.id, name=user.name, project_id=project_id,
|
||||||
domain_id=user.domain_id)
|
domain_id=user.domain_id)
|
||||||
|
|
||||||
@ -173,6 +232,18 @@ class UnifiedKeystoneV3Service(identity.Identity):
|
|||||||
project = self._impl.create_project(project_name)
|
project = self._impl.create_project(project_name)
|
||||||
return self._unify_project(project)
|
return self._unify_project(project)
|
||||||
|
|
||||||
|
def update_project(self, project_id, name=None, enabled=None,
|
||||||
|
description=None):
|
||||||
|
"""Update project name, enabled and description
|
||||||
|
|
||||||
|
:param project_id: Id of project to update
|
||||||
|
:param name: project name to be set
|
||||||
|
:param enabled: enabled status of project
|
||||||
|
:param description: project description to be set
|
||||||
|
"""
|
||||||
|
self._impl.update_project(project_id=project_id, name=name,
|
||||||
|
enabled=enabled, description=description)
|
||||||
|
|
||||||
def delete_project(self, project_id):
|
def delete_project(self, project_id):
|
||||||
"""Deletes project."""
|
"""Deletes project."""
|
||||||
return self._impl.delete_project(project_id)
|
return self._impl.delete_project(project_id)
|
||||||
@ -181,33 +252,47 @@ class UnifiedKeystoneV3Service(identity.Identity):
|
|||||||
"""List all projects."""
|
"""List all projects."""
|
||||||
return [self._unify_project(p) for p in self._impl.list_projects()]
|
return [self._unify_project(p) for p in self._impl.list_projects()]
|
||||||
|
|
||||||
def create_user(self, username, password, email=None, project_id=None,
|
def get_project(self, project_id):
|
||||||
domain_name="Default", default_role="member"):
|
"""Get project."""
|
||||||
|
return self._unify_project(self._impl.get_project(project_id))
|
||||||
|
|
||||||
|
def create_user(self, username=None, password=None, project_id=None,
|
||||||
|
domain_name="Default", enabled=True,
|
||||||
|
default_role="member"):
|
||||||
"""Create user.
|
"""Create user.
|
||||||
|
|
||||||
:param username: name of user
|
:param username: name of user
|
||||||
:param password: user password
|
:param password: user password
|
||||||
:param email: user's email
|
|
||||||
:param project_id: user's default project
|
:param project_id: user's default project
|
||||||
:param domain_name: Name or id of domain where to create project,
|
:param domain_name: Name or id of domain where to create project,
|
||||||
|
:param enabled: whether the user is enabled.
|
||||||
:param default_role: Name of default user's role
|
:param default_role: Name of default user's role
|
||||||
"""
|
"""
|
||||||
return self._unify_user(self._impl.create_user(
|
return self._unify_user(self._impl.create_user(
|
||||||
username=username, password=password, email=email,
|
username=username, password=password, project_id=project_id,
|
||||||
project_id=project_id, domain_name=domain_name,
|
domain_name=domain_name, default_role=default_role,
|
||||||
default_role=default_role))
|
enabled=enabled))
|
||||||
|
|
||||||
def delete_user(self, user_id):
|
def create_users(self, project_id, number_of_users, user_create_args=None):
|
||||||
"""Deletes user by its id."""
|
"""Create specified amount of users.
|
||||||
return self._impl.delete_user(user_id)
|
|
||||||
|
:param project_id: Id of project
|
||||||
|
:param number_of_users: number of users to create
|
||||||
|
:param user_create_args: additional user creation arguments
|
||||||
|
"""
|
||||||
|
return [self._unify_user(u)
|
||||||
|
for u in self._impl.create_users(
|
||||||
|
project_id=project_id, number_of_users=number_of_users,
|
||||||
|
user_create_args=user_create_args)]
|
||||||
|
|
||||||
def list_users(self):
|
def list_users(self):
|
||||||
"""List all users."""
|
"""List all users."""
|
||||||
return [self._unify_user(u) for u in self._impl.list_users()]
|
return [self._unify_user(u) for u in self._impl.list_users()]
|
||||||
|
|
||||||
def delete_service(self, service_id):
|
def update_user(self, user_id, enabled=None, name=None, email=None,
|
||||||
"""Deletes service."""
|
password=None):
|
||||||
return self._impl.delete_service(service_id)
|
return self._impl.update_user(user_id, enabled=enabled, name=name,
|
||||||
|
email=email, password=password)
|
||||||
|
|
||||||
def list_services(self):
|
def list_services(self):
|
||||||
"""List all services."""
|
"""List all services."""
|
||||||
@ -220,12 +305,8 @@ class UnifiedKeystoneV3Service(identity.Identity):
|
|||||||
|
|
||||||
def add_role(self, role_id, user_id, project_id):
|
def add_role(self, role_id, user_id, project_id):
|
||||||
"""Add role to user."""
|
"""Add role to user."""
|
||||||
return self._unify_role(self._impl.add_role(
|
self._impl.add_role(role_id=role_id, user_id=user_id,
|
||||||
role_id=role_id, user_id=user_id, project_id=project_id))
|
project_id=project_id)
|
||||||
|
|
||||||
def delete_role(self, role_id):
|
|
||||||
"""Deletes role."""
|
|
||||||
return self._impl.delete_role(role_id)
|
|
||||||
|
|
||||||
def revoke_role(self, role_id, user_id, project_id):
|
def revoke_role(self, role_id, user_id, project_id):
|
||||||
"""Revokes a role from a user."""
|
"""Revokes a role from a user."""
|
||||||
@ -237,6 +318,13 @@ class UnifiedKeystoneV3Service(identity.Identity):
|
|||||||
return [self._unify_role(role) for role in self._impl.list_roles(
|
return [self._unify_role(role) for role in self._impl.list_roles(
|
||||||
user_id=user_id, project_id=project_id, domain_name=domain_name)]
|
user_id=user_id, project_id=project_id, domain_name=domain_name)]
|
||||||
|
|
||||||
def get_role(self, role_id):
|
def create_ec2credentials(self, user_id, project_id):
|
||||||
"""Get role."""
|
"""Create ec2credentials.
|
||||||
return self._unify_role(self._impl.get_role(role_id))
|
|
||||||
|
:param user_id: User ID for which to create credentials
|
||||||
|
:param project_id: Project ID for which to create credentials
|
||||||
|
|
||||||
|
:returns: Created ec2-credentials object
|
||||||
|
"""
|
||||||
|
return self._impl.create_ec2credentials(user_id=user_id,
|
||||||
|
project_id=project_id)
|
||||||
|
@ -21,23 +21,38 @@ from tests.unit import test
|
|||||||
|
|
||||||
class CeilometerEventsTestCase(test.ScenarioTestCase):
|
class CeilometerEventsTestCase(test.ScenarioTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(CeilometerEventsTestCase, self).setUp()
|
||||||
|
patch = mock.patch(
|
||||||
|
"rally.plugins.openstack.services.identity.identity.Identity")
|
||||||
|
self.addCleanup(patch.stop)
|
||||||
|
self.mock_identity = patch.start()
|
||||||
|
|
||||||
|
def get_test_context(self):
|
||||||
|
context = super(CeilometerEventsTestCase, self).get_test_context()
|
||||||
|
context["admin"] = {"id": "fake_user_id",
|
||||||
|
"credential": mock.MagicMock()
|
||||||
|
}
|
||||||
|
return context
|
||||||
|
|
||||||
def test_list_events(self):
|
def test_list_events(self):
|
||||||
scenario = events.CeilometerEventsCreateUserAndListEvents(self.context)
|
scenario = events.CeilometerEventsCreateUserAndListEvents(self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_events = mock.MagicMock()
|
scenario._list_events = mock.MagicMock()
|
||||||
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_events.assert_called_once_with()
|
scenario._list_events.assert_called_once_with()
|
||||||
|
|
||||||
def test_list_events_fails(self):
|
def test_list_events_fails(self):
|
||||||
scenario = events.CeilometerEventsCreateUserAndListEvents(self.context)
|
scenario = events.CeilometerEventsCreateUserAndListEvents(self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_events = mock.MagicMock(return_value=[])
|
scenario._list_events = mock.MagicMock(return_value=[])
|
||||||
|
|
||||||
self.assertRaises(exceptions.RallyException, scenario.run)
|
self.assertRaises(exceptions.RallyException, scenario.run)
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_events.assert_called_once_with()
|
scenario._list_events.assert_called_once_with()
|
||||||
|
|
||||||
def test_list_event_types(self):
|
def test_list_event_types(self):
|
||||||
@ -45,43 +60,44 @@ class CeilometerEventsTestCase(test.ScenarioTestCase):
|
|||||||
self.context)
|
self.context)
|
||||||
|
|
||||||
scenario._list_event_types = mock.MagicMock()
|
scenario._list_event_types = mock.MagicMock()
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_event_types.assert_called_once_with()
|
scenario._list_event_types.assert_called_once_with()
|
||||||
|
|
||||||
def test_list_event_types_fails(self):
|
def test_list_event_types_fails(self):
|
||||||
scenario = events.CeilometerEventsCreateUserAndListEventTypes(
|
scenario = events.CeilometerEventsCreateUserAndListEventTypes(
|
||||||
self.context)
|
self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_event_types = mock.MagicMock(return_value=[])
|
scenario._list_event_types = mock.MagicMock(return_value=[])
|
||||||
|
|
||||||
self.assertRaises(exceptions.RallyException, scenario.run)
|
self.assertRaises(exceptions.RallyException, scenario.run)
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_event_types.assert_called_once_with()
|
scenario._list_event_types.assert_called_once_with()
|
||||||
|
|
||||||
def test_get_event(self):
|
def test_get_event(self):
|
||||||
scenario = events.CeilometerEventsCreateUserAndGetEvent(self.context)
|
scenario = events.CeilometerEventsCreateUserAndGetEvent(self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_events = mock.MagicMock()
|
|
||||||
scenario._get_event = mock.MagicMock()
|
scenario._get_event = mock.MagicMock()
|
||||||
scenario._list_events.return_value = [mock.Mock(message_id="fake_id")]
|
scenario._list_events = mock.MagicMock(
|
||||||
|
return_value=[mock.Mock(message_id="fake_id")])
|
||||||
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_events.assert_called_with()
|
scenario._list_events.assert_called_with()
|
||||||
scenario._get_event.assert_called_with(event_id="fake_id")
|
scenario._get_event.assert_called_with(event_id="fake_id")
|
||||||
|
|
||||||
def test_get_event_fails(self):
|
def test_get_event_fails(self):
|
||||||
scenario = events.CeilometerEventsCreateUserAndGetEvent(self.context)
|
scenario = events.CeilometerEventsCreateUserAndGetEvent(self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_events = mock.MagicMock(return_value=[])
|
scenario._list_events = mock.MagicMock(return_value=[])
|
||||||
scenario._get_event = mock.MagicMock()
|
scenario._get_event = mock.MagicMock()
|
||||||
|
|
||||||
self.assertRaises(exceptions.RallyException, scenario.run)
|
self.assertRaises(exceptions.RallyException, scenario.run)
|
||||||
|
|
||||||
scenario._user_create.assert_called_once_with()
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_events.assert_called_with()
|
scenario._list_events.assert_called_with()
|
||||||
self.assertFalse(scenario._get_event.called)
|
self.assertFalse(scenario._get_event.called)
|
||||||
|
@ -20,18 +20,33 @@ from tests.unit import test
|
|||||||
|
|
||||||
class CeilometerTraitsTestCase(test.ScenarioTestCase):
|
class CeilometerTraitsTestCase(test.ScenarioTestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(CeilometerTraitsTestCase, self).setUp()
|
||||||
|
patch = mock.patch(
|
||||||
|
"rally.plugins.openstack.services.identity.identity.Identity")
|
||||||
|
self.addCleanup(patch.stop)
|
||||||
|
self.mock_identity = patch.start()
|
||||||
|
|
||||||
|
def get_test_context(self):
|
||||||
|
context = super(CeilometerTraitsTestCase, self).get_test_context()
|
||||||
|
context["admin"] = {"id": "fake_user_id",
|
||||||
|
"credential": mock.MagicMock()
|
||||||
|
}
|
||||||
|
return context
|
||||||
|
|
||||||
def test_list_traits(self):
|
def test_list_traits(self):
|
||||||
scenario = traits.CreateUserAndListTraits(self.context)
|
scenario = traits.CreateUserAndListTraits(self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_events = mock.MagicMock()
|
|
||||||
scenario._list_event_traits = mock.MagicMock()
|
scenario._list_event_traits = mock.MagicMock()
|
||||||
scenario._list_events.return_value = [mock.Mock(
|
scenario._list_events = mock.MagicMock(
|
||||||
|
return_value=[mock.Mock(
|
||||||
event_type="fake_event_type",
|
event_type="fake_event_type",
|
||||||
traits=[{"name": "fake_trait_name"}])
|
traits=[{"name": "fake_trait_name"}])
|
||||||
]
|
])
|
||||||
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_events.assert_called_with()
|
scenario._list_events.assert_called_with()
|
||||||
scenario._list_event_traits.assert_called_once_with(
|
scenario._list_event_traits.assert_called_once_with(
|
||||||
event_type="fake_event_type", trait_name="fake_trait_name")
|
event_type="fake_event_type", trait_name="fake_trait_name")
|
||||||
@ -40,14 +55,15 @@ class CeilometerTraitsTestCase(test.ScenarioTestCase):
|
|||||||
scenario = traits.CreateUserAndListTraitDescriptions(
|
scenario = traits.CreateUserAndListTraitDescriptions(
|
||||||
self.context)
|
self.context)
|
||||||
|
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_events = mock.MagicMock()
|
|
||||||
scenario._list_event_trait_descriptions = mock.MagicMock()
|
scenario._list_event_trait_descriptions = mock.MagicMock()
|
||||||
scenario._list_events.return_value = [mock.Mock(
|
scenario._list_events = mock.MagicMock(
|
||||||
|
return_value=[mock.Mock(
|
||||||
event_type="fake_event_type")
|
event_type="fake_event_type")
|
||||||
]
|
])
|
||||||
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._user_create.assert_called_once_with()
|
|
||||||
|
self.mock_identity.return_value.create_user.assert_called_once_with()
|
||||||
scenario._list_events.assert_called_with()
|
scenario._list_events.assert_called_with()
|
||||||
scenario._list_event_trait_descriptions.assert_called_once_with(
|
scenario._list_event_trait_descriptions.assert_called_once_with(
|
||||||
event_type="fake_event_type")
|
event_type="fake_event_type")
|
||||||
|
@ -48,88 +48,91 @@ class KeystoneBasicTestCase(test.ScenarioTestCase):
|
|||||||
|
|
||||||
def test_create_user(self):
|
def test_create_user(self):
|
||||||
scenario = basic.CreateUser(self.context)
|
scenario = basic.CreateUser(self.context)
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario.run(password="tttt", tenant_id="id")
|
scenario.run(password="tttt", project_id="id")
|
||||||
scenario._user_create.assert_called_once_with(password="tttt",
|
self.mock_identity.return_value.create_user.assert_called_once_with(
|
||||||
tenant_id="id")
|
password="tttt", project_id="id")
|
||||||
|
|
||||||
def test_create_delete_user(self):
|
def test_create_delete_user(self):
|
||||||
create_result = mock.MagicMock()
|
identity_service = self.mock_identity.return_value
|
||||||
|
|
||||||
|
fake_email = "abcd"
|
||||||
|
fake_user = identity_service.create_user.return_value
|
||||||
|
|
||||||
scenario = basic.CreateDeleteUser(self.context)
|
scenario = basic.CreateDeleteUser(self.context)
|
||||||
scenario._user_create = mock.MagicMock(return_value=create_result)
|
|
||||||
scenario._resource_delete = mock.MagicMock()
|
|
||||||
|
|
||||||
scenario.run(email="abcd", enabled=True)
|
scenario.run(email=fake_email, enabled=True)
|
||||||
|
|
||||||
scenario._user_create.assert_called_once_with(email="abcd",
|
identity_service.create_user.assert_called_once_with(
|
||||||
enabled=True)
|
email=fake_email, enabled=True)
|
||||||
scenario._resource_delete.assert_called_once_with(create_result)
|
identity_service.delete_user.assert_called_once_with(fake_user.id)
|
||||||
|
|
||||||
def test_create_user_set_enabled_and_delete(self):
|
def test_create_user_set_enabled_and_delete(self):
|
||||||
scenario = basic.CreateUserSetEnabledAndDelete(self.context)
|
identity_service = self.mock_identity.return_value
|
||||||
scenario._user_create = mock.Mock()
|
|
||||||
scenario._update_user_enabled = mock.Mock()
|
|
||||||
scenario._resource_delete = mock.Mock()
|
|
||||||
|
|
||||||
scenario.run(enabled=True, email="abcd")
|
scenario = basic.CreateUserSetEnabledAndDelete(self.context)
|
||||||
scenario._user_create.assert_called_once_with(email="abcd",
|
|
||||||
enabled=True)
|
fake_email = "abcd"
|
||||||
scenario._update_user_enabled.assert_called_once_with(
|
fake_user = identity_service.create_user.return_value
|
||||||
scenario._user_create.return_value, False)
|
scenario.run(enabled=True, email=fake_email)
|
||||||
scenario._resource_delete.assert_called_once_with(
|
|
||||||
scenario._user_create.return_value)
|
identity_service.create_user.assert_called_once_with(
|
||||||
|
email=fake_email, enabled=True)
|
||||||
|
identity_service.update_user.assert_called_once_with(
|
||||||
|
fake_user.id, enabled=False)
|
||||||
|
identity_service.delete_user.assert_called_once_with(fake_user.id)
|
||||||
|
|
||||||
def test_user_authenticate_and_validate_token(self):
|
def test_user_authenticate_and_validate_token(self):
|
||||||
fake_token = mock.MagicMock()
|
identity_service = self.mock_identity.return_value
|
||||||
context = self.context
|
scenario = basic.AuthenticateUserAndValidateToken(self.context)
|
||||||
scenario = basic.AuthenticateUserAndValidateToken(context)
|
|
||||||
|
|
||||||
fake_user = context["user"]["credential"].username
|
fake_token = identity_service.fetch_token.return_value
|
||||||
fake_paswd = context["user"]["credential"].password
|
|
||||||
fake_tenant_id = context["tenant"]["id"]
|
|
||||||
fake_tenant_name = context["tenant"]["name"]
|
|
||||||
|
|
||||||
scenario._authenticate_token = mock.MagicMock(return_value=fake_token)
|
|
||||||
scenario._token_validate = mock.MagicMock()
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._authenticate_token.assert_called_once_with(
|
|
||||||
fake_user, fake_paswd, fake_tenant_id,
|
identity_service.fetch_token.assert_called_once_with()
|
||||||
fake_tenant_name, atomic_action=False)
|
identity_service.validate_token.assert_called_once_with(fake_token)
|
||||||
scenario._token_validate.assert_called_once_with(fake_token.id)
|
|
||||||
|
|
||||||
def test_create_tenant(self):
|
def test_create_tenant(self):
|
||||||
scenario = basic.CreateTenant(self.context)
|
scenario = basic.CreateTenant(self.context)
|
||||||
scenario._tenant_create = mock.MagicMock()
|
|
||||||
scenario.run(enabled=True)
|
scenario.run(enabled=True)
|
||||||
scenario._tenant_create.assert_called_once_with(enabled=True)
|
|
||||||
|
self.mock_identity.return_value.create_project.assert_called_once_with(
|
||||||
|
enabled=True)
|
||||||
|
|
||||||
def test_create_tenant_with_users(self):
|
def test_create_tenant_with_users(self):
|
||||||
|
identity_service = self.mock_identity.return_value
|
||||||
|
|
||||||
|
fake_project = identity_service.create_project.return_value
|
||||||
|
number_of_users = 1
|
||||||
|
|
||||||
scenario = basic.CreateTenantWithUsers(self.context)
|
scenario = basic.CreateTenantWithUsers(self.context)
|
||||||
fake_tenant = mock.MagicMock()
|
|
||||||
scenario._tenant_create = mock.MagicMock(return_value=fake_tenant)
|
scenario.run(users_per_tenant=number_of_users, enabled=True)
|
||||||
scenario._users_create = mock.MagicMock()
|
|
||||||
scenario.run(users_per_tenant=1, enabled=True)
|
identity_service.create_project.assert_called_once_with(enabled=True)
|
||||||
scenario._tenant_create.assert_called_once_with(enabled=True)
|
identity_service.create_users.assert_called_once_with(
|
||||||
scenario._users_create.assert_called_once_with(fake_tenant,
|
fake_project.id, number_of_users=number_of_users)
|
||||||
users_per_tenant=1)
|
|
||||||
|
|
||||||
def test_create_and_list_users(self):
|
def test_create_and_list_users(self):
|
||||||
scenario = basic.CreateAndListUsers(self.context)
|
scenario = basic.CreateAndListUsers(self.context)
|
||||||
scenario._user_create = mock.MagicMock()
|
|
||||||
scenario._list_users = mock.MagicMock()
|
passwd = "tttt"
|
||||||
scenario.run(password="tttt", tenant_id="id")
|
project_id = "id"
|
||||||
scenario._user_create.assert_called_once_with(password="tttt",
|
|
||||||
tenant_id="id")
|
scenario.run(password=passwd, project_id=project_id)
|
||||||
scenario._list_users.assert_called_once_with()
|
self.mock_identity.return_value.create_user.assert_called_once_with(
|
||||||
|
password=passwd, project_id=project_id)
|
||||||
|
self.mock_identity.return_value.list_users.assert_called_once_with()
|
||||||
|
|
||||||
def test_create_and_list_tenants(self):
|
def test_create_and_list_tenants(self):
|
||||||
|
identity_service = self.mock_identity.return_value
|
||||||
scenario = basic.CreateAndListTenants(self.context)
|
scenario = basic.CreateAndListTenants(self.context)
|
||||||
scenario._tenant_create = mock.MagicMock()
|
|
||||||
scenario._list_tenants = mock.MagicMock()
|
|
||||||
scenario.run(enabled=True)
|
scenario.run(enabled=True)
|
||||||
scenario._tenant_create.assert_called_once_with(enabled=True)
|
identity_service.create_project.assert_called_once_with(enabled=True)
|
||||||
scenario._list_tenants.assert_called_with()
|
identity_service.list_projects.assert_called_once_with()
|
||||||
|
|
||||||
def test_assign_and_remove_user_role(self):
|
def test_assign_and_remove_user_role(self):
|
||||||
fake_tenant = self.context["tenant"]["id"]
|
fake_tenant = self.context["tenant"]["id"]
|
||||||
@ -187,116 +190,127 @@ class KeystoneBasicTestCase(test.ScenarioTestCase):
|
|||||||
|
|
||||||
@ddt.data(None, "keystone", "fooservice")
|
@ddt.data(None, "keystone", "fooservice")
|
||||||
def test_get_entities(self, service_name):
|
def test_get_entities(self, service_name):
|
||||||
fake_tenant = mock.MagicMock()
|
identity_service = self.mock_identity.return_value
|
||||||
fake_user = mock.MagicMock()
|
|
||||||
fake_role = mock.MagicMock()
|
|
||||||
fake_service = mock.MagicMock()
|
|
||||||
|
|
||||||
self.mock_identity.return_value.create_role.return_value = fake_role
|
fake_project = identity_service.create_project.return_value
|
||||||
|
fake_user = identity_service.create_user.return_value
|
||||||
|
fake_role = identity_service.create_role.return_value
|
||||||
|
fake_service = identity_service.create_service.return_value
|
||||||
|
|
||||||
scenario = basic.GetEntities(self.context)
|
scenario = basic.GetEntities(self.context)
|
||||||
|
|
||||||
scenario._tenant_create = mock.MagicMock(return_value=fake_tenant)
|
|
||||||
scenario._user_create = mock.MagicMock(return_value=fake_user)
|
|
||||||
|
|
||||||
scenario._service_create = mock.MagicMock(return_value=fake_service)
|
|
||||||
|
|
||||||
scenario._get_tenant = mock.MagicMock(return_value=fake_tenant)
|
|
||||||
scenario._get_user = mock.MagicMock(return_value=fake_user)
|
|
||||||
scenario._get_role = mock.MagicMock(return_value=fake_role)
|
|
||||||
scenario._get_service_by_name = mock.MagicMock(
|
|
||||||
return_value=fake_service)
|
|
||||||
scenario._get_service = mock.MagicMock(return_value=fake_service)
|
|
||||||
|
|
||||||
scenario.run(service_name)
|
scenario.run(service_name)
|
||||||
|
|
||||||
scenario._tenant_create.assert_called_once_with()
|
identity_service.create_project.assert_called_once_with()
|
||||||
scenario._user_create.assert_called_once_with()
|
identity_service.create_user.assert_called_once_with(
|
||||||
self.mock_identity.return_value.create_role.assert_called_once_with()
|
project_id=fake_project.id)
|
||||||
|
identity_service.create_role.assert_called_once_with()
|
||||||
|
|
||||||
scenario._get_tenant.assert_called_once_with(fake_tenant.id)
|
identity_service.get_project.assert_called_once_with(fake_project.id)
|
||||||
scenario._get_user.assert_called_once_with(fake_user.id)
|
identity_service.get_user.assert_called_once_with(fake_user.id)
|
||||||
scenario._get_role.assert_called_once_with(fake_role.id)
|
identity_service.get_role.assert_called_once_with(fake_role.id)
|
||||||
|
|
||||||
if service_name is None:
|
if service_name is None:
|
||||||
scenario._service_create.assert_called_once_with()
|
identity_service.create_service.assert_called_once_with()
|
||||||
self.assertFalse(scenario._get_service_by_name.called)
|
self.assertFalse(identity_service.get_service_by_name.called)
|
||||||
|
identity_service.get_service.assert_called_once_with(
|
||||||
|
fake_service.id)
|
||||||
else:
|
else:
|
||||||
scenario._get_service_by_name.assert_called_once_with(service_name)
|
identity_service.get_service_by_name.assert_called_once_with(
|
||||||
self.assertFalse(scenario._service_create.called)
|
service_name)
|
||||||
scenario._get_service.assert_called_once_with(fake_service.id)
|
self.assertFalse(identity_service.create_service.called)
|
||||||
|
identity_service.get_service.assert_called_once_with(
|
||||||
|
identity_service.get_service_by_name.return_value.id)
|
||||||
|
|
||||||
def test_create_and_delete_service(self):
|
def test_create_and_delete_service(self):
|
||||||
|
identity_service = self.mock_identity.return_value
|
||||||
scenario = basic.CreateAndDeleteService(self.context)
|
scenario = basic.CreateAndDeleteService(self.context)
|
||||||
|
|
||||||
service_type = "test_service_type"
|
service_type = "test_service_type"
|
||||||
description = "test_description"
|
description = "test_description"
|
||||||
fake_service = mock.MagicMock()
|
fake_service = identity_service.create_service.return_value
|
||||||
scenario._service_create = mock.MagicMock(return_value=fake_service)
|
|
||||||
scenario._delete_service = mock.MagicMock()
|
|
||||||
scenario.run(service_type=service_type, description=description)
|
scenario.run(service_type=service_type, description=description)
|
||||||
scenario._service_create.assert_called_once_with(service_type,
|
|
||||||
description)
|
identity_service.create_service.assert_called_once_with(
|
||||||
scenario._delete_service.assert_called_once_with(fake_service.id)
|
service_type=service_type, description=description)
|
||||||
|
identity_service.delete_service.assert_called_once_with(
|
||||||
|
fake_service.id)
|
||||||
|
|
||||||
def test_create_update_and_delete_tenant(self):
|
def test_create_update_and_delete_tenant(self):
|
||||||
|
identity_service = self.mock_identity.return_value
|
||||||
|
|
||||||
scenario = basic.CreateUpdateAndDeleteTenant(self.context)
|
scenario = basic.CreateUpdateAndDeleteTenant(self.context)
|
||||||
fake_tenant = mock.MagicMock()
|
|
||||||
scenario._tenant_create = mock.MagicMock(return_value=fake_tenant)
|
gen_name = mock.MagicMock()
|
||||||
scenario._update_tenant = mock.MagicMock()
|
basic.CreateUpdateAndDeleteTenant.generate_random_name = gen_name
|
||||||
scenario._resource_delete = mock.MagicMock()
|
fake_project = identity_service.create_project.return_value
|
||||||
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._update_tenant.assert_called_once_with(fake_tenant)
|
|
||||||
scenario._resource_delete.assert_called_once_with(fake_tenant)
|
identity_service.create_project.assert_called_once_with()
|
||||||
|
identity_service.update_project.assert_called_once_with(
|
||||||
|
fake_project.id, description=gen_name.return_value,
|
||||||
|
name=gen_name.return_value)
|
||||||
|
identity_service.delete_project(fake_project.id)
|
||||||
|
|
||||||
def test_create_user_update_password(self):
|
def test_create_user_update_password(self):
|
||||||
|
identity_service = self.mock_identity.return_value
|
||||||
|
|
||||||
scenario = basic.CreateUserUpdatePassword(self.context)
|
scenario = basic.CreateUserUpdatePassword(self.context)
|
||||||
|
|
||||||
fake_password = "pswd"
|
fake_password = "pswd"
|
||||||
fake_user = mock.MagicMock()
|
fake_user = identity_service.create_user.return_value
|
||||||
scenario._user_create = mock.MagicMock(return_value=fake_user)
|
|
||||||
scenario.generate_random_name = mock.MagicMock(
|
scenario.generate_random_name = mock.MagicMock(
|
||||||
return_value=fake_password)
|
return_value=fake_password)
|
||||||
scenario._update_user_password = mock.MagicMock()
|
|
||||||
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
|
|
||||||
scenario.generate_random_name.assert_called_once_with()
|
scenario.generate_random_name.assert_called_once_with()
|
||||||
scenario._user_create.assert_called_once_with()
|
identity_service.create_user.assert_called_once_with()
|
||||||
scenario._update_user_password.assert_called_once_with(fake_user.id,
|
identity_service.update_user.assert_called_once_with(
|
||||||
fake_password)
|
fake_user.id, password=fake_password)
|
||||||
|
|
||||||
def test_create_and_list_services(self):
|
def test_create_and_list_services(self):
|
||||||
|
identity_service = self.mock_identity.return_value
|
||||||
|
|
||||||
scenario = basic.CreateAndListServices(self.context)
|
scenario = basic.CreateAndListServices(self.context)
|
||||||
service_type = "test_service_type"
|
service_type = "test_service_type"
|
||||||
description = "test_description"
|
description = "test_description"
|
||||||
fake_service = mock.MagicMock()
|
|
||||||
scenario._service_create = mock.MagicMock(return_value=fake_service)
|
|
||||||
scenario._list_services = mock.MagicMock()
|
|
||||||
scenario.run(service_type=service_type, description=description)
|
scenario.run(service_type=service_type, description=description)
|
||||||
scenario._service_create.assert_called_once_with(service_type,
|
|
||||||
description)
|
identity_service.create_service.assert_called_once_with(
|
||||||
scenario._list_services.assert_called_once_with()
|
service_type=service_type, description=description)
|
||||||
|
identity_service.list_services.assert_called_once_with()
|
||||||
|
|
||||||
def test_create_and_list_ec2credentials(self):
|
def test_create_and_list_ec2credentials(self):
|
||||||
context = self.context
|
identity_service = self.mock_identity.return_value
|
||||||
scenario = basic.CreateAndListEc2Credentials(context)
|
|
||||||
scenario._create_ec2credentials = mock.MagicMock()
|
scenario = basic.CreateAndListEc2Credentials(self.context)
|
||||||
scenario._list_ec2credentials = mock.MagicMock()
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._create_ec2credentials.assert_called_once_with(
|
|
||||||
"fake_user_id", "fake_tenant_id")
|
identity_service.create_ec2credentials.assert_called_once_with(
|
||||||
scenario._list_ec2credentials.assert_called_with("fake_user_id")
|
self.context["user"]["id"],
|
||||||
|
project_id=self.context["tenant"]["id"])
|
||||||
|
identity_service.list_ec2credentials.assert_called_with(
|
||||||
|
self.context["user"]["id"])
|
||||||
|
|
||||||
def test_create_and_delete_ec2credential(self):
|
def test_create_and_delete_ec2credential(self):
|
||||||
fake_creds = mock.MagicMock()
|
identity_service = self.mock_identity.return_value
|
||||||
context = self.context
|
|
||||||
scenario = basic.CreateAndDeleteEc2Credential(context)
|
fake_creds = identity_service.create_ec2credentials.return_value
|
||||||
scenario._create_ec2credentials = mock.MagicMock(
|
|
||||||
return_value=fake_creds)
|
scenario = basic.CreateAndDeleteEc2Credential(self.context)
|
||||||
scenario._delete_ec2credential = mock.MagicMock()
|
|
||||||
scenario.run()
|
scenario.run()
|
||||||
scenario._create_ec2credentials.assert_called_once_with(
|
|
||||||
"fake_user_id", "fake_tenant_id")
|
identity_service.create_ec2credentials.assert_called_once_with(
|
||||||
scenario._delete_ec2credential.assert_called_once_with(
|
self.context["user"]["id"],
|
||||||
"fake_user_id", fake_creds.access)
|
project_id=self.context["tenant"]["id"])
|
||||||
|
identity_service.delete_ec2credential.assert_called_once_with(
|
||||||
|
self.context["user"]["id"], access=fake_creds.access)
|
||||||
|
|
||||||
def test_add_and_remove_user_role(self):
|
def test_add_and_remove_user_role(self):
|
||||||
context = self.context
|
context = self.context
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
# Copyright 2014: Mirantis Inc.
|
|
||||||
# All Rights Reserved.
|
# All Rights Reserved.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
@ -41,6 +40,19 @@ class IdentityTestCase(test.TestCase):
|
|||||||
service._impl.create_project.assert_called_once_with(
|
service._impl.create_project.assert_called_once_with(
|
||||||
project_name, domain_name=domain_name)
|
project_name, domain_name=domain_name)
|
||||||
|
|
||||||
|
def test_update_project(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
|
project_id = "id"
|
||||||
|
project_name = "name"
|
||||||
|
description = "descr"
|
||||||
|
enabled = False
|
||||||
|
service.update_project(project_id=project_id, name=project_name,
|
||||||
|
description=description, enabled=enabled)
|
||||||
|
service._impl.update_project.assert_called_once_with(
|
||||||
|
project_id, name=project_name, description=description,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
def test_delete_project(self):
|
def test_delete_project(self):
|
||||||
service = self.get_service_with_fake_impl()
|
service = self.get_service_with_fake_impl()
|
||||||
project = "id"
|
project = "id"
|
||||||
@ -52,21 +64,37 @@ class IdentityTestCase(test.TestCase):
|
|||||||
service.list_projects()
|
service.list_projects()
|
||||||
service._impl.list_projects.assert_called_once_with()
|
service._impl.list_projects.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_get_project(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
project = "id"
|
||||||
|
service.get_project(project)
|
||||||
|
service._impl.get_project.assert_called_once_with(project)
|
||||||
|
|
||||||
def test_create_user(self):
|
def test_create_user(self):
|
||||||
service = self.get_service_with_fake_impl()
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
username = "username"
|
username = "username"
|
||||||
password = "password"
|
password = "password"
|
||||||
email = "email"
|
|
||||||
project_id = "project_id"
|
project_id = "project_id"
|
||||||
domain_name = "domain_name"
|
domain_name = "domain_name"
|
||||||
|
|
||||||
service.create_user(username=username, password=password, email=email,
|
service.create_user(username=username, password=password,
|
||||||
project_id=project_id, domain_name=domain_name)
|
project_id=project_id, domain_name=domain_name)
|
||||||
service._impl.create_user.assert_called_once_with(
|
service._impl.create_user.assert_called_once_with(
|
||||||
username=username, password=password, email=email,
|
username=username, password=password, project_id=project_id,
|
||||||
project_id=project_id, domain_name=domain_name,
|
domain_name=domain_name, default_role="member")
|
||||||
default_role="member")
|
|
||||||
|
def test_create_users(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
|
project_id = "project_id"
|
||||||
|
n = 3
|
||||||
|
user_create_args = {}
|
||||||
|
|
||||||
|
service.create_users(project_id, number_of_users=n,
|
||||||
|
user_create_args=user_create_args)
|
||||||
|
service._impl.create_users.assert_called_once_with(
|
||||||
|
project_id, number_of_users=n, user_create_args=user_create_args)
|
||||||
|
|
||||||
def test_delete_user(self):
|
def test_delete_user(self):
|
||||||
service = self.get_service_with_fake_impl()
|
service = self.get_service_with_fake_impl()
|
||||||
@ -79,6 +107,38 @@ class IdentityTestCase(test.TestCase):
|
|||||||
service.list_users()
|
service.list_users()
|
||||||
service._impl.list_users.assert_called_once_with()
|
service._impl.list_users.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_update_user(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
|
user_id = "id"
|
||||||
|
user_name = "name"
|
||||||
|
email = "mail"
|
||||||
|
password = "pass"
|
||||||
|
enabled = False
|
||||||
|
service.update_user(user_id, name=user_name, password=password,
|
||||||
|
email=email, enabled=enabled)
|
||||||
|
service._impl.update_user.assert_called_once_with(
|
||||||
|
user_id, name=user_name, password=password, email=email,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
|
def test_get_user(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
user = "id"
|
||||||
|
service.get_user(user)
|
||||||
|
service._impl.get_user.assert_called_once_with(user)
|
||||||
|
|
||||||
|
def test_create_service(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
|
service_name = "name"
|
||||||
|
service_type = "service_type"
|
||||||
|
description = "descr"
|
||||||
|
service.create_service(service_name, service_type=service_type,
|
||||||
|
description=description)
|
||||||
|
service._impl.create_service.assert_called_once_with(
|
||||||
|
name=service_name, service_type=service_type,
|
||||||
|
description=description)
|
||||||
|
|
||||||
def test_delete_service(self):
|
def test_delete_service(self):
|
||||||
service = self.get_service_with_fake_impl()
|
service = self.get_service_with_fake_impl()
|
||||||
service_id = "id"
|
service_id = "id"
|
||||||
@ -91,6 +151,18 @@ class IdentityTestCase(test.TestCase):
|
|||||||
service.list_services()
|
service.list_services()
|
||||||
service._impl.list_services.assert_called_once_with()
|
service._impl.list_services.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_get_service(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
service_id = "id"
|
||||||
|
service.get_service(service_id)
|
||||||
|
service._impl.get_service.assert_called_once_with(service_id)
|
||||||
|
|
||||||
|
def test_get_service_by_name(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
service_name = "name"
|
||||||
|
service.get_service_by_name(service_name)
|
||||||
|
service._impl.get_service_by_name.assert_called_once_with(service_name)
|
||||||
|
|
||||||
def test_create_role(self):
|
def test_create_role(self):
|
||||||
service = self.get_service_with_fake_impl()
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
@ -144,26 +216,42 @@ class IdentityTestCase(test.TestCase):
|
|||||||
service.get_role(role)
|
service.get_role(role)
|
||||||
service._impl.get_role.assert_called_once_with(role)
|
service._impl.get_role.assert_called_once_with(role)
|
||||||
|
|
||||||
def test__unify_service(self):
|
def test_create_ec2credentials(self):
|
||||||
class SomeFakeService(object):
|
service = self.get_service_with_fake_impl()
|
||||||
id = 123123123123123
|
|
||||||
name = "asdfasdfasdfasdfadf"
|
|
||||||
other_var = "asdfasdfasdfasdfasdfasdfasdf"
|
|
||||||
|
|
||||||
service = self.get_service_with_fake_impl()._unify_service(
|
user_id = "id"
|
||||||
SomeFakeService())
|
project_id = "project-id"
|
||||||
self.assertIsInstance(service, identity.Service)
|
|
||||||
self.assertEqual(SomeFakeService.id, service.id)
|
|
||||||
self.assertEqual(SomeFakeService.name, service.name)
|
|
||||||
|
|
||||||
def test__unify_role(self):
|
service.create_ec2credentials(user_id=user_id, project_id=project_id)
|
||||||
class SomeFakeRole(object):
|
service._impl.create_ec2credentials.assert_called_once_with(
|
||||||
id = 123123123123123
|
user_id=user_id, project_id=project_id)
|
||||||
name = "asdfasdfasdfasdfadf"
|
|
||||||
other_var = "asdfasdfasdfasdfasdfasdfasdf"
|
|
||||||
|
|
||||||
role = self.get_service_with_fake_impl()._unify_role(
|
def test_list_ec2credentials(self):
|
||||||
SomeFakeRole())
|
service = self.get_service_with_fake_impl()
|
||||||
self.assertIsInstance(role, identity.Role)
|
|
||||||
self.assertEqual(SomeFakeRole.id, role.id)
|
user_id = "id"
|
||||||
self.assertEqual(SomeFakeRole.name, role.name)
|
|
||||||
|
service.list_ec2credentials(user_id=user_id)
|
||||||
|
service._impl.list_ec2credentials.assert_called_once_with(user_id)
|
||||||
|
|
||||||
|
def test_delete_ec2credential(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
|
user_id = "id"
|
||||||
|
access = "access"
|
||||||
|
|
||||||
|
service.delete_ec2credential(user_id=user_id, access=access)
|
||||||
|
service._impl.delete_ec2credential.assert_called_once_with(
|
||||||
|
user_id=user_id, access=access)
|
||||||
|
|
||||||
|
def test_fetch_token(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
service.fetch_token()
|
||||||
|
service._impl.fetch_token.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_validate_token(self):
|
||||||
|
service = self.get_service_with_fake_impl()
|
||||||
|
|
||||||
|
token = "id"
|
||||||
|
service.validate_token(token)
|
||||||
|
service._impl.validate_token.assert_called_once_with(token)
|
||||||
|
@ -0,0 +1,280 @@
|
|||||||
|
# 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.
|
||||||
|
|
||||||
|
import mock
|
||||||
|
|
||||||
|
from rally.plugins.openstack import service
|
||||||
|
from rally.plugins.openstack.services.identity import identity
|
||||||
|
from rally.plugins.openstack.services.identity import keystone_common
|
||||||
|
from tests.unit import test
|
||||||
|
|
||||||
|
|
||||||
|
class FullUnifiedKeystone(keystone_common.UnifiedKeystoneMixin,
|
||||||
|
service.Service):
|
||||||
|
"""Implementation of UnifiedKeystoneMixin with Service base class."""
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class UnifiedKeystoneMixinTestCase(test.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
super(UnifiedKeystoneMixinTestCase, self).setUp()
|
||||||
|
self.clients = mock.MagicMock()
|
||||||
|
self.name_generator = mock.MagicMock()
|
||||||
|
self.impl = mock.MagicMock()
|
||||||
|
self.version = "some"
|
||||||
|
self.service = FullUnifiedKeystone(
|
||||||
|
clients=self.clients, name_generator=self.name_generator)
|
||||||
|
self.service._impl = self.impl
|
||||||
|
self.service.version = self.version
|
||||||
|
|
||||||
|
def test__unify_service(self):
|
||||||
|
class SomeFakeService(object):
|
||||||
|
id = 123123123123123
|
||||||
|
name = "asdfasdfasdfasdfadf"
|
||||||
|
other_var = "asdfasdfasdfasdfasdfasdfasdf"
|
||||||
|
|
||||||
|
service = self.service._unify_service(SomeFakeService())
|
||||||
|
self.assertIsInstance(service, identity.Service)
|
||||||
|
self.assertEqual(SomeFakeService.id, service.id)
|
||||||
|
self.assertEqual(SomeFakeService.name, service.name)
|
||||||
|
|
||||||
|
def test__unify_role(self):
|
||||||
|
class SomeFakeRole(object):
|
||||||
|
id = 123123123123123
|
||||||
|
name = "asdfasdfasdfasdfadf"
|
||||||
|
other_var = "asdfasdfasdfasdfasdfasdfasdf"
|
||||||
|
|
||||||
|
role = self.service._unify_role(SomeFakeRole())
|
||||||
|
self.assertIsInstance(role, identity.Role)
|
||||||
|
self.assertEqual(SomeFakeRole.id, role.id)
|
||||||
|
self.assertEqual(SomeFakeRole.name, role.name)
|
||||||
|
|
||||||
|
def test_delete_user(self):
|
||||||
|
user_id = "id"
|
||||||
|
|
||||||
|
self.service.delete_user(user_id)
|
||||||
|
self.impl.delete_user.assert_called_once_with(user_id)
|
||||||
|
|
||||||
|
def test_get_user(self):
|
||||||
|
user_id = "id"
|
||||||
|
|
||||||
|
self.service._unify_user = mock.MagicMock()
|
||||||
|
|
||||||
|
self.assertEqual(self.service._unify_user.return_value,
|
||||||
|
self.service.get_user(user_id))
|
||||||
|
|
||||||
|
self.impl.get_user.assert_called_once_with(user_id)
|
||||||
|
self.service._unify_user.assert_called_once_with(
|
||||||
|
self.impl.get_user.return_value)
|
||||||
|
|
||||||
|
def test_create_service(self):
|
||||||
|
self.service._unify_service = mock.MagicMock()
|
||||||
|
|
||||||
|
name = "some_Service"
|
||||||
|
service_type = "computeNextGen"
|
||||||
|
description = "we will Rock you!"
|
||||||
|
|
||||||
|
self.assertEqual(self.service._unify_service.return_value,
|
||||||
|
self.service.create_service(
|
||||||
|
name=name, service_type=service_type,
|
||||||
|
description=description))
|
||||||
|
|
||||||
|
self.service._unify_service.assert_called_once_with(
|
||||||
|
self.service._impl.create_service.return_value)
|
||||||
|
self.service._impl.create_service.assert_called_once_with(
|
||||||
|
name=name, service_type=service_type, description=description)
|
||||||
|
|
||||||
|
def test_delete_service(self):
|
||||||
|
service_id = "id"
|
||||||
|
|
||||||
|
self.service.delete_service(service_id)
|
||||||
|
self.impl.delete_service.assert_called_once_with(service_id)
|
||||||
|
|
||||||
|
def test_get_service(self):
|
||||||
|
service_id = "id"
|
||||||
|
|
||||||
|
self.service._unify_service = mock.MagicMock()
|
||||||
|
|
||||||
|
self.assertEqual(self.service._unify_service.return_value,
|
||||||
|
self.service.get_service(service_id))
|
||||||
|
|
||||||
|
self.impl.get_service.assert_called_once_with(service_id)
|
||||||
|
self.service._unify_service.assert_called_once_with(
|
||||||
|
self.impl.get_service.return_value)
|
||||||
|
|
||||||
|
def test_get_service_by_name(self):
|
||||||
|
service_id = "id"
|
||||||
|
|
||||||
|
self.service._unify_service = mock.MagicMock()
|
||||||
|
|
||||||
|
self.assertEqual(self.service._unify_service.return_value,
|
||||||
|
self.service.get_service_by_name(service_id))
|
||||||
|
|
||||||
|
self.impl.get_service_by_name.assert_called_once_with(service_id)
|
||||||
|
self.service._unify_service.assert_called_once_with(
|
||||||
|
self.impl.get_service_by_name.return_value)
|
||||||
|
|
||||||
|
def test_delete_role(self):
|
||||||
|
role_id = "id"
|
||||||
|
|
||||||
|
self.service.delete_role(role_id)
|
||||||
|
self.impl.delete_role.assert_called_once_with(role_id)
|
||||||
|
|
||||||
|
def test_get_role(self):
|
||||||
|
role_id = "id"
|
||||||
|
|
||||||
|
self.service._unify_role = mock.MagicMock()
|
||||||
|
|
||||||
|
self.assertEqual(self.service._unify_role.return_value,
|
||||||
|
self.service.get_role(role_id))
|
||||||
|
|
||||||
|
self.impl.get_role.assert_called_once_with(role_id)
|
||||||
|
self.service._unify_role.assert_called_once_with(
|
||||||
|
self.impl.get_role.return_value)
|
||||||
|
|
||||||
|
def test_list_ec2credentials(self):
|
||||||
|
user_id = "id"
|
||||||
|
self.assertEqual(self.impl.list_ec2credentials.return_value,
|
||||||
|
self.service.list_ec2credentials(user_id))
|
||||||
|
|
||||||
|
self.impl.list_ec2credentials.assert_called_once_with(user_id)
|
||||||
|
|
||||||
|
def test_delete_ec2credential(self):
|
||||||
|
user_id = "id"
|
||||||
|
access = mock.MagicMock()
|
||||||
|
|
||||||
|
self.assertEqual(self.impl.delete_ec2credential.return_value,
|
||||||
|
self.service.delete_ec2credential(user_id,
|
||||||
|
access=access))
|
||||||
|
|
||||||
|
self.impl.delete_ec2credential.assert_called_once_with(user_id=user_id,
|
||||||
|
access=access)
|
||||||
|
|
||||||
|
def test_fetch_token(self):
|
||||||
|
|
||||||
|
self.assertEqual(self.impl.fetch_token.return_value,
|
||||||
|
self.service.fetch_token())
|
||||||
|
|
||||||
|
self.impl.fetch_token.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_validate_token(self):
|
||||||
|
token = "id"
|
||||||
|
|
||||||
|
self.assertEqual(self.impl.validate_token.return_value,
|
||||||
|
self.service.validate_token(token))
|
||||||
|
|
||||||
|
self.impl.validate_token.assert_called_once_with(token)
|
||||||
|
|
||||||
|
|
||||||
|
class FullKeystone(service.Service, keystone_common.KeystoneMixin):
|
||||||
|
"""Implementation of KeystoneMixin with Service base class."""
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class KeystoneMixinTestCase(test.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
super(KeystoneMixinTestCase, self).setUp()
|
||||||
|
self.clients = mock.MagicMock()
|
||||||
|
self.kc = self.clients.keystone.return_value
|
||||||
|
self.name_generator = mock.MagicMock()
|
||||||
|
self.version = "some"
|
||||||
|
self.service = FullKeystone(
|
||||||
|
clients=self.clients, name_generator=self.name_generator)
|
||||||
|
self.service.version = self.version
|
||||||
|
|
||||||
|
def test_list_users(self):
|
||||||
|
self.assertEqual(self.kc.users.list.return_value,
|
||||||
|
self.service.list_users())
|
||||||
|
self.kc.users.list.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_delete_user(self):
|
||||||
|
user_id = "fake_id"
|
||||||
|
self.service.delete_user(user_id)
|
||||||
|
self.kc.users.delete.assert_called_once_with(user_id)
|
||||||
|
|
||||||
|
def test_get_user(self):
|
||||||
|
user_id = "fake_id"
|
||||||
|
self.service.get_user(user_id)
|
||||||
|
self.kc.users.get.assert_called_once_with(user_id)
|
||||||
|
|
||||||
|
def test_delete_service(self):
|
||||||
|
service_id = "fake_id"
|
||||||
|
self.service.delete_service(service_id)
|
||||||
|
self.kc.services.delete.assert_called_once_with(service_id)
|
||||||
|
|
||||||
|
def test_list_services(self):
|
||||||
|
self.assertEqual(self.kc.services.list.return_value,
|
||||||
|
self.service.list_services())
|
||||||
|
self.kc.services.list.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_get_service(self):
|
||||||
|
service_id = "fake_id"
|
||||||
|
self.service.get_service(service_id)
|
||||||
|
self.kc.services.get.assert_called_once_with(service_id)
|
||||||
|
|
||||||
|
def test_get_service_by_name(self):
|
||||||
|
class FakeService(object):
|
||||||
|
def __init__(self, name):
|
||||||
|
self.name = name
|
||||||
|
service_name = "fake_name"
|
||||||
|
services = [FakeService(name="foo"), FakeService(name=service_name),
|
||||||
|
FakeService(name="bar")]
|
||||||
|
self.service.list_services = mock.MagicMock(return_value=services)
|
||||||
|
|
||||||
|
self.assertEqual(services[1],
|
||||||
|
self.service.get_service_by_name(service_name))
|
||||||
|
|
||||||
|
def test_delete_role(self):
|
||||||
|
role_id = "fake_id"
|
||||||
|
self.service.delete_role(role_id)
|
||||||
|
self.kc.roles.delete.assert_called_once_with(role_id)
|
||||||
|
|
||||||
|
def test_list_roles(self):
|
||||||
|
self.assertEqual(self.kc.roles.list.return_value,
|
||||||
|
self.service.list_roles())
|
||||||
|
self.kc.roles.list.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_get_role(self):
|
||||||
|
role_id = "fake_id"
|
||||||
|
self.service.get_role(role_id)
|
||||||
|
self.kc.roles.get.assert_called_once_with(role_id)
|
||||||
|
|
||||||
|
def test_list_ec2credentials(self):
|
||||||
|
user_id = "fake_id"
|
||||||
|
|
||||||
|
self.assertEqual(self.kc.ec2.list.return_value,
|
||||||
|
self.service.list_ec2credentials(user_id))
|
||||||
|
self.kc.ec2.list.assert_called_once_with(user_id)
|
||||||
|
|
||||||
|
def test_delete_ec2credentials(self):
|
||||||
|
user_id = "fake_id"
|
||||||
|
access = mock.MagicMock()
|
||||||
|
|
||||||
|
self.service.delete_ec2credential(user_id, access=access)
|
||||||
|
self.kc.ec2.delete.assert_called_once_with(user_id=user_id,
|
||||||
|
access=access)
|
||||||
|
|
||||||
|
@mock.patch("rally.osclients.Clients")
|
||||||
|
def test_fetch_token(self, mock_clients):
|
||||||
|
expected_token = mock_clients.return_value.keystone.auth_ref.auth_token
|
||||||
|
self.assertEqual(expected_token, self.service.fetch_token())
|
||||||
|
mock_clients.assert_called_once_with(
|
||||||
|
credential=self.clients.credential,
|
||||||
|
api_info=self.clients.api_info)
|
||||||
|
|
||||||
|
def test_validate_token(self):
|
||||||
|
token = "some_token"
|
||||||
|
|
||||||
|
self.service.validate_token(token)
|
||||||
|
self.kc.tokens.validate.assert_called_once_with(token)
|
@ -1,4 +1,3 @@
|
|||||||
# Copyright 2014: Mirantis Inc.
|
|
||||||
# All Rights Reserved.
|
# All Rights Reserved.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
@ -15,6 +14,7 @@
|
|||||||
|
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
|
import ddt
|
||||||
import mock
|
import mock
|
||||||
|
|
||||||
from rally.plugins.openstack.services.identity import identity
|
from rally.plugins.openstack.services.identity import identity
|
||||||
@ -25,12 +25,15 @@ from tests.unit import test
|
|||||||
PATH = "rally.plugins.openstack.services.identity.keystone_v2"
|
PATH = "rally.plugins.openstack.services.identity.keystone_v2"
|
||||||
|
|
||||||
|
|
||||||
|
@ddt.ddt
|
||||||
class KeystoneV2ServiceTestCase(test.TestCase):
|
class KeystoneV2ServiceTestCase(test.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(KeystoneV2ServiceTestCase, self).setUp()
|
super(KeystoneV2ServiceTestCase, self).setUp()
|
||||||
self.clients = mock.MagicMock()
|
self.clients = mock.MagicMock()
|
||||||
self.kc = self.clients.keystone.return_value
|
self.kc = self.clients.keystone.return_value
|
||||||
self.service = keystone_v2.KeystoneV2Service(self.clients)
|
self.name_generator = mock.MagicMock()
|
||||||
|
self.service = keystone_v2.KeystoneV2Service(
|
||||||
|
self.clients, name_generator=self.name_generator)
|
||||||
|
|
||||||
def test_create_tenant(self):
|
def test_create_tenant(self):
|
||||||
name = "name"
|
name = "name"
|
||||||
@ -39,6 +42,25 @@ class KeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.assertEqual(tenant, self.kc.tenants.create.return_value)
|
self.assertEqual(tenant, self.kc.tenants.create.return_value)
|
||||||
self.kc.tenants.create.assert_called_once_with(name)
|
self.kc.tenants.create.assert_called_once_with(name)
|
||||||
|
|
||||||
|
@ddt.data({"tenant_id": "fake_id", "name": True, "enabled": True,
|
||||||
|
"description": True},
|
||||||
|
{"tenant_id": "fake_id", "name": "some", "enabled": False,
|
||||||
|
"description": "descr"})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_update_tenant(self, tenant_id, name, enabled, description):
|
||||||
|
|
||||||
|
self.name_generator.side_effect = ("foo", "bar")
|
||||||
|
self.service.update_tenant(tenant_id,
|
||||||
|
name=name,
|
||||||
|
description=description,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
|
name = "foo" if name is True else name
|
||||||
|
description = "bar" if description is True else description
|
||||||
|
|
||||||
|
self.kc.tenants.update.assert_called_once_with(
|
||||||
|
tenant_id, name=name, description=description, enabled=enabled)
|
||||||
|
|
||||||
def test_delete_tenant(self):
|
def test_delete_tenant(self):
|
||||||
tenant_id = "fake_id"
|
tenant_id = "fake_id"
|
||||||
self.service.delete_tenant(tenant_id)
|
self.service.delete_tenant(tenant_id)
|
||||||
@ -49,6 +71,11 @@ class KeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.service.list_tenants())
|
self.service.list_tenants())
|
||||||
self.kc.tenants.list.assert_called_once_with()
|
self.kc.tenants.list.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_get_tenant(self):
|
||||||
|
tenant_id = "fake_id"
|
||||||
|
self.service.get_tenant(tenant_id)
|
||||||
|
self.kc.tenants.get.assert_called_once_with(tenant_id)
|
||||||
|
|
||||||
def test_create_user(self):
|
def test_create_user(self):
|
||||||
name = "name"
|
name = "name"
|
||||||
password = "passwd"
|
password = "passwd"
|
||||||
@ -60,27 +87,56 @@ class KeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
|
|
||||||
self.assertEqual(user, self.kc.users.create.return_value)
|
self.assertEqual(user, self.kc.users.create.return_value)
|
||||||
self.kc.users.create.assert_called_once_with(
|
self.kc.users.create.assert_called_once_with(
|
||||||
name=name, password=password, email=email, tenant_id=tenant_id)
|
name=name, password=password, email=email, tenant_id=tenant_id,
|
||||||
|
enabled=True)
|
||||||
|
|
||||||
def test_list_users(self):
|
def test_create_users(self):
|
||||||
self.assertEqual(self.kc.users.list.return_value,
|
self.service.create_user = mock.MagicMock()
|
||||||
self.service.list_users())
|
|
||||||
self.kc.users.list.assert_called_once_with()
|
|
||||||
|
|
||||||
def test_delete_user(self):
|
n = 2
|
||||||
|
tenant_id = "some"
|
||||||
|
self.assertEqual([self.service.create_user.return_value] * n,
|
||||||
|
self.service.create_users(number_of_users=n,
|
||||||
|
tenant_id=tenant_id))
|
||||||
|
self.assertEqual([mock.call(tenant_id=tenant_id)] * n,
|
||||||
|
self.service.create_user.call_args_list)
|
||||||
|
|
||||||
|
def test_update_user_with_wrong_params(self):
|
||||||
user_id = "fake_id"
|
user_id = "fake_id"
|
||||||
self.service.delete_user(user_id)
|
card_with_cvv2 = "1234 5678 9000 0000 : 666"
|
||||||
self.kc.users.delete.assert_called_once_with(user_id)
|
self.assertRaises(NotImplementedError, self.service.update_user,
|
||||||
|
user_id, card_with_cvv2=card_with_cvv2)
|
||||||
|
|
||||||
def test_delete_service(self):
|
def test_update_user(self):
|
||||||
service_id = "fake_id"
|
user_id = "fake_id"
|
||||||
self.service.delete_service(service_id)
|
name = "new name"
|
||||||
self.kc.services.delete.assert_called_once_with(service_id)
|
email = "new.name2016@example.com"
|
||||||
|
enabled = True
|
||||||
|
self.service.update_user(user_id, name=name, email=email,
|
||||||
|
enabled=enabled)
|
||||||
|
self.kc.users.update.assert_called_once_with(
|
||||||
|
user_id, name=name, email=email, enabled=enabled)
|
||||||
|
|
||||||
def test_list_services(self):
|
def test_update_user_password(self):
|
||||||
self.assertEqual(self.kc.services.list.return_value,
|
user_id = "fake_id"
|
||||||
self.service.list_services())
|
password = "qwerty123"
|
||||||
self.kc.services.list.assert_called_once_with()
|
self.service.update_user_password(user_id, password=password)
|
||||||
|
self.kc.users.update_password.assert_called_once_with(
|
||||||
|
user_id, password=password)
|
||||||
|
|
||||||
|
@ddt.data({"name": None, "service_type": None, "description": None},
|
||||||
|
{"name": "some", "service_type": "st", "description": "d"})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_create_service(self, name, service_type, description):
|
||||||
|
self.assertEqual(self.kc.services.create.return_value,
|
||||||
|
self.service.create_service(name=name,
|
||||||
|
service_type=service_type,
|
||||||
|
description=description))
|
||||||
|
name = name or self.name_generator.return_value
|
||||||
|
service_type = service_type or "rally_test_type"
|
||||||
|
description = description or self.name_generator.return_value
|
||||||
|
self.kc.services.create.assert_called_once_with(
|
||||||
|
name, service_type=service_type, description=description)
|
||||||
|
|
||||||
def test_create_role(self):
|
def test_create_role(self):
|
||||||
name = "some"
|
name = "some"
|
||||||
@ -96,11 +152,6 @@ class KeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.kc.roles.add_user_role.assert_called_once_with(
|
self.kc.roles.add_user_role.assert_called_once_with(
|
||||||
user=user_id, role=role_id, tenant=tenant_id)
|
user=user_id, role=role_id, tenant=tenant_id)
|
||||||
|
|
||||||
def test_delete_role(self):
|
|
||||||
role_id = "fake_id"
|
|
||||||
self.service.delete_role(role_id)
|
|
||||||
self.kc.roles.delete.assert_called_once_with(role_id)
|
|
||||||
|
|
||||||
def test_list_roles(self):
|
def test_list_roles(self):
|
||||||
self.assertEqual(self.kc.roles.list.return_value,
|
self.assertEqual(self.kc.roles.list.return_value,
|
||||||
self.service.list_roles())
|
self.service.list_roles())
|
||||||
@ -126,12 +177,18 @@ class KeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.kc.roles.remove_user_role.assert_called_once_with(
|
self.kc.roles.remove_user_role.assert_called_once_with(
|
||||||
user=user_id, role=role_id, tenant=tenant_id)
|
user=user_id, role=role_id, tenant=tenant_id)
|
||||||
|
|
||||||
def test_get_role(self):
|
def test_create_ec2credentials(self):
|
||||||
role_id = "fake_id"
|
user_id = "fake_id"
|
||||||
self.service.get_role(role_id)
|
tenant_id = "fake_id"
|
||||||
self.kc.roles.get.assert_called_once_with(role_id)
|
|
||||||
|
self.assertEqual(self.kc.ec2.create.return_value,
|
||||||
|
self.service.create_ec2credentials(
|
||||||
|
user_id, tenant_id=tenant_id))
|
||||||
|
self.kc.ec2.create.assert_called_once_with(user_id,
|
||||||
|
tenant_id=tenant_id)
|
||||||
|
|
||||||
|
|
||||||
|
@ddt.ddt
|
||||||
class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(UnifiedKeystoneV2ServiceTestCase, self).setUp()
|
super(UnifiedKeystoneV2ServiceTestCase, self).setUp()
|
||||||
@ -207,11 +264,35 @@ class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.service._impl.create_tenant.return_value)
|
self.service._impl.create_tenant.return_value)
|
||||||
self.service._impl.create_tenant.assert_called_once_with(name)
|
self.service._impl.create_tenant.assert_called_once_with(name)
|
||||||
|
|
||||||
|
def test_update_project(self):
|
||||||
|
tenant_id = "fake_id"
|
||||||
|
name = "name"
|
||||||
|
description = "descr"
|
||||||
|
enabled = False
|
||||||
|
|
||||||
|
self.service.update_project(project_id=tenant_id, name=name,
|
||||||
|
description=description, enabled=enabled)
|
||||||
|
self.service._impl.update_tenant.assert_called_once_with(
|
||||||
|
tenant_id=tenant_id, name=name, description=description,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
def test_delete_project(self):
|
def test_delete_project(self):
|
||||||
tenant_id = "fake_id"
|
tenant_id = "fake_id"
|
||||||
self.service.delete_project(tenant_id)
|
self.service.delete_project(tenant_id)
|
||||||
self.service._impl.delete_tenant.assert_called_once_with(tenant_id)
|
self.service._impl.delete_tenant.assert_called_once_with(tenant_id)
|
||||||
|
|
||||||
|
@mock.patch("%s.UnifiedKeystoneV2Service._unify_tenant" % PATH)
|
||||||
|
def test_get_project(self,
|
||||||
|
mock_unified_keystone_v2_service__unify_tenant):
|
||||||
|
mock_unify_tenant = mock_unified_keystone_v2_service__unify_tenant
|
||||||
|
tenant_id = "id"
|
||||||
|
|
||||||
|
self.assertEqual(mock_unify_tenant.return_value,
|
||||||
|
self.service.get_project(tenant_id))
|
||||||
|
mock_unify_tenant.assert_called_once_with(
|
||||||
|
self.service._impl.get_tenant.return_value)
|
||||||
|
self.service._impl.get_tenant.assert_called_once_with(tenant_id)
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV2Service._unify_tenant" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV2Service._unify_tenant" % PATH)
|
||||||
def test_list_projects(self,
|
def test_list_projects(self,
|
||||||
mock_unified_keystone_v2_service__unify_tenant):
|
mock_unified_keystone_v2_service__unify_tenant):
|
||||||
@ -233,23 +314,35 @@ class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
|
|
||||||
name = "name"
|
name = "name"
|
||||||
password = "passwd"
|
password = "passwd"
|
||||||
email = "rally@example.com"
|
|
||||||
tenant_id = "project"
|
tenant_id = "project"
|
||||||
|
|
||||||
self.assertEqual(mock_unify_user.return_value,
|
self.assertEqual(mock_unify_user.return_value,
|
||||||
self.service.create_user(name, password=password,
|
self.service.create_user(name, password=password,
|
||||||
email=email,
|
|
||||||
project_id=tenant_id))
|
project_id=tenant_id))
|
||||||
mock_check_domain.assert_called_once_with("Default")
|
mock_check_domain.assert_called_once_with("Default")
|
||||||
mock_unify_user.assert_called_once_with(
|
mock_unify_user.assert_called_once_with(
|
||||||
self.service._impl.create_user.return_value)
|
self.service._impl.create_user.return_value)
|
||||||
self.service._impl.create_user.assert_called_once_with(
|
self.service._impl.create_user.assert_called_once_with(
|
||||||
username=name, password=password, email=email, tenant_id=tenant_id)
|
username=name, password=password, tenant_id=tenant_id,
|
||||||
|
enabled=True)
|
||||||
|
|
||||||
def test_delete_user(self):
|
@mock.patch("%s.UnifiedKeystoneV2Service._check_domain" % PATH)
|
||||||
user_id = "fake_id"
|
@mock.patch("%s.UnifiedKeystoneV2Service._unify_user" % PATH)
|
||||||
self.service.delete_user(user_id)
|
def test_create_users(self, mock_unified_keystone_v2_service__unify_user,
|
||||||
self.service._impl.delete_user.assert_called_once_with(user_id)
|
mock_unified_keystone_v2_service__check_domain):
|
||||||
|
mock_check_domain = mock_unified_keystone_v2_service__check_domain
|
||||||
|
|
||||||
|
tenant_id = "project"
|
||||||
|
n = 3
|
||||||
|
domain_name = "Default"
|
||||||
|
|
||||||
|
self.service.create_users(
|
||||||
|
tenant_id, number_of_users=3,
|
||||||
|
user_create_args={"domain_name": domain_name})
|
||||||
|
mock_check_domain.assert_called_once_with(domain_name)
|
||||||
|
self.service._impl.create_users.assert_called_once_with(
|
||||||
|
tenant_id=tenant_id, number_of_users=n,
|
||||||
|
user_create_args={"domain_name": domain_name})
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV2Service._unify_user" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV2Service._unify_user" % PATH)
|
||||||
def test_list_users(self, mock_unified_keystone_v2_service__unify_user):
|
def test_list_users(self, mock_unified_keystone_v2_service__unify_user):
|
||||||
@ -262,10 +355,29 @@ class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.service.list_users())
|
self.service.list_users())
|
||||||
mock_unify_user.assert_called_once_with(users[0])
|
mock_unify_user.assert_called_once_with(users[0])
|
||||||
|
|
||||||
def test_delete_service(self):
|
@ddt.data({"user_id": "id", "enabled": False, "name": "Fake",
|
||||||
service_id = "fake_id"
|
"email": "badboy@example.com", "password": "pass"},
|
||||||
self.service.delete_service(service_id)
|
{"user_id": "id", "enabled": None, "name": None,
|
||||||
self.service._impl.delete_service.assert_called_once_with(service_id)
|
"email": None, "password": None})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_update_user(self, user_id, enabled, name, email, password):
|
||||||
|
self.service.update_user(user_id, enabled=enabled, name=name,
|
||||||
|
email=email, password=password)
|
||||||
|
if password:
|
||||||
|
self.service._impl.update_user_password.assert_called_once_with(
|
||||||
|
user_id=user_id, password=password)
|
||||||
|
|
||||||
|
args = {}
|
||||||
|
if enabled is not None:
|
||||||
|
args["enabled"] = enabled
|
||||||
|
if name is not None:
|
||||||
|
args["name"] = name
|
||||||
|
if email is not None:
|
||||||
|
args["email"] = email
|
||||||
|
|
||||||
|
if args:
|
||||||
|
self.service._impl.update_user.assert_called_once_with(
|
||||||
|
user_id, **args)
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV2Service._unify_service" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV2Service._unify_service" % PATH)
|
||||||
def test_list_services(self,
|
def test_list_services(self,
|
||||||
@ -291,22 +403,17 @@ class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
mock_unify_role.assert_called_once_with(
|
mock_unify_role.assert_called_once_with(
|
||||||
self.service._impl.create_role.return_value)
|
self.service._impl.create_role.return_value)
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV2Service._unify_role" % PATH)
|
def test_add_role(self):
|
||||||
def test_add_role(self, mock_unified_keystone_v2_service__unify_role):
|
|
||||||
mock_unify_role = mock_unified_keystone_v2_service__unify_role
|
|
||||||
|
|
||||||
role_id = "fake_id"
|
role_id = "fake_id"
|
||||||
user_id = "user_id"
|
user_id = "user_id"
|
||||||
project_id = "user_id"
|
project_id = "user_id"
|
||||||
|
|
||||||
self.assertEqual(mock_unify_role.return_value,
|
|
||||||
self.service.add_role(role_id, user_id=user_id,
|
self.service.add_role(role_id, user_id=user_id,
|
||||||
project_id=project_id))
|
project_id=project_id)
|
||||||
|
|
||||||
self.service._impl.add_role.assert_called_once_with(
|
self.service._impl.add_role.assert_called_once_with(
|
||||||
user_id=user_id, role_id=role_id, tenant_id=project_id)
|
user_id=user_id, role_id=role_id, tenant_id=project_id)
|
||||||
mock_unify_role.assert_called_once_with(
|
|
||||||
self.service._impl.add_role.return_value)
|
|
||||||
|
|
||||||
def test_delete_role(self):
|
def test_delete_role(self):
|
||||||
role_id = "fake_id"
|
role_id = "fake_id"
|
||||||
@ -358,7 +465,13 @@ class UnifiedKeystoneV2ServiceTestCase(test.TestCase):
|
|||||||
self.assertRaises(NotImplementedError, self.service.list_roles,
|
self.assertRaises(NotImplementedError, self.service.list_roles,
|
||||||
domain_name="some")
|
domain_name="some")
|
||||||
|
|
||||||
def test_get_role(self):
|
def test_create_ec2credentials(self):
|
||||||
role_id = "fake_id"
|
user_id = "id"
|
||||||
self.service.get_role(role_id)
|
tenant_id = "tenant-id"
|
||||||
self.service._impl.get_role.assert_called_once_with(role_id)
|
|
||||||
|
self.assertEqual(self.service._impl.create_ec2credentials.return_value,
|
||||||
|
self.service.create_ec2credentials(
|
||||||
|
user_id=user_id, project_id=tenant_id))
|
||||||
|
|
||||||
|
self.service._impl.create_ec2credentials.assert_called_once_with(
|
||||||
|
user_id=user_id, tenant_id=tenant_id)
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
# Copyright 2014: Mirantis Inc.
|
|
||||||
# All Rights Reserved.
|
# All Rights Reserved.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
@ -15,6 +14,7 @@
|
|||||||
|
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
|
import ddt
|
||||||
import mock
|
import mock
|
||||||
|
|
||||||
from rally import exceptions
|
from rally import exceptions
|
||||||
@ -26,12 +26,15 @@ from tests.unit import test
|
|||||||
PATH = "rally.plugins.openstack.services.identity.keystone_v3"
|
PATH = "rally.plugins.openstack.services.identity.keystone_v3"
|
||||||
|
|
||||||
|
|
||||||
|
@ddt.ddt
|
||||||
class KeystoneV3ServiceTestCase(test.TestCase):
|
class KeystoneV3ServiceTestCase(test.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(KeystoneV3ServiceTestCase, self).setUp()
|
super(KeystoneV3ServiceTestCase, self).setUp()
|
||||||
self.clients = mock.MagicMock()
|
self.clients = mock.MagicMock()
|
||||||
self.kc = self.clients.keystone.return_value
|
self.kc = self.clients.keystone.return_value
|
||||||
self.service = keystone_v3.KeystoneV3Service(self.clients)
|
self.name_generator = mock.MagicMock()
|
||||||
|
self.service = keystone_v3.KeystoneV3Service(
|
||||||
|
self.clients, name_generator=self.name_generator)
|
||||||
|
|
||||||
def test__get_domain_id_not_found(self):
|
def test__get_domain_id_not_found(self):
|
||||||
from keystoneclient import exceptions as kc_exceptions
|
from keystoneclient import exceptions as kc_exceptions
|
||||||
@ -85,6 +88,26 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.kc.projects.create.assert_called_once_with(name=name,
|
self.kc.projects.create.assert_called_once_with(name=name,
|
||||||
domain=domain_id)
|
domain=domain_id)
|
||||||
|
|
||||||
|
@ddt.data({"project_id": "fake_id", "name": True, "enabled": True,
|
||||||
|
"description": True},
|
||||||
|
{"project_id": "fake_id", "name": "some", "enabled": False,
|
||||||
|
"description": "descr"})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_update_project(self, project_id, name, enabled, description):
|
||||||
|
|
||||||
|
self.service.update_project(project_id,
|
||||||
|
name=name,
|
||||||
|
description=description,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
|
if name is True:
|
||||||
|
name = self.name_generator.return_value
|
||||||
|
if description is True:
|
||||||
|
description = self.name_generator.return_value
|
||||||
|
|
||||||
|
self.kc.projects.update.assert_called_once_with(
|
||||||
|
project_id, name=name, description=description, enabled=enabled)
|
||||||
|
|
||||||
def test_delete_project(self):
|
def test_delete_project(self):
|
||||||
project_id = "fake_id"
|
project_id = "fake_id"
|
||||||
self.service.delete_project(project_id)
|
self.service.delete_project(project_id)
|
||||||
@ -95,30 +118,57 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.service.list_projects())
|
self.service.list_projects())
|
||||||
self.kc.projects.list.assert_called_once_with()
|
self.kc.projects.list.assert_called_once_with()
|
||||||
|
|
||||||
|
def test_get_project(self):
|
||||||
|
project_id = "fake_id"
|
||||||
|
self.service.get_project(project_id)
|
||||||
|
self.kc.projects.get.assert_called_once_with(project_id)
|
||||||
|
|
||||||
@mock.patch("%s.LOG" % PATH)
|
@mock.patch("%s.LOG" % PATH)
|
||||||
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
||||||
def test_create_user(self, mock__get_domain_id, mock_log):
|
def test_create_user(self, mock__get_domain_id, mock_log):
|
||||||
|
|
||||||
name = "name"
|
name = "name"
|
||||||
password = "passwd"
|
password = "passwd"
|
||||||
email = "rally@example.com"
|
|
||||||
project_id = "project"
|
project_id = "project"
|
||||||
domain_name = "domain"
|
domain_name = "domain"
|
||||||
|
|
||||||
self.service.list_roles = mock.MagicMock(return_value=[])
|
self.service.list_roles = mock.MagicMock(return_value=[])
|
||||||
|
|
||||||
user = self.service.create_user(name, password=password, email=email,
|
user = self.service.create_user(name, password=password,
|
||||||
project_id=project_id,
|
project_id=project_id,
|
||||||
domain_name=domain_name)
|
domain_name=domain_name)
|
||||||
|
|
||||||
self.assertEqual(user, self.kc.users.create.return_value)
|
self.assertEqual(user, self.kc.users.create.return_value)
|
||||||
self.kc.users.create.assert_called_once_with(
|
self.kc.users.create.assert_called_once_with(
|
||||||
name=name, password=password, email=email,
|
name=name, password=password, default_project=project_id,
|
||||||
default_project=project_id,
|
domain=mock__get_domain_id.return_value,
|
||||||
domain=mock__get_domain_id.return_value)
|
enabled=True)
|
||||||
|
|
||||||
self.assertTrue(mock_log.warning.called)
|
self.assertTrue(mock_log.warning.called)
|
||||||
|
|
||||||
|
@mock.patch("%s.LOG" % PATH)
|
||||||
|
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
||||||
|
def test_create_user_without_project_id(self, mock__get_domain_id,
|
||||||
|
mock_log):
|
||||||
|
|
||||||
|
name = "name"
|
||||||
|
password = "passwd"
|
||||||
|
domain_name = "domain"
|
||||||
|
|
||||||
|
self.service.list_roles = mock.MagicMock(return_value=[])
|
||||||
|
|
||||||
|
user = self.service.create_user(name, password=password,
|
||||||
|
domain_name=domain_name)
|
||||||
|
|
||||||
|
self.assertEqual(user, self.kc.users.create.return_value)
|
||||||
|
self.kc.users.create.assert_called_once_with(
|
||||||
|
name=name, password=password, default_project=None,
|
||||||
|
domain=mock__get_domain_id.return_value,
|
||||||
|
enabled=True)
|
||||||
|
|
||||||
|
self.assertFalse(self.service.list_roles.called)
|
||||||
|
self.assertFalse(mock_log.warning.called)
|
||||||
|
|
||||||
@mock.patch("%s.LOG" % PATH)
|
@mock.patch("%s.LOG" % PATH)
|
||||||
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
||||||
def test_create_user_and_add_role(
|
def test_create_user_and_add_role(
|
||||||
@ -127,7 +177,6 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
|
|
||||||
name = "name"
|
name = "name"
|
||||||
password = "passwd"
|
password = "passwd"
|
||||||
email = "rally@example.com"
|
|
||||||
project_id = "project"
|
project_id = "project"
|
||||||
domain_name = "domain"
|
domain_name = "domain"
|
||||||
|
|
||||||
@ -140,15 +189,15 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
return_value=[Role("admin"), Role("member")])
|
return_value=[Role("admin"), Role("member")])
|
||||||
self.service.add_role = mock.MagicMock()
|
self.service.add_role = mock.MagicMock()
|
||||||
|
|
||||||
user = self.service.create_user(name, password=password, email=email,
|
user = self.service.create_user(name, password=password,
|
||||||
project_id=project_id,
|
project_id=project_id,
|
||||||
domain_name=domain_name)
|
domain_name=domain_name)
|
||||||
|
|
||||||
self.assertEqual(user, self.kc.users.create.return_value)
|
self.assertEqual(user, self.kc.users.create.return_value)
|
||||||
self.kc.users.create.assert_called_once_with(
|
self.kc.users.create.assert_called_once_with(
|
||||||
name=name, password=password, email=email,
|
name=name, password=password, default_project=project_id,
|
||||||
default_project=project_id,
|
domain=mock__get_domain_id.return_value,
|
||||||
domain=mock__get_domain_id.return_value)
|
enabled=True)
|
||||||
|
|
||||||
self.assertFalse(mock_log.warning.called)
|
self.assertFalse(mock_log.warning.called)
|
||||||
self.service.add_role.assert_called_once_with(
|
self.service.add_role.assert_called_once_with(
|
||||||
@ -156,25 +205,65 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
user_id=user.id,
|
user_id=user.id,
|
||||||
project_id=project_id)
|
project_id=project_id)
|
||||||
|
|
||||||
def test_list_users(self):
|
def test_create_users(self):
|
||||||
self.assertEqual(self.kc.users.list.return_value,
|
self.service.create_user = mock.MagicMock()
|
||||||
self.service.list_users())
|
|
||||||
self.kc.users.list.assert_called_once_with()
|
|
||||||
|
|
||||||
def test_delete_user(self):
|
n = 2
|
||||||
|
project_id = "some"
|
||||||
|
self.assertEqual([self.service.create_user.return_value] * n,
|
||||||
|
self.service.create_users(number_of_users=n,
|
||||||
|
project_id=project_id))
|
||||||
|
self.assertEqual([mock.call(project_id=project_id)] * n,
|
||||||
|
self.service.create_user.call_args_list)
|
||||||
|
|
||||||
|
@ddt.data(None, "some")
|
||||||
|
def test_update_user(self, domain_name):
|
||||||
user_id = "fake_id"
|
user_id = "fake_id"
|
||||||
self.service.delete_user(user_id)
|
name = "new name"
|
||||||
self.kc.users.delete.assert_called_once_with(user_id)
|
project_id = "new project"
|
||||||
|
password = "pass"
|
||||||
|
email = "mail"
|
||||||
|
description = "n/a"
|
||||||
|
enabled = False
|
||||||
|
default_project = "some"
|
||||||
|
|
||||||
def test_delete_service(self):
|
self.service._get_domain_id = mock.MagicMock()
|
||||||
service_id = "fake_id"
|
|
||||||
self.service.delete_service(service_id)
|
|
||||||
self.kc.services.delete.assert_called_once_with(service_id)
|
|
||||||
|
|
||||||
def test_list_services(self):
|
self.service.update_user(user_id, name=name, domain_name=domain_name,
|
||||||
self.assertEqual(self.kc.services.list.return_value,
|
project_id=project_id, password=password,
|
||||||
self.service.list_services())
|
email=email, description=description,
|
||||||
self.kc.services.list.assert_called_once_with()
|
enabled=enabled,
|
||||||
|
default_project=default_project)
|
||||||
|
|
||||||
|
domain = None
|
||||||
|
if domain_name:
|
||||||
|
self.service._get_domain_id.assert_called_once_with(domain_name)
|
||||||
|
domain = self.service._get_domain_id.return_value
|
||||||
|
else:
|
||||||
|
self.assertFalse(self.service._get_domain_id.called)
|
||||||
|
|
||||||
|
self.kc.users.update.assert_called_once_with(
|
||||||
|
user_id, name=name, domain=domain, project=project_id,
|
||||||
|
password=password, email=email, description=description,
|
||||||
|
enabled=enabled, default_project=default_project)
|
||||||
|
|
||||||
|
@ddt.data({"name": None, "service_type": None, "description": None,
|
||||||
|
"enabled": True},
|
||||||
|
{"name": "some", "service_type": "st", "description": "d",
|
||||||
|
"enabled": False})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_create_service(self, name, service_type, description, enabled):
|
||||||
|
self.assertEqual(self.kc.services.create.return_value,
|
||||||
|
self.service.create_service(name=name,
|
||||||
|
service_type=service_type,
|
||||||
|
description=description,
|
||||||
|
enabled=enabled))
|
||||||
|
name = name or self.name_generator.return_value
|
||||||
|
service_type = service_type or "rally_test_type"
|
||||||
|
description = description or self.name_generator.return_value
|
||||||
|
self.kc.services.create.assert_called_once_with(
|
||||||
|
name, type=service_type, description=description,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
@mock.patch("%s.KeystoneV3Service._get_domain_id" % PATH)
|
||||||
def test_create_role(self, mock__get_domain_id):
|
def test_create_role(self, mock__get_domain_id):
|
||||||
@ -188,6 +277,26 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.kc.roles.create.assert_called_once_with(
|
self.kc.roles.create.assert_called_once_with(
|
||||||
name, domain=mock__get_domain_id.return_value)
|
name, domain=mock__get_domain_id.return_value)
|
||||||
|
|
||||||
|
@ddt.data({"domain_name": "domain", "user_id": "user", "project_id": "pr"},
|
||||||
|
{"domain_name": None, "user_id": None, "project_id": None})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_list_roles(self, domain_name, user_id, project_id):
|
||||||
|
self.service._get_domain_id = mock.MagicMock()
|
||||||
|
self.assertEqual(self.kc.roles.list.return_value,
|
||||||
|
self.service.list_roles(user_id=user_id,
|
||||||
|
domain_name=domain_name,
|
||||||
|
project_id=project_id))
|
||||||
|
domain = None
|
||||||
|
if domain_name:
|
||||||
|
self.service._get_domain_id.assert_called_once_with(domain_name)
|
||||||
|
domain = self.service._get_domain_id.return_value
|
||||||
|
else:
|
||||||
|
self.assertFalse(self.service._get_domain_id.called)
|
||||||
|
|
||||||
|
self.kc.roles.list.assert_called_once_with(user=user_id,
|
||||||
|
domain=domain,
|
||||||
|
project=project_id)
|
||||||
|
|
||||||
def test_add_role(self):
|
def test_add_role(self):
|
||||||
role_id = "fake_id"
|
role_id = "fake_id"
|
||||||
user_id = "user_id"
|
user_id = "user_id"
|
||||||
@ -197,17 +306,6 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.kc.roles.grant.assert_called_once_with(
|
self.kc.roles.grant.assert_called_once_with(
|
||||||
user=user_id, role=role_id, project=project_id)
|
user=user_id, role=role_id, project=project_id)
|
||||||
|
|
||||||
def test_delete_role(self):
|
|
||||||
role_id = "fake_id"
|
|
||||||
self.service.delete_role(role_id)
|
|
||||||
self.kc.roles.delete.assert_called_once_with(role_id)
|
|
||||||
|
|
||||||
def test_list_roles(self):
|
|
||||||
self.assertEqual(self.kc.roles.list.return_value,
|
|
||||||
self.service.list_roles())
|
|
||||||
self.kc.roles.list.assert_called_once_with(project=None, user=None,
|
|
||||||
domain=None)
|
|
||||||
|
|
||||||
def test_revoke_role(self):
|
def test_revoke_role(self):
|
||||||
role_id = "fake_id"
|
role_id = "fake_id"
|
||||||
user_id = "user_id"
|
user_id = "user_id"
|
||||||
@ -233,7 +331,18 @@ class KeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.kc.domains.create.assert_called_once_with(
|
self.kc.domains.create.assert_called_once_with(
|
||||||
name, description=descr, enabled=enabled)
|
name, description=descr, enabled=enabled)
|
||||||
|
|
||||||
|
def test_create_ec2credentials(self):
|
||||||
|
user_id = "fake_id"
|
||||||
|
project_id = "fake_id"
|
||||||
|
|
||||||
|
self.assertEqual(self.kc.ec2.create.return_value,
|
||||||
|
self.service.create_ec2credentials(
|
||||||
|
user_id, project_id=project_id))
|
||||||
|
self.kc.ec2.create.assert_called_once_with(user_id,
|
||||||
|
project_id=project_id)
|
||||||
|
|
||||||
|
|
||||||
|
@ddt.ddt
|
||||||
class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(UnifiedKeystoneV3ServiceTestCase, self).setUp()
|
super(UnifiedKeystoneV3ServiceTestCase, self).setUp()
|
||||||
@ -300,11 +409,35 @@ class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.service._impl.create_project.return_value)
|
self.service._impl.create_project.return_value)
|
||||||
self.service._impl.create_project.assert_called_once_with(name)
|
self.service._impl.create_project.assert_called_once_with(name)
|
||||||
|
|
||||||
|
def test_update_project(self):
|
||||||
|
project_id = "fake_id"
|
||||||
|
name = "name"
|
||||||
|
description = "descr"
|
||||||
|
enabled = False
|
||||||
|
|
||||||
|
self.service.update_project(project_id=project_id, name=name,
|
||||||
|
description=description, enabled=enabled)
|
||||||
|
self.service._impl.update_project.assert_called_once_with(
|
||||||
|
project_id=project_id, name=name, description=description,
|
||||||
|
enabled=enabled)
|
||||||
|
|
||||||
def test_delete_project(self):
|
def test_delete_project(self):
|
||||||
project_id = "fake_id"
|
project_id = "fake_id"
|
||||||
self.service.delete_project(project_id)
|
self.service.delete_project(project_id)
|
||||||
self.service._impl.delete_project.assert_called_once_with(project_id)
|
self.service._impl.delete_project.assert_called_once_with(project_id)
|
||||||
|
|
||||||
|
@mock.patch("%s.UnifiedKeystoneV3Service._unify_project" % PATH)
|
||||||
|
def test_get_project(self,
|
||||||
|
mock_unified_keystone_v3_service__unify_project):
|
||||||
|
mock_unify_project = mock_unified_keystone_v3_service__unify_project
|
||||||
|
project_id = "id"
|
||||||
|
|
||||||
|
self.assertEqual(mock_unify_project.return_value,
|
||||||
|
self.service.get_project(project_id))
|
||||||
|
mock_unify_project.assert_called_once_with(
|
||||||
|
self.service._impl.get_project.return_value)
|
||||||
|
self.service._impl.get_project.assert_called_once_with(project_id)
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV3Service._unify_project" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV3Service._unify_project" % PATH)
|
||||||
def test_list_projects(self,
|
def test_list_projects(self,
|
||||||
mock_unified_keystone_v3_service__unify_project):
|
mock_unified_keystone_v3_service__unify_project):
|
||||||
@ -323,28 +456,33 @@ class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
|
|
||||||
name = "name"
|
name = "name"
|
||||||
password = "passwd"
|
password = "passwd"
|
||||||
email = "rally@example.com"
|
|
||||||
project_id = "project"
|
project_id = "project"
|
||||||
domain_name = "domain"
|
domain_name = "domain"
|
||||||
default_role = "role"
|
default_role = "role"
|
||||||
|
|
||||||
self.assertEqual(mock_unify_user.return_value,
|
self.assertEqual(mock_unify_user.return_value,
|
||||||
self.service.create_user(name, password=password,
|
self.service.create_user(name, password=password,
|
||||||
email=email,
|
|
||||||
project_id=project_id,
|
project_id=project_id,
|
||||||
domain_name=domain_name,
|
domain_name=domain_name,
|
||||||
default_role=default_role))
|
default_role=default_role))
|
||||||
mock_unify_user.assert_called_once_with(
|
mock_unify_user.assert_called_once_with(
|
||||||
self.service._impl.create_user.return_value)
|
self.service._impl.create_user.return_value)
|
||||||
self.service._impl.create_user.assert_called_once_with(
|
self.service._impl.create_user.assert_called_once_with(
|
||||||
username=name, password=password, email=email,
|
username=name, password=password, project_id=project_id,
|
||||||
project_id=project_id, domain_name=domain_name,
|
domain_name=domain_name, default_role=default_role, enabled=True)
|
||||||
default_role=default_role)
|
|
||||||
|
|
||||||
def test_delete_user(self):
|
@mock.patch("%s.UnifiedKeystoneV3Service._unify_user" % PATH)
|
||||||
user_id = "fake_id"
|
def test_create_users(self, mock_unified_keystone_v3_service__unify_user):
|
||||||
self.service.delete_user(user_id)
|
project_id = "project"
|
||||||
self.service._impl.delete_user.assert_called_once_with(user_id)
|
n = 3
|
||||||
|
domain_name = "Default"
|
||||||
|
|
||||||
|
self.service.create_users(
|
||||||
|
project_id, number_of_users=3,
|
||||||
|
user_create_args={"domain_name": domain_name})
|
||||||
|
self.service._impl.create_users.assert_called_once_with(
|
||||||
|
project_id=project_id, number_of_users=n,
|
||||||
|
user_create_args={"domain_name": domain_name})
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV3Service._unify_user" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV3Service._unify_user" % PATH)
|
||||||
def test_list_users(self, mock_unified_keystone_v3_service__unify_user):
|
def test_list_users(self, mock_unified_keystone_v3_service__unify_user):
|
||||||
@ -357,10 +495,17 @@ class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.service.list_users())
|
self.service.list_users())
|
||||||
mock_unify_user.assert_called_once_with(users[0])
|
mock_unify_user.assert_called_once_with(users[0])
|
||||||
|
|
||||||
def test_delete_service(self):
|
@ddt.data({"user_id": "id", "enabled": False, "name": "Fake",
|
||||||
service_id = "fake_id"
|
"email": "badboy@example.com", "password": "pass"},
|
||||||
self.service.delete_service(service_id)
|
{"user_id": "id", "enabled": None, "name": None,
|
||||||
self.service._impl.delete_service.assert_called_once_with(service_id)
|
"email": None, "password": None})
|
||||||
|
@ddt.unpack
|
||||||
|
def test_update_user(self, user_id, enabled, name, email, password):
|
||||||
|
self.service.update_user(user_id, enabled=enabled, name=name,
|
||||||
|
email=email, password=password)
|
||||||
|
self.service._impl.update_user.assert_called_once_with(
|
||||||
|
user_id, enabled=enabled, name=name, email=email,
|
||||||
|
password=password)
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV3Service._unify_service" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV3Service._unify_service" % PATH)
|
||||||
def test_list_services(self,
|
def test_list_services(self,
|
||||||
@ -375,26 +520,28 @@ class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
mock_unify_service.assert_called_once_with(services[0])
|
mock_unify_service.assert_called_once_with(services[0])
|
||||||
|
|
||||||
@mock.patch("%s.UnifiedKeystoneV3Service._unify_role" % PATH)
|
@mock.patch("%s.UnifiedKeystoneV3Service._unify_role" % PATH)
|
||||||
def test_add_role(self, mock_unified_keystone_v3_service__unify_role):
|
def test_create_role(self, mock_unified_keystone_v3_service__unify_role):
|
||||||
mock_unify_role = mock_unified_keystone_v3_service__unify_role
|
mock_unify_role = mock_unified_keystone_v3_service__unify_role
|
||||||
|
name = "some"
|
||||||
|
domain = "some"
|
||||||
|
|
||||||
|
self.assertEqual(mock_unify_role.return_value,
|
||||||
|
self.service.create_role(name, domain_name=domain))
|
||||||
|
|
||||||
|
self.service._impl.create_role.assert_called_once_with(
|
||||||
|
name, domain_name=domain)
|
||||||
|
mock_unify_role.assert_called_once_with(
|
||||||
|
self.service._impl.create_role.return_value)
|
||||||
|
|
||||||
|
def test_add_role(self):
|
||||||
role_id = "fake_id"
|
role_id = "fake_id"
|
||||||
user_id = "user_id"
|
user_id = "user_id"
|
||||||
project_id = "user_id"
|
project_id = "user_id"
|
||||||
|
|
||||||
self.assertEqual(mock_unify_role.return_value,
|
self.service.add_role(role_id, user_id=user_id, project_id=project_id)
|
||||||
self.service.add_role(role_id, user_id=user_id,
|
|
||||||
project_id=project_id))
|
|
||||||
|
|
||||||
self.service._impl.add_role.assert_called_once_with(
|
self.service._impl.add_role.assert_called_once_with(
|
||||||
user_id=user_id, role_id=role_id, project_id=project_id)
|
user_id=user_id, role_id=role_id, project_id=project_id)
|
||||||
mock_unify_role.assert_called_once_with(
|
|
||||||
self.service._impl.add_role.return_value)
|
|
||||||
|
|
||||||
def test_delete_role(self):
|
|
||||||
role_id = "fake_id"
|
|
||||||
self.service.delete_role(role_id)
|
|
||||||
self.service._impl.delete_role.assert_called_once_with(role_id)
|
|
||||||
|
|
||||||
def test_revoke_role(self):
|
def test_revoke_role(self):
|
||||||
role_id = "fake_id"
|
role_id = "fake_id"
|
||||||
@ -418,7 +565,13 @@ class UnifiedKeystoneV3ServiceTestCase(test.TestCase):
|
|||||||
self.service.list_roles())
|
self.service.list_roles())
|
||||||
mock_unify_role.assert_called_once_with(roles[0])
|
mock_unify_role.assert_called_once_with(roles[0])
|
||||||
|
|
||||||
def test_get_role(self):
|
def test_create_ec2credentials(self):
|
||||||
role_id = "fake_id"
|
user_id = "id"
|
||||||
self.service.get_role(role_id)
|
project_id = "project-id"
|
||||||
self.service._impl.get_role.assert_called_once_with(role_id)
|
|
||||||
|
self.assertEqual(self.service._impl.create_ec2credentials.return_value,
|
||||||
|
self.service.create_ec2credentials(
|
||||||
|
user_id=user_id, project_id=project_id))
|
||||||
|
|
||||||
|
self.service._impl.create_ec2credentials.assert_called_once_with(
|
||||||
|
user_id=user_id, project_id=project_id)
|
||||||
|
Loading…
Reference in New Issue
Block a user