monasca-transform/tests/unit/test_json_kafka_offsets.py

258 lines
11 KiB
Python

# Copyright 2016 Hewlett Packard Enterprise Development Company LP
#
# 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 datetime
import json
import os
import random
import sys
import unittest
import uuid
from monasca_transform.offset_specs import JSONOffsetSpecs
from monasca_transform.offset_specs import OffsetSpec
class TestJSONOffsetSpecs(unittest.TestCase):
test_resources_path = 'tests/unit/test_resources'
def setUp(self):
pass
def tearDown(self):
pass
def get_dummy_batch_time(self):
"""get a batch time for all tests."""
my_batch_time = datetime.datetime.strptime('2016-01-01 00:00:00',
'%Y-%m-%d %H:%M:%S')
return my_batch_time
def test_read_offsets_on_start(self):
json_offset_specs = JSONOffsetSpecs(
path=self.test_resources_path,
filename='test_read_offsets_on_start.json')
app_name = "mon_metrics_kafka"
kafka_offsets = json_offset_specs.get_kafka_offsets(app_name)
self.assertEqual(1, len(kafka_offsets))
offset_key_0 = kafka_offsets.iterkeys().next()
self.assertEqual('mon_metrics_kafka_metrics_0', offset_key_0)
offset_value_0 = kafka_offsets.get(offset_key_0)
self.assertEqual('metrics', offset_value_0.get_topic())
self.assertEqual(85081, offset_value_0.get_until_offset())
self.assertEqual(0, offset_value_0.get_partition())
self.assertEqual(app_name, offset_value_0.get_app_name())
self.assertEqual(84790, offset_value_0.get_from_offset())
def test_write_offsets_each_add(self):
filename = '%s.json' % str(uuid.uuid4())
file_path = os.path.join(self.test_resources_path, filename)
json_offset_specs = JSONOffsetSpecs(
path=self.test_resources_path,
filename=filename
)
topic_1 = str(uuid.uuid4())
partition_1 = random.randint(0, 1024)
until_offset_1 = random.randint(0, sys.maxsize)
from_offset_1 = random.randint(0, sys.maxsize)
app_name_1 = str(uuid.uuid4())
my_batch_time = self.get_dummy_batch_time()
used_values = {}
json_offset_specs.add(topic=topic_1, partition=partition_1,
app_name=app_name_1, from_offset=from_offset_1,
until_offset=until_offset_1,
batch_time_info=my_batch_time)
kafka_offset_dict = self.load_offset_file_as_json(file_path)
offset_key_1 = "%s_%s_%s" % (app_name_1, topic_1, partition_1)
used_values[offset_key_1] = {
"topic": topic_1, "partition": partition_1, "app_name": app_name_1,
"from_offset": from_offset_1, "until_offset": until_offset_1
}
offset_value_1 = kafka_offset_dict.get(offset_key_1)
self.assertions_on_offset(used_value=used_values.get(offset_key_1),
offset_value=offset_value_1)
topic_2 = str(uuid.uuid4())
partition_2 = random.randint(0, 1024)
until_offset_2 = random.randint(0, sys.maxsize)
from_offset_2 = random.randint(0, sys.maxsize)
app_name_2 = str(uuid.uuid4())
json_offset_specs.add(topic=topic_2, partition=partition_2,
app_name=app_name_2, from_offset=from_offset_2,
until_offset=until_offset_2,
batch_time_info=my_batch_time)
offset_key_2 = "%s_%s_%s" % (app_name_2, topic_2, partition_2)
used_values[offset_key_2] = {
"topic": topic_2, "partition": partition_2, "app_name": app_name_2,
"from_offset": from_offset_2, "until_offset": until_offset_2
}
kafka_offset_dict = self.load_offset_file_as_json(file_path)
for key in [offset_key_1, offset_key_2]:
self.assertions_on_offset(used_value=used_values.get(key),
offset_value=kafka_offset_dict.get(key))
# if assertions fail then file is left for analysis
os.remove(file_path)
def test_as_dict(self):
topic_1 = str(uuid.uuid4())
partition_1 = random.randint(0, 1024)
until_offset_1 = random.randint(0, sys.maxsize)
from_offset_1 = random.randint(0, sys.maxsize)
app_name_1 = str(uuid.uuid4())
offset_spec = OffsetSpec(
app_name=app_name_1, topic=topic_1, partition=partition_1,
from_offset=from_offset_1, until_offset=until_offset_1)
offset_spec_dict = JSONOffsetSpecs.as_dict(offset_spec)
self.assertions_on_offset(
used_value={
"topic": topic_1, "partition": partition_1,
"app_name": app_name_1, "from_offset": from_offset_1,
"until_offset": until_offset_1},
offset_value=offset_spec_dict)
def test_write_then_read(self):
filename = '%s.json' % str(uuid.uuid4())
json_offset_specs = JSONOffsetSpecs(
path=self.test_resources_path,
filename=filename
)
topic_1 = str(uuid.uuid4())
partition_1 = random.randint(0, 1024)
until_offset_1 = random.randint(0, sys.maxsize)
from_offset_1 = random.randint(0, sys.maxsize)
app_name_1 = str(uuid.uuid4())
my_batch_time = self.get_dummy_batch_time()
used_values = {}
json_offset_specs.add(topic=topic_1, partition=partition_1,
app_name=app_name_1, from_offset=from_offset_1,
until_offset=until_offset_1,
batch_time_info=my_batch_time)
offset_key_1 = "%s_%s_%s" % (app_name_1, topic_1, partition_1)
used_values[offset_key_1] = {
"topic": topic_1, "partition": partition_1, "app_name": app_name_1,
"from_offset": from_offset_1, "until_offset": until_offset_1
}
topic_2 = str(uuid.uuid4())
partition_2 = random.randint(0, 1024)
until_offset_2 = random.randint(0, sys.maxsize)
from_offset_2 = random.randint(0, sys.maxsize)
app_name_2 = str(uuid.uuid4())
json_offset_specs.add(topic=topic_2, partition=partition_2,
app_name=app_name_2, from_offset=from_offset_2,
until_offset=until_offset_2,
batch_time_info=my_batch_time)
offset_key_2 = "%s_%s_%s" % (app_name_2, topic_2, partition_2)
used_values[offset_key_2] = {
"topic": topic_2, "partition": partition_2, "app_name": app_name_2,
"from_offset": from_offset_2, "until_offset": until_offset_2
}
# now create a new JSONOffsetSpecs
json_offset_specs_2 = JSONOffsetSpecs(self.test_resources_path,
filename)
found_offsets = json_offset_specs_2.get_kafka_offsets(app_name_2)
json_found_offsets = {key: JSONOffsetSpecs.as_dict(value)
for key, value in found_offsets.items()}
for key, value in used_values.items():
found_value = json_found_offsets.get(key)
self.assertEqual(value.get("app_name"),
found_value.get("app_name"))
self.assertEqual(value.get("topic"), found_value.get("topic"))
self.assertEqual(value.get("partition"),
found_value.get("partition"))
self.assertEqual(value.get("from_offset"),
found_value.get("from_offset"))
self.assertEqual(value.get("until_offset"),
found_value.get("until_offset"))
os.remove(os.path.join(self.test_resources_path, filename))
def test_update_offset_values(self):
filename = '%s.json' % str(uuid.uuid4())
file_path = os.path.join(self.test_resources_path, filename)
json_offset_specs = JSONOffsetSpecs(
path=self.test_resources_path,
filename=filename
)
topic_1 = str(uuid.uuid4())
partition_1 = random.randint(0, 1024)
until_offset_1 = random.randint(0, sys.maxsize)
from_offset_1 = random.randint(0, sys.maxsize)
app_name_1 = str(uuid.uuid4())
my_batch_time = self.get_dummy_batch_time()
used_values = {}
json_offset_specs.add(topic=topic_1, partition=partition_1,
app_name=app_name_1, from_offset=from_offset_1,
until_offset=until_offset_1,
batch_time_info=my_batch_time)
kafka_offset_dict = self.load_offset_file_as_json(file_path)
offset_key_1 = "%s_%s_%s" % (app_name_1, topic_1, partition_1)
used_values[offset_key_1] = {
"topic": topic_1, "partition": partition_1, "app_name": app_name_1,
"from_offset": from_offset_1, "until_offset": until_offset_1
}
offset_value_1 = kafka_offset_dict.get(offset_key_1)
self.assertions_on_offset(used_value=used_values.get(offset_key_1),
offset_value=offset_value_1)
until_offset_2 = random.randint(0, sys.maxsize)
while until_offset_2 == until_offset_1:
until_offset_2 = random.randint(0, sys.maxsize)
from_offset_2 = random.randint(0, sys.maxsize)
while from_offset_2 == from_offset_1:
from_offset_2 = random.randint(0, sys.maxsize)
json_offset_specs.add(topic=topic_1, partition=partition_1,
app_name=app_name_1, from_offset=from_offset_2,
until_offset=until_offset_2,
batch_time_info=my_batch_time)
kafka_offset_dict = self.load_offset_file_as_json(file_path)
offset_value_updated = kafka_offset_dict.get(offset_key_1)
self.assertEqual(from_offset_2,
offset_value_updated.get('from_offset'))
self.assertEqual(until_offset_2,
offset_value_updated.get('until_offset'))
os.remove(file_path)
def load_offset_file_as_json(self, file_path):
with open(file_path, 'r') as f:
json_file = json.load(f)
return json_file
@unittest.skip
def test_get_offsets_is_obj_based(self):
self.fail('We need to assert that we get objects back '
'from the get offsets method')
def assertions_on_offset(self, used_value=None, offset_value=None):
self.assertEqual(used_value.get('topic'),
offset_value.get('topic'))
self.assertEqual(used_value.get('partition'),
int(offset_value.get('partition')))
self.assertEqual(used_value.get('until_offset'),
int(offset_value.get('until_offset')))
self.assertEqual(used_value.get('from_offset'),
int(offset_value.get('from_offset')))
self.assertEqual(used_value.get('app_name'),
offset_value.get('app_name'))