Add kayobe overcloud service prechecks command
Runs 'kolla-ansible prechecks' without deploying services. Change-Id: I3806b707593fc6ac9d7125e1b12d716ad40a2808 Story: 2008912 Task: 42503
This commit is contained in:
parent
211c68aa6c
commit
b398e28dc5
@ -130,6 +130,18 @@ and/or kolla-ansible::
|
|||||||
|
|
||||||
(kayobe) $ kayobe overcloud service upgrade --tags config --kolla-tags keystone
|
(kayobe) $ kayobe overcloud service upgrade --tags config --kolla-tags keystone
|
||||||
|
|
||||||
|
Running Prechecks
|
||||||
|
=================
|
||||||
|
|
||||||
|
Sometimes it may be useful to run prechecks without deploying services::
|
||||||
|
|
||||||
|
(kayobe) $ kayobe overcloud service prechecks
|
||||||
|
|
||||||
|
As for other similar commands, it is possible to specify tags for Kayobe and/or
|
||||||
|
kolla-ansible::
|
||||||
|
|
||||||
|
(kayobe) $ kayobe overcloud service upgrade --tags config --kolla-tags keystone
|
||||||
|
|
||||||
Stopping the Overcloud Services
|
Stopping the Overcloud Services
|
||||||
===============================
|
===============================
|
||||||
|
|
||||||
|
@ -1283,6 +1283,29 @@ class OvercloudServiceDeployContainers(KollaAnsibleMixin, KayobeAnsibleMixin,
|
|||||||
extra_vars=extra_vars, limit="overcloud")
|
extra_vars=extra_vars, limit="overcloud")
|
||||||
|
|
||||||
|
|
||||||
|
class OvercloudServicePrechecks(KollaAnsibleMixin, KayobeAnsibleMixin,
|
||||||
|
VaultMixin, Command):
|
||||||
|
"""Run prechecks against overcloud services.
|
||||||
|
|
||||||
|
* Configure kolla-ansible.
|
||||||
|
* Configure overcloud services in kolla-ansible.
|
||||||
|
* Perform kolla-ansible prechecks to verify the system state for
|
||||||
|
deployment.
|
||||||
|
|
||||||
|
This can be used in conjunction with the --tags and --kolla-tags arguments
|
||||||
|
to check specific services.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
self.app.LOG.debug("Running overcloud prechecks")
|
||||||
|
|
||||||
|
# First prepare configuration.
|
||||||
|
self.generate_kolla_ansible_config(parsed_args)
|
||||||
|
|
||||||
|
# Run the kolla-ansible prechecks.
|
||||||
|
self.run_kolla_ansible_overcloud(parsed_args, "prechecks")
|
||||||
|
|
||||||
|
|
||||||
class OvercloudServiceReconfigure(KollaAnsibleMixin, KayobeAnsibleMixin,
|
class OvercloudServiceReconfigure(KollaAnsibleMixin, KayobeAnsibleMixin,
|
||||||
VaultMixin, Command):
|
VaultMixin, Command):
|
||||||
"""Reconfigure the overcloud services.
|
"""Reconfigure the overcloud services.
|
||||||
|
@ -1426,6 +1426,44 @@ class TestCase(unittest.TestCase):
|
|||||||
]
|
]
|
||||||
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
||||||
|
|
||||||
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
||||||
|
"run_kayobe_playbooks")
|
||||||
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
||||||
|
"run_kolla_ansible_overcloud")
|
||||||
|
def test_overcloud_service_prechecks(self, mock_kolla_run, mock_run):
|
||||||
|
command = commands.OvercloudServicePrechecks(TestApp(), [])
|
||||||
|
parser = command.get_parser("test")
|
||||||
|
parsed_args = parser.parse_args([])
|
||||||
|
|
||||||
|
result = command.run(parsed_args)
|
||||||
|
self.assertEqual(0, result)
|
||||||
|
|
||||||
|
expected_calls = [
|
||||||
|
mock.call(
|
||||||
|
mock.ANY,
|
||||||
|
[utils.get_data_files_path("ansible", "kolla-ansible.yml")],
|
||||||
|
ignore_limit=True,
|
||||||
|
tags="config",
|
||||||
|
),
|
||||||
|
mock.call(
|
||||||
|
mock.ANY,
|
||||||
|
[
|
||||||
|
utils.get_data_files_path("ansible",
|
||||||
|
"kolla-openstack.yml"),
|
||||||
|
],
|
||||||
|
ignore_limit=True,
|
||||||
|
),
|
||||||
|
]
|
||||||
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
||||||
|
|
||||||
|
expected_calls = [
|
||||||
|
mock.call(
|
||||||
|
mock.ANY,
|
||||||
|
"prechecks",
|
||||||
|
),
|
||||||
|
]
|
||||||
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
||||||
|
|
||||||
@mock.patch.object(commands.KayobeAnsibleMixin,
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
||||||
"run_kayobe_playbooks")
|
"run_kayobe_playbooks")
|
||||||
@mock.patch.object(commands.KollaAnsibleMixin,
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
||||||
|
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- |
|
||||||
|
Adds a new ``kayobe overcloud service prechecks`` command to run Kolla
|
||||||
|
Ansible prechecks without deploying services.
|
@ -72,6 +72,7 @@ kayobe.cli=
|
|||||||
overcloud_service_deploy = kayobe.cli.commands:OvercloudServiceDeploy
|
overcloud_service_deploy = kayobe.cli.commands:OvercloudServiceDeploy
|
||||||
overcloud_service_deploy_containers = kayobe.cli.commands:OvercloudServiceDeployContainers
|
overcloud_service_deploy_containers = kayobe.cli.commands:OvercloudServiceDeployContainers
|
||||||
overcloud_service_destroy = kayobe.cli.commands:OvercloudServiceDestroy
|
overcloud_service_destroy = kayobe.cli.commands:OvercloudServiceDestroy
|
||||||
|
overcloud_service_prechecks = kayobe.cli.commands:OvercloudServicePrechecks
|
||||||
overcloud_service_reconfigure = kayobe.cli.commands:OvercloudServiceReconfigure
|
overcloud_service_reconfigure = kayobe.cli.commands:OvercloudServiceReconfigure
|
||||||
overcloud_service_stop = kayobe.cli.commands:OvercloudServiceStop
|
overcloud_service_stop = kayobe.cli.commands:OvercloudServiceStop
|
||||||
overcloud_service_upgrade = kayobe.cli.commands:OvercloudServiceUpgrade
|
overcloud_service_upgrade = kayobe.cli.commands:OvercloudServiceUpgrade
|
||||||
@ -159,6 +160,8 @@ kayobe.cli.overcloud_service_deploy_containers =
|
|||||||
hooks = kayobe.cli.commands:HookDispatcher
|
hooks = kayobe.cli.commands:HookDispatcher
|
||||||
kayobe.cli.overcloud_service_destroy =
|
kayobe.cli.overcloud_service_destroy =
|
||||||
hooks = kayobe.cli.commands:HookDispatcher
|
hooks = kayobe.cli.commands:HookDispatcher
|
||||||
|
kayobe.cli.overcloud_service_prechecks =
|
||||||
|
hooks = kayobe.cli.commands:HookDispatcher
|
||||||
kayobe.cli.overcloud_service_reconfigure =
|
kayobe.cli.overcloud_service_reconfigure =
|
||||||
hooks = kayobe.cli.commands:HookDispatcher
|
hooks = kayobe.cli.commands:HookDispatcher
|
||||||
kayobe.cli.overcloud_service_stop =
|
kayobe.cli.overcloud_service_stop =
|
||||||
|
Loading…
Reference in New Issue
Block a user