175 lines
8.1 KiB
Python
175 lines
8.1 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.
|
|
|
|
import json
|
|
import os.path
|
|
|
|
import mock
|
|
from oslo_config import cfg
|
|
from zake import fake_client
|
|
|
|
from kolla_mesos import service
|
|
from kolla_mesos.tests import base
|
|
|
|
|
|
class TestAPI(base.BaseTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestAPI, self).setUp()
|
|
self.service_dir = os.path.join(self.project_dir, 'services')
|
|
self.client = fake_client.FakeClient()
|
|
self.client.start()
|
|
self.addCleanup(self.client.stop)
|
|
self.addCleanup(self.client.close)
|
|
cfg.CONF.set_override('deployment_id', 'did', group='kolla')
|
|
|
|
def test_jvars_dict(self):
|
|
jvars = service.JvarsDict(non_global1='old_value',
|
|
non_global2='old_value')
|
|
jvars.set_global_vars({'global1': 'old_value',
|
|
'global2': 'old_value'})
|
|
|
|
jvars.update({'global1': 'new_value',
|
|
'global2': 'new_value',
|
|
'non_global1': 'new_value',
|
|
'non_global2': 'new_value'})
|
|
self.assertDictEqual({'global1': 'old_value',
|
|
'global2': 'old_value',
|
|
'non_global1': 'new_value',
|
|
'non_global2': 'new_value'}, jvars)
|
|
|
|
jvars['global1'] = 'newer_value'
|
|
jvars['global2'] = 'newer_value'
|
|
jvars['non_global1'] = 'newer_value'
|
|
jvars['non_global2'] = 'newer_value'
|
|
self.assertDictEqual({'global1': 'old_value',
|
|
'global2': 'old_value',
|
|
'non_global1': 'newer_value',
|
|
'non_global2': 'newer_value'}, jvars)
|
|
|
|
jvars.set_force('global1', 'force_override')
|
|
jvars.update({'global2': 'force_override'}, force=True)
|
|
self.assertDictEqual({'global1': 'force_override',
|
|
'global2': 'force_override',
|
|
'non_global1': 'newer_value',
|
|
'non_global2': 'newer_value'}, jvars)
|
|
|
|
@mock.patch.object(service.config, 'get_marathon_framework')
|
|
@mock.patch.object(service.config, 'apply_deployment_vars')
|
|
@mock.patch.object(service.MarathonApp, 'run')
|
|
def test_run_marathon(self, m_run, m_apply, m_gmf):
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.run_service('openstack/keystone/keystone-api',
|
|
self.service_dir)
|
|
m_run.assert_called_once_with()
|
|
|
|
# assert that we have the basics in zk
|
|
exp_nodes = ['/kolla/common/kolla_mesos_start.py',
|
|
'/kolla/did/variables/keystone_admin_port',
|
|
'/kolla/did/openstack/keystone/keystone-api']
|
|
for node in exp_nodes:
|
|
self.assertTrue(self.client.exists(node), node)
|
|
|
|
@mock.patch.object(service.config, 'get_marathon_framework')
|
|
@mock.patch.object(service.config, 'apply_deployment_vars')
|
|
@mock.patch.object(service.ChronosTask, 'run')
|
|
def test_run_chronos(self, m_run, m_apply, m_gmf):
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.run_service('openstack/keystone/keystone-init',
|
|
self.service_dir)
|
|
m_run.assert_called_once_with()
|
|
|
|
# assert that we have the basics in zk
|
|
exp_nodes = ['/kolla/common/kolla_mesos_start.py',
|
|
'/kolla/did/variables/keystone_admin_port',
|
|
'/kolla/did/openstack/keystone/keystone_ansible_tasks']
|
|
for node in exp_nodes:
|
|
self.assertTrue(self.client.exists(node), node)
|
|
|
|
@mock.patch.object(service.MarathonApp, 'kill')
|
|
def test_kill(self, m_kill):
|
|
self.client.create('/kolla/did/openstack/nova/nova-api',
|
|
json.dumps({'name': 'openstack/nova/nova-api',
|
|
'service': {}}).encode('utf-8'),
|
|
makepath=True)
|
|
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.kill_service('openstack/nova/nova-api')
|
|
m_kill.assert_called_once_with(self.client)
|
|
|
|
@mock.patch.object(service.ChronosTask, 'get_state')
|
|
@mock.patch.object(service.MarathonApp, 'get_state')
|
|
def test_get_marathon(self, m_get_state, c_get_state):
|
|
self.client.create('/kolla/did/openstack/nova/nova-api',
|
|
json.dumps({'name': 'openstack/nova/nova-api',
|
|
'service': {}}).encode('utf-8'),
|
|
makepath=True)
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.get_service('openstack/nova/nova-api')
|
|
self.assertEqual([], c_get_state.mock_calls)
|
|
m_get_state.assert_called_once_with(None)
|
|
|
|
@mock.patch.object(service.ChronosTask, 'get_state')
|
|
@mock.patch.object(service.MarathonApp, 'get_state')
|
|
def test_get_chronos(self, m_get_state, c_get_state):
|
|
self.client.create('/kolla/did/openstack/nova/nova_init',
|
|
json.dumps({'name': 'openstack/nova/nova_init',
|
|
'task': {}}).encode('utf-8'),
|
|
makepath=True)
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.get_service('openstack-nova-nova_init')
|
|
self.assertEqual([], m_get_state.mock_calls)
|
|
c_get_state.assert_called_once_with(None)
|
|
|
|
@mock.patch.object(service.MarathonApp, 'scale')
|
|
def test_scale_marathon(self, m_scale):
|
|
self.client.create('/kolla/did/openstack/nova/nova-api',
|
|
json.dumps({'name': 'openstack/nova/nova-api',
|
|
'service': {}}).encode('utf-8'),
|
|
makepath=True)
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.scale_service('openstack/nova/nova-api', 2, force=False)
|
|
m_scale.assert_called_once_with(2, False)
|
|
|
|
@mock.patch.object(service.config, 'get_marathon_framework')
|
|
@mock.patch.object(service.config, 'apply_deployment_vars')
|
|
@mock.patch.object(service.MarathonApp, 'update')
|
|
def test_update_marathon(self, m_update, m_apply, m_gmf):
|
|
self.client.create('/kolla/did/openstack/nova/nova-api',
|
|
json.dumps({'name': 'openstack/nova/nova-api',
|
|
'service': {}}).encode('utf-8'),
|
|
makepath=True)
|
|
with mock.patch.object(service.zk_utils,
|
|
'connection') as m_zk_c:
|
|
m_zk_c.return_value.__enter__.return_value = self.client
|
|
service.update_service('openstack/nova/nova-api', self.service_dir)
|
|
m_update.assert_called_once_with()
|
|
|
|
@mock.patch.object(service.ChronosTask, 'list_all')
|
|
@mock.patch.object(service.MarathonApp, 'list_all')
|
|
def test_list(self, m_list, c_list):
|
|
service.list_services()
|
|
c_list.assert_called_once_with()
|
|
m_list.assert_called_once_with()
|