summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2016-02-12 07:40:34 +0000
committerGerrit Code Review <review@openstack.org>2016-02-12 07:40:35 +0000
commit66365a525ab1aa2a40f230afbd14f7c5a89a8e42 (patch)
treea0eea1f40e244815ba55b3691b3c47a52851aee2
parente4bc109543b81f2b5095c7fb1de4c26293772407 (diff)
parentb968f5fba05e439f9c65d504741bb8ab236e756f (diff)
downloadceilometer-66365a525ab1aa2a40f230afbd14f7c5a89a8e42.tar.gz
Merge "Changes aggregator transformer to allow retention_time w/o size" into stable/kilo
-rw-r--r--ceilometer/tests/pipeline_base.py9
-rw-r--r--ceilometer/tests/unit/transformer/__init__.py0
-rw-r--r--ceilometer/tests/unit/transformer/test_conversions.py89
-rw-r--r--ceilometer/transformer/conversions.py5
4 files changed, 93 insertions, 10 deletions
diff --git a/ceilometer/tests/pipeline_base.py b/ceilometer/tests/pipeline_base.py
index 6686319a..14e97059 100644
--- a/ceilometer/tests/pipeline_base.py
+++ b/ceilometer/tests/pipeline_base.py
@@ -1330,15 +1330,6 @@ class BasePipelineTestCase(base.BaseTestCase):
actual = sorted(s.volume for s in publisher.samples)
self.assertEqual([2.0, 3.0, 6.0], actual)
- def test_aggregator_input_validation(self):
- aggregator = conversions.AggregatorTransformer("1", "15", None,
- None, None)
- self.assertEqual(1, aggregator.size)
- self.assertEqual(15, aggregator.retention_time)
-
- self.assertRaises(ValueError, conversions.AggregatorTransformer,
- "abc", "cde", None, None, None)
-
def test_aggregator_metadata(self):
for conf, expected_version in [('last', '2.0'), ('first', '1.0')]:
samples = self._do_test_aggregator({
diff --git a/ceilometer/tests/unit/transformer/__init__.py b/ceilometer/tests/unit/transformer/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ceilometer/tests/unit/transformer/__init__.py
diff --git a/ceilometer/tests/unit/transformer/test_conversions.py b/ceilometer/tests/unit/transformer/test_conversions.py
new file mode 100644
index 00000000..2e775d5e
--- /dev/null
+++ b/ceilometer/tests/unit/transformer/test_conversions.py
@@ -0,0 +1,89 @@
+#
+# Copyright 2016 IBM Corp.
+#
+# 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 copy
+
+from oslo_context import context
+from oslo_utils import timeutils
+from oslotest import base
+
+from ceilometer import sample
+from ceilometer.transformer import conversions
+
+
+class AggregatorTransformerTestCase(base.BaseTestCase):
+ SAMPLE = sample.Sample(
+ name='cpu',
+ type=sample.TYPE_CUMULATIVE,
+ unit='ns',
+ volume='1234567',
+ user_id='56c5692032f34041900342503fecab30',
+ project_id='ac9494df2d9d4e709bac378cceabaf23',
+ resource_id='1ca738a1-c49c-4401-8346-5c60ebdb03f4',
+ timestamp="2015-10-29 14:12:15.485877+00:00",
+ resource_metadata={}
+ )
+
+ def setUp(self):
+ super(AggregatorTransformerTestCase, self).setUp()
+ self._sample_offset = 0
+
+ def test_init_input_validation(self):
+ aggregator = conversions.AggregatorTransformer("2", "15", None,
+ None, None)
+ self.assertEqual(2, aggregator.size)
+ self.assertEqual(15, aggregator.retention_time)
+
+ def test_init_no_size_or_rention_time(self):
+ aggregator = conversions.AggregatorTransformer()
+ self.assertEqual(1, aggregator.size)
+ self.assertEqual(None, aggregator.retention_time)
+
+ def test_init_size_zero(self):
+ aggregator = conversions.AggregatorTransformer(size="0")
+ self.assertEqual(1, aggregator.size)
+ self.assertEqual(None, aggregator.retention_time)
+
+ def test_init_input_validation_size_invalid(self):
+ self.assertRaises(ValueError, conversions.AggregatorTransformer,
+ "abc", "15", None, None, None)
+
+ def test_init_input_validation_retention_time_invalid(self):
+ self.assertRaises(ValueError, conversions.AggregatorTransformer,
+ "2", "abc", None, None, None)
+
+ def test_size_unbounded(self):
+ aggregator = conversions.AggregatorTransformer(size="0",
+ retention_time="300")
+ self._insert_sample_data(aggregator)
+
+ samples = aggregator.flush(context.get_admin_context())
+
+ self.assertEqual([], samples)
+
+ def test_size_bounded(self):
+ aggregator = conversions.AggregatorTransformer(size="100")
+ self._insert_sample_data(aggregator)
+
+ samples = aggregator.flush(context.get_admin_context())
+
+ self.assertEqual(100, len(samples))
+
+ def _insert_sample_data(self, aggregator):
+ for _ in range(100):
+ sample = copy.copy(self.SAMPLE)
+ sample.resource_id = sample.resource_id + str(self._sample_offset)
+ sample.timestamp = timeutils.isotime()
+ aggregator.handle_sample(context.get_admin_context(), sample)
+ self._sample_offset += 1
diff --git a/ceilometer/transformer/conversions.py b/ceilometer/transformer/conversions.py
index 1e5f8190..307b424c 100644
--- a/ceilometer/transformer/conversions.py
+++ b/ceilometer/transformer/conversions.py
@@ -167,6 +167,9 @@ class AggregatorTransformer(ScalingTransformer):
self.counts = collections.defaultdict(int)
self.size = int(size) if size else None
self.retention_time = float(retention_time) if retention_time else None
+ if not (self.size or self.retention_time):
+ self.size = 1
+
self.initial_timestamp = None
self.aggregated_samples = 0
@@ -229,7 +232,7 @@ class AggregatorTransformer(ScalingTransformer):
expired = (self.retention_time and
timeutils.is_older_than(self.initial_timestamp,
self.retention_time))
- full = self.aggregated_samples >= self.size
+ full = self.size and self.aggregated_samples >= self.size
if full or expired:
x = self.samples.values()
# gauge aggregates need to be averages