
Also, made some minor changes to imports orders to fit PEP8 Change-Id: I1596989cac61602a3f417c9d60774354f5650424
51 lines
2.1 KiB
Python
51 lines
2.1 KiB
Python
# 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.task import validation
|
|
|
|
from rally_openstack import consts
|
|
from rally_openstack import scenario
|
|
from rally_openstack.scenarios.senlin import utils
|
|
|
|
|
|
"""Scenarios for Senlin clusters."""
|
|
|
|
|
|
@validation.add("required_platform", platform="openstack", admin=True)
|
|
@validation.add("required_services", services=[consts.Service.SENLIN])
|
|
@validation.add("required_contexts", contexts=("profiles"))
|
|
@scenario.configure(context={"admin_cleanup@openstack": ["senlin"]},
|
|
name="SenlinClusters.create_and_delete_cluster",
|
|
platform="openstack")
|
|
class CreateAndDeleteCluster(utils.SenlinScenario):
|
|
|
|
def run(self, desired_capacity=0, min_size=0,
|
|
max_size=-1, timeout=3600, metadata=None):
|
|
"""Create a cluster and then delete it.
|
|
|
|
Measure the "senlin cluster-create" and "senlin cluster-delete"
|
|
commands performance.
|
|
|
|
:param desired_capacity: The capacity or initial number of nodes
|
|
owned by the cluster
|
|
:param min_size: The minimum number of nodes owned by the cluster
|
|
:param max_size: The maximum number of nodes owned by the cluster.
|
|
-1 means no limit
|
|
:param timeout: The timeout value in seconds for cluster creation
|
|
:param metadata: A set of key value pairs to associate with the cluster
|
|
"""
|
|
|
|
profile_id = self.context["tenant"]["profile"]
|
|
cluster = self._create_cluster(profile_id, desired_capacity,
|
|
min_size, max_size, timeout, metadata)
|
|
self._delete_cluster(cluster)
|