Merge "Extend statistic benchmarks for Ceilometer"
This commit is contained in:
commit
f637814243
@ -717,22 +717,42 @@
|
|||||||
failure_rate:
|
failure_rate:
|
||||||
max: 0
|
max: 0
|
||||||
|
|
||||||
CeilometerStats.create_meter_and_get_stats:
|
CeilometerStats.get_stats:
|
||||||
-
|
-
|
||||||
args:
|
|
||||||
user_id: "user-id"
|
|
||||||
resource_id: "resource-id"
|
|
||||||
counter_volume: 1.0
|
|
||||||
counter_unit: ""
|
|
||||||
counter_type: "cumulative"
|
|
||||||
runner:
|
runner:
|
||||||
type: "constant"
|
type: constant
|
||||||
times: 20
|
times: 10
|
||||||
concurrency: 10
|
concurrency: 2
|
||||||
context:
|
context:
|
||||||
users:
|
users:
|
||||||
tenants: 1
|
tenants: 2
|
||||||
users_per_tenant: 1
|
users_per_tenant: 2
|
||||||
|
ceilometer:
|
||||||
|
counter_name: "benchmark_meter"
|
||||||
|
counter_type: "gauge"
|
||||||
|
counter_unit: "%"
|
||||||
|
counter_volume: 100
|
||||||
|
resources_per_tenant: 100
|
||||||
|
samples_per_resource: 100
|
||||||
|
timestamp_interval: 10
|
||||||
|
metadata_list:
|
||||||
|
-
|
||||||
|
status: "active"
|
||||||
|
name: "rally benchmark on"
|
||||||
|
deleted: "false"
|
||||||
|
-
|
||||||
|
status: "terminated"
|
||||||
|
name: "rally benchmark off"
|
||||||
|
deleted: "true"
|
||||||
|
args:
|
||||||
|
meter_name: "benchmark_meter"
|
||||||
|
filter_by_user_id: true
|
||||||
|
filter_by_project_id: true
|
||||||
|
filter_by_resource_id: true
|
||||||
|
metadata_query:
|
||||||
|
status: "terminated"
|
||||||
|
period: 300
|
||||||
|
groupby: "resource_id"
|
||||||
sla:
|
sla:
|
||||||
failure_rate:
|
failure_rate:
|
||||||
max: 0
|
max: 0
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
from rally.common import log
|
||||||
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
|
from rally.plugins.openstack.scenarios.ceilometer import utils
|
||||||
@ -21,9 +22,11 @@ from rally.task import validation
|
|||||||
class CeilometerStats(utils.CeilometerScenario):
|
class CeilometerStats(utils.CeilometerScenario):
|
||||||
"""Benchmark scenarios for Ceilometer Stats API."""
|
"""Benchmark scenarios for Ceilometer Stats API."""
|
||||||
|
|
||||||
|
@log.log_deprecated("Use 'get_stats' method, now samples are created in "
|
||||||
|
"context", "0.1.2")
|
||||||
@validation.required_services(consts.Service.CEILOMETER)
|
@validation.required_services(consts.Service.CEILOMETER)
|
||||||
@validation.required_openstack(users=True)
|
@validation.required_openstack(users=True)
|
||||||
@scenario.configure(context={"cleanup": ["ceilometer"]})
|
@scenario.configure()
|
||||||
def create_meter_and_get_stats(self, **kwargs):
|
def create_meter_and_get_stats(self, **kwargs):
|
||||||
"""Create a meter and fetch its statistics.
|
"""Create a meter and fetch its statistics.
|
||||||
|
|
||||||
@ -34,3 +37,32 @@ class CeilometerStats(utils.CeilometerScenario):
|
|||||||
"""
|
"""
|
||||||
meter = self._create_meter(**kwargs)
|
meter = self._create_meter(**kwargs)
|
||||||
self._get_stats(meter.counter_name)
|
self._get_stats(meter.counter_name)
|
||||||
|
|
||||||
|
@validation.required_services(consts.Service.CEILOMETER)
|
||||||
|
@validation.required_openstack(users=True)
|
||||||
|
@scenario.configure()
|
||||||
|
def get_stats(self, meter_name, filter_by_user_id=False,
|
||||||
|
filter_by_project_id=False, filter_by_resource_id=False,
|
||||||
|
metadata_query=None, period=None, groupby=None,
|
||||||
|
aggregates=None):
|
||||||
|
"""Fetch statistics for certain meter.
|
||||||
|
|
||||||
|
Statistics is fetched for the using
|
||||||
|
GET /v2/meters/(meter_name)/statistics.
|
||||||
|
|
||||||
|
:param meter_name: meter to take statistic for
|
||||||
|
:param filter_by_user_id: flag for query by user_id
|
||||||
|
:param filter_by_project_id: flag for query by project_id
|
||||||
|
:param filter_by_resource_id: flag for query by resource_id
|
||||||
|
:param metadata_query: dict with metadata fields and values for query
|
||||||
|
:param period: the length of the time range covered by these stats
|
||||||
|
:param groupby: the fields used to group the samples
|
||||||
|
:param aggregates: name of function for samples aggregation
|
||||||
|
|
||||||
|
:returns: list of statistics data
|
||||||
|
"""
|
||||||
|
query = self._make_general_query(filter_by_project_id,
|
||||||
|
filter_by_user_id,
|
||||||
|
filter_by_resource_id,
|
||||||
|
metadata_query)
|
||||||
|
self._get_stats(meter_name, query, period, groupby, aggregates)
|
||||||
|
@ -322,12 +322,23 @@ class CeilometerScenario(scenario.OpenStackScenario):
|
|||||||
return self.clients("ceilometer").resources.get(resource_id)
|
return self.clients("ceilometer").resources.get(resource_id)
|
||||||
|
|
||||||
@atomic.action_timer("ceilometer.get_stats")
|
@atomic.action_timer("ceilometer.get_stats")
|
||||||
def _get_stats(self, meter_name):
|
def _get_stats(self, meter_name, query=None, period=None, groupby=None,
|
||||||
|
aggregates=None):
|
||||||
"""Get stats for a specific meter.
|
"""Get stats for a specific meter.
|
||||||
|
|
||||||
:param meter_name: Name of ceilometer meter
|
:param meter_name: Name of ceilometer meter
|
||||||
|
:param query: list of queries
|
||||||
|
:param period: the length of the time range covered by these stats
|
||||||
|
:param groupby: the fields used to group the samples
|
||||||
|
:param aggregates: function for samples aggregation
|
||||||
|
|
||||||
|
:returns: list of statistics data
|
||||||
"""
|
"""
|
||||||
return self.clients("ceilometer").statistics.list(meter_name)
|
return self.clients("ceilometer").statistics.list(meter_name, q=query,
|
||||||
|
period=period,
|
||||||
|
groupby=groupby,
|
||||||
|
aggregates=aggregates
|
||||||
|
)
|
||||||
|
|
||||||
@atomic.action_timer("ceilometer.create_meter")
|
@atomic.action_timer("ceilometer.create_meter")
|
||||||
def _create_meter(self, **kwargs):
|
def _create_meter(self, **kwargs):
|
||||||
|
@ -22,4 +22,3 @@
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
42
samples/tasks/scenarios/ceilometer/get-stats.json
Normal file
42
samples/tasks/scenarios/ceilometer/get-stats.json
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
{
|
||||||
|
"CeilometerStats.get_stats": [
|
||||||
|
{
|
||||||
|
"runner": {
|
||||||
|
"type": "constant",
|
||||||
|
"times": 10,
|
||||||
|
"concurrency": 1
|
||||||
|
},
|
||||||
|
"context": {
|
||||||
|
"users": {
|
||||||
|
"tenants": 2,
|
||||||
|
"users_per_tenant": 2
|
||||||
|
},
|
||||||
|
"ceilometer": {
|
||||||
|
"counter_name": "benchmark_meter",
|
||||||
|
"counter_type": "gauge",
|
||||||
|
"counter_unit": "%",
|
||||||
|
"counter_volume": 100,
|
||||||
|
"resources_per_tenant": 100,
|
||||||
|
"samples_per_resource": 100,
|
||||||
|
"timestamp_interval": 10,
|
||||||
|
"metadata_list": [
|
||||||
|
{"status": "active", "name": "rally benchmark on",
|
||||||
|
"deleted": "false"},
|
||||||
|
{"status": "terminated", "name": "rally benchmark off",
|
||||||
|
"deleted": "true"}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"args": {
|
||||||
|
"meter_name": "benchmark_meter",
|
||||||
|
"filter_by_user_id": true,
|
||||||
|
"filter_by_project_id": true,
|
||||||
|
"filter_by_resource_id": true,
|
||||||
|
"metadata_query": {"status": "terminated"},
|
||||||
|
"period": 300,
|
||||||
|
"groupby": "resource_id"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
37
samples/tasks/scenarios/ceilometer/get-stats.yaml
Normal file
37
samples/tasks/scenarios/ceilometer/get-stats.yaml
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
---
|
||||||
|
CeilometerStats.get_stats:
|
||||||
|
-
|
||||||
|
runner:
|
||||||
|
type: constant
|
||||||
|
times: 10
|
||||||
|
concurrency: 1
|
||||||
|
context:
|
||||||
|
users:
|
||||||
|
tenants: 2
|
||||||
|
users_per_tenant: 2
|
||||||
|
ceilometer:
|
||||||
|
counter_name: "benchmark_meter"
|
||||||
|
counter_type: "gauge"
|
||||||
|
counter_unit: "%"
|
||||||
|
counter_volume: 100
|
||||||
|
resources_per_tenant: 100
|
||||||
|
samples_per_resource: 100
|
||||||
|
timestamp_interval: 10
|
||||||
|
metadata_list:
|
||||||
|
-
|
||||||
|
status: "active"
|
||||||
|
name: "rally benchmark on"
|
||||||
|
deleted: "false"
|
||||||
|
-
|
||||||
|
status: "terminated"
|
||||||
|
name: "rally benchmark off"
|
||||||
|
deleted: "true"
|
||||||
|
args:
|
||||||
|
meter_name: "benchmark_meter"
|
||||||
|
filter_by_user_id: true
|
||||||
|
filter_by_project_id: true
|
||||||
|
filter_by_resource_id: true
|
||||||
|
metadata_query:
|
||||||
|
status: "terminated"
|
||||||
|
period: 300
|
||||||
|
groupby: "resource_id"
|
@ -19,12 +19,27 @@ from tests.unit import test
|
|||||||
|
|
||||||
|
|
||||||
class CeilometerStatsTestCase(test.ScenarioTestCase):
|
class CeilometerStatsTestCase(test.ScenarioTestCase):
|
||||||
def test_create_meter_and_get_stats(self):
|
|
||||||
fake_meter = mock.MagicMock()
|
def test_get_stats(self):
|
||||||
kwargs = mock.MagicMock()
|
|
||||||
scenario = stats.CeilometerStats(self.context)
|
scenario = stats.CeilometerStats(self.context)
|
||||||
scenario._create_meter = mock.MagicMock(return_value=fake_meter)
|
|
||||||
scenario._get_stats = mock.MagicMock()
|
scenario._get_stats = mock.MagicMock()
|
||||||
scenario.create_meter_and_get_stats(**kwargs)
|
context = {"user": {"tenant_id": "fake", "id": "fake_id"},
|
||||||
scenario._create_meter.assert_called_once_with(**kwargs)
|
"tenant": {"id": "fake_id",
|
||||||
scenario._get_stats.assert_called_once_with(fake_meter.counter_name)
|
"resources": ["fake_resource"]}}
|
||||||
|
metadata_query = {"a": "test"}
|
||||||
|
period = 10
|
||||||
|
groupby = "user_id"
|
||||||
|
aggregates = "sum"
|
||||||
|
scenario.context = context
|
||||||
|
scenario.get_stats("fake_meter", True, True, True, metadata_query,
|
||||||
|
period, groupby, aggregates)
|
||||||
|
scenario._get_stats.assert_called_once_with(
|
||||||
|
"fake_meter",
|
||||||
|
[{"field": "user_id", "value": "fake_id", "op": "eq"},
|
||||||
|
{"field": "project_id", "value": "fake_id", "op": "eq"},
|
||||||
|
{"field": "resource_id", "value": "fake_resource", "op": "eq"},
|
||||||
|
{"field": "metadata.a", "value": "test", "op": "eq"}],
|
||||||
|
10,
|
||||||
|
"user_id",
|
||||||
|
"sum"
|
||||||
|
)
|
||||||
|
@ -250,7 +250,7 @@ class CeilometerScenarioTestCase(test.ScenarioTestCase):
|
|||||||
self.scenario._get_stats("fake-meter"),
|
self.scenario._get_stats("fake-meter"),
|
||||||
self.clients("ceilometer").statistics.list.return_value)
|
self.clients("ceilometer").statistics.list.return_value)
|
||||||
self.clients("ceilometer").statistics.list.assert_called_once_with(
|
self.clients("ceilometer").statistics.list.assert_called_once_with(
|
||||||
"fake-meter")
|
"fake-meter", q=None, period=None, groupby=None, aggregates=None)
|
||||||
self._test_atomic_action_timer(self.scenario.atomic_actions(),
|
self._test_atomic_action_timer(self.scenario.atomic_actions(),
|
||||||
"ceilometer.get_stats")
|
"ceilometer.get_stats")
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user