heat/heat/tests/test_common_service_utils.py

74 lines
3.1 KiB
Python

# Copyright (c) 2014 Hewlett-Packard Development Company, L.P.
#
# 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 uuid
from heat.common import service_utils
from heat.db.sqlalchemy import models
from heat.tests import common
class TestServiceUtils(common.HeatTestCase):
def test_status_check(self):
service = models.Service()
service.id = str(uuid.uuid4())
service.engine_id = str(uuid.uuid4())
service.binary = 'heat-engine'
service.hostname = 'host.devstack.org'
service.host = 'engine-1'
service.report_interval = 60
service.topic = 'engine'
service.created_at = datetime.datetime.utcnow()
service.deleted_at = None
service.updated_at = None
service_dict = service_utils.format_service(service)
self.assertEqual(service_dict['id'], service.id)
self.assertEqual(service_dict['engine_id'], service.engine_id)
self.assertEqual(service_dict['host'], service.host)
self.assertEqual(service_dict['hostname'], service.hostname)
self.assertEqual(service_dict['binary'], service.binary)
self.assertEqual(service_dict['topic'], service.topic)
self.assertEqual(service_dict['report_interval'],
service.report_interval)
self.assertEqual(service_dict['created_at'], service.created_at)
self.assertEqual(service_dict['updated_at'], service.updated_at)
self.assertEqual(service_dict['deleted_at'], service.deleted_at)
self.assertEqual(service_dict['status'], 'up')
# check again within first report_interval time (60)
service_dict = service_utils.format_service(service)
self.assertEqual(service_dict['status'], 'up')
# check update not happen within report_interval time (60+)
service.created_at = (datetime.datetime.utcnow() -
datetime.timedelta(0, 70))
service_dict = service_utils.format_service(service)
self.assertEqual(service_dict['status'], 'down')
# check update happened after report_interval time (60+)
service.updated_at = (datetime.datetime.utcnow() -
datetime.timedelta(0, 70))
service_dict = service_utils.format_service(service)
self.assertEqual(service_dict['status'], 'down')
# check update happened within report_interval time (60)
service.updated_at = (datetime.datetime.utcnow() -
datetime.timedelta(0, 50))
service_dict = service_utils.format_service(service)
self.assertEqual(service_dict['status'], 'up')