a3e7db9916
Create the base data abstraction layer into the DB in basic API service. I create a database table services as a example. This table is used to save the running status of deployed services. The command smaug-manage is used to manage the database. we can use this command 'smaug-manage db sync' to sync the smaug database up to the most recent version. smaug-manage version list: exposing the smaug codebase version. smaug-manage config list: exposing the configuration. smaug-manage service list: showing a list of all smaug services status. Change-Id: I2beeae0c0a7494a88bc4e4d143d36cee3f3f2a4e Closes-Bug: #1525794
99 lines
4.5 KiB
Python
99 lines
4.5 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.
|
|
|
|
"""Tests for Models Database."""
|
|
|
|
from oslo_config import cfg
|
|
|
|
from smaug import context
|
|
from smaug import db
|
|
from smaug import exception
|
|
from smaug.tests import base
|
|
|
|
|
|
CONF = cfg.CONF
|
|
|
|
|
|
class ServicesDbTestCase(base.TestCase):
|
|
"""Test cases for Services database table."""
|
|
|
|
def setUp(self):
|
|
super(ServicesDbTestCase, self).setUp()
|
|
self.ctxt = context.RequestContext(user_id='user_id',
|
|
project_id='project_id',
|
|
is_admin=True)
|
|
|
|
def test_services_create(self):
|
|
service_ref = db.service_create(self.ctxt,
|
|
{'host': 'hosttest',
|
|
'binary': 'binarytest',
|
|
'topic': 'topictest',
|
|
'report_count': 0,
|
|
'availability_zone': 'zonetest'})
|
|
self.assertEqual(service_ref['host'], 'hosttest')
|
|
|
|
def test_services_get(self):
|
|
service_ref = db.service_create(self.ctxt,
|
|
{'host': 'hosttest1',
|
|
'binary': 'binarytest1',
|
|
'topic': 'topictest1',
|
|
'report_count': 0,
|
|
'availability_zone': 'zonetest1'})
|
|
|
|
service_get_ref = db.service_get(self.ctxt, service_ref['id'])
|
|
self.assertEqual(service_ref['host'], 'hosttest1')
|
|
self.assertEqual(service_get_ref['host'], 'hosttest1')
|
|
|
|
def test_service_destroy(self):
|
|
service_ref = db.service_create(self.ctxt,
|
|
{'host': 'hosttest2',
|
|
'binary': 'binarytest2',
|
|
'topic': 'topictest2',
|
|
'report_count': 0,
|
|
'availability_zone': 'zonetest2'})
|
|
service_id = service_ref['id']
|
|
db.service_destroy(self.ctxt, service_id)
|
|
self.assertRaises(exception.ServiceNotFound, db.service_get,
|
|
self.ctxt, service_id)
|
|
|
|
def test_service_update(self):
|
|
service_ref = db.service_create(self.ctxt,
|
|
{'host': 'hosttest3',
|
|
'binary': 'binarytest3',
|
|
'topic': 'topictest3',
|
|
'report_count': 0,
|
|
'availability_zone': 'zonetest3'})
|
|
service_id = service_ref['id']
|
|
service_update_ref = db.service_update(self.ctxt, service_id,
|
|
{'host': 'hosttest4',
|
|
'binary': 'binarytest4',
|
|
'topic': 'topictest4',
|
|
'report_count': 0,
|
|
'availability_zone':
|
|
'zonetest4'})
|
|
self.assertEqual(service_ref['host'], 'hosttest3')
|
|
self.assertEqual(service_update_ref['host'], 'hosttest4')
|
|
|
|
def test_service_get_by_host_and_topic(self):
|
|
service_ref = db.service_create(self.ctxt,
|
|
{'host': 'hosttest5',
|
|
'binary': 'binarytest5',
|
|
'topic': 'topictest5',
|
|
'report_count': 0,
|
|
'availability_zone': 'zonetest5'})
|
|
|
|
service_get_ref = db.service_get_by_host_and_topic(self.ctxt,
|
|
'hosttest5',
|
|
'topictest5')
|
|
self.assertEqual(service_ref['host'], 'hosttest5')
|
|
self.assertEqual(service_get_ref['host'], 'hosttest5')
|