1512 lines
57 KiB
Python
1512 lines
57 KiB
Python
# Copyright (c) 2017 StackHPC Ltd.
|
|
#
|
|
# 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 unittest
|
|
|
|
import cliff.app
|
|
import cliff.commandmanager
|
|
import mock
|
|
|
|
from kayobe import ansible
|
|
from kayobe.cli import commands
|
|
from kayobe import utils
|
|
|
|
|
|
class TestApp(cliff.app.App):
|
|
|
|
def __init__(self):
|
|
super(TestApp, self).__init__(
|
|
description='Test app',
|
|
version='0.1',
|
|
command_manager=cliff.commandmanager.CommandManager('kayobe.cli'))
|
|
|
|
|
|
class TestCase(unittest.TestCase):
|
|
|
|
@mock.patch.object(ansible, "install_galaxy_roles", autospec=True)
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_control_host_bootstrap(self, mock_run, mock_install):
|
|
command = commands.ControlHostBootstrap(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
mock_install.assert_called_once_with(parsed_args)
|
|
expected_calls = [
|
|
mock.call(mock.ANY, [utils.get_data_files_path(
|
|
"ansible", "bootstrap.yml")]),
|
|
mock.call(mock.ANY, [
|
|
utils.get_data_files_path("ansible", "kolla-ansible.yml")
|
|
], tags="install"),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(ansible, "install_galaxy_roles", autospec=True)
|
|
@mock.patch.object(ansible, "prune_galaxy_roles", autospec=True)
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_control_host_upgrade(self, mock_run, mock_prune, mock_install):
|
|
command = commands.ControlHostUpgrade(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
mock_install.assert_called_once_with(parsed_args, force=True)
|
|
mock_prune.assert_called_once_with(parsed_args)
|
|
expected_calls = [
|
|
mock.call(mock.ANY, [utils.get_data_files_path(
|
|
"ansible", "bootstrap.yml")]),
|
|
mock.call(mock.ANY, [
|
|
utils.get_data_files_path("ansible", "kolla-ansible.yml")
|
|
], tags="install"),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_physical_network_configure(self, mock_run):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--group", "switches"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "physical-network.yml"),
|
|
limit="switches",
|
|
extra_vars={
|
|
"physical_network_display": False
|
|
}
|
|
)
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_physical_network_configure_display(self, mock_run):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--group", "switches", "--display"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "physical-network.yml"),
|
|
limit="switches",
|
|
extra_vars={
|
|
"physical_network_display": True
|
|
}
|
|
)
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_physical_network_configure_enable_disco(self, mock_run):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(
|
|
["--group", "switches", "--enable-discovery"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "physical-network.yml"),
|
|
limit="switches",
|
|
extra_vars={
|
|
"physical_network_display": False,
|
|
"physical_network_enable_discovery": True
|
|
}
|
|
)
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_physical_network_configure_disable_disco(self, mock_run):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(
|
|
["--group", "switches", "--disable-discovery"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "physical-network.yml"),
|
|
limit="switches",
|
|
extra_vars={
|
|
"physical_network_display": False,
|
|
"physical_network_disable_discovery": True
|
|
}
|
|
)
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
def test_physical_network_configure_enable_disable_disco(self):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
self.assertRaises(
|
|
SystemExit,
|
|
parser.parse_args,
|
|
["--group", "switches", "--enable-discovery",
|
|
"--disable-discovery"])
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_physical_network_configure_interface_limit(self, mock_run):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(
|
|
["--group", "switches", "--interface-limit", "eth0,eth1"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "physical-network.yml"),
|
|
limit="switches",
|
|
extra_vars={
|
|
"physical_network_display": False,
|
|
"physical_network_interface_limit": "eth0,eth1"
|
|
}
|
|
)
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_physical_network_configure_interface_description_limit(
|
|
self, mock_run):
|
|
command = commands.PhysicalNetworkConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(
|
|
["--group", "switches",
|
|
"--interface-description-limit", "host1,host2"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "physical-network.yml"),
|
|
limit="switches",
|
|
extra_vars={
|
|
"physical_network_display": False,
|
|
"physical_network_interface_description_limit": (
|
|
"host1,host2")
|
|
}
|
|
)
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_network_connectivity_check(self, mock_run):
|
|
command = commands.NetworkConnectivityCheck(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", "network-connectivity.yml")]),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_hypervisor_host_configure(self, mock_run, mock_dump):
|
|
command = commands.SeedHypervisorHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = "stack"
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(mock.ANY, host="seed-hypervisor",
|
|
var_name="kayobe_ansible_user", tags="dump-config")
|
|
]
|
|
self.assertEqual(expected_calls, mock_dump.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "ip-allocation.yml"),
|
|
utils.get_data_files_path("ansible", "ssh-known-host.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kayobe-ansible-user.yml"),
|
|
utils.get_data_files_path("ansible", "pip.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kayobe-target-venv.yml"),
|
|
utils.get_data_files_path("ansible", "users.yml"),
|
|
utils.get_data_files_path("ansible", "yum.yml"),
|
|
utils.get_data_files_path("ansible", "dev-tools.yml"),
|
|
utils.get_data_files_path("ansible", "network.yml"),
|
|
utils.get_data_files_path("ansible", "sysctl.yml"),
|
|
utils.get_data_files_path("ansible", "ntp.yml"),
|
|
utils.get_data_files_path("ansible", "lvm.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "seed-hypervisor-libvirt-host.yml"),
|
|
],
|
|
limit="seed-hypervisor",
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_hypervisor_host_upgrade(self, mock_run):
|
|
command = commands.SeedHypervisorHostUpgrade(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", "kayobe-target-venv.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kolla-target-venv.yml"),
|
|
],
|
|
limit="seed-hypervisor",
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_seed")
|
|
def test_seed_host_configure(self, mock_kolla_run, mock_run, mock_dump):
|
|
command = commands.SeedHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"seed": {"kayobe_ansible_user": "stack"}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(mock.ANY, hosts="seed", tags="dump-config")
|
|
]
|
|
self.assertEqual(expected_calls, mock_dump.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "ip-allocation.yml"),
|
|
utils.get_data_files_path("ansible", "ssh-known-host.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kayobe-ansible-user.yml"),
|
|
utils.get_data_files_path("ansible", "pip.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kayobe-target-venv.yml"),
|
|
utils.get_data_files_path("ansible", "users.yml"),
|
|
utils.get_data_files_path("ansible", "yum.yml"),
|
|
utils.get_data_files_path("ansible", "dev-tools.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "disable-selinux.yml"),
|
|
utils.get_data_files_path("ansible", "network.yml"),
|
|
utils.get_data_files_path("ansible", "sysctl.yml"),
|
|
utils.get_data_files_path("ansible", "ip-routing.yml"),
|
|
utils.get_data_files_path("ansible", "snat.yml"),
|
|
utils.get_data_files_path("ansible", "disable-glean.yml"),
|
|
utils.get_data_files_path("ansible", "ntp.yml"),
|
|
utils.get_data_files_path("ansible", "lvm.yml"),
|
|
],
|
|
limit="seed",
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[utils.get_data_files_path("ansible", "kolla-ansible.yml")],
|
|
tags="config",
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "pip.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kolla-target-venv.yml"),
|
|
utils.get_data_files_path("ansible", "kolla-host.yml"),
|
|
utils.get_data_files_path("ansible", "docker.yml"),
|
|
],
|
|
limit="seed",
|
|
extra_vars={'pip_applicable_users': [None]},
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible",
|
|
"docker-registry.yml"),
|
|
],
|
|
limit="seed",
|
|
extra_vars={'kayobe_action': 'deploy'},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={"ansible_user": "stack"},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_seed")
|
|
def test_seed_host_configure_kayobe_venv(self, mock_kolla_run, mock_run,
|
|
mock_dump):
|
|
command = commands.SeedHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"seed": {
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"kayobe_ansible_user": "stack",
|
|
}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"ansible_user": "stack",
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_seed")
|
|
def test_seed_host_configure_kolla_venv(self, mock_kolla_run, mock_run,
|
|
mock_dump):
|
|
command = commands.SeedHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"seed": {
|
|
"kayobe_ansible_user": "stack",
|
|
"kolla_ansible_target_venv": "/kolla/venv/bin/python",
|
|
}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={
|
|
"ansible_python_interpreter": "/usr/bin/python",
|
|
"ansible_user": "stack",
|
|
"virtualenv": "/kolla/venv/bin/python",
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_seed")
|
|
def test_seed_host_configure_both_venvs(self, mock_kolla_run, mock_run,
|
|
mock_dump):
|
|
command = commands.SeedHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"seed": {
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"kayobe_ansible_user": "stack",
|
|
"kolla_ansible_target_venv": "/kolla/venv/bin/python",
|
|
}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"ansible_user": "stack",
|
|
"virtualenv": "/kolla/venv/bin/python",
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_host_package_update_all(self, mock_run):
|
|
command = commands.SeedHostPackageUpdate(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--packages", "*"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "host-package-update.yml"),
|
|
],
|
|
limit="seed",
|
|
extra_vars={
|
|
"host_package_update_packages": "*",
|
|
"host_package_update_security": False,
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_host_package_update_list(self, mock_run):
|
|
command = commands.SeedHostPackageUpdate(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--packages", "p1,p2"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "host-package-update.yml"),
|
|
],
|
|
limit="seed",
|
|
extra_vars={
|
|
"host_package_update_packages": "p1,p2",
|
|
"host_package_update_security": False,
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_host_package_update_security(self, mock_run):
|
|
command = commands.SeedHostPackageUpdate(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--packages", "*", "--security"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "host-package-update.yml"),
|
|
],
|
|
limit="seed",
|
|
extra_vars={
|
|
"host_package_update_packages": "*",
|
|
"host_package_update_security": True,
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_host_upgrade(self, mock_run):
|
|
command = commands.SeedHostUpgrade(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", "kayobe-target-venv.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kolla-target-venv.yml"),
|
|
],
|
|
limit="seed",
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_container_image_build(self, mock_run):
|
|
command = commands.SeedContainerImageBuild(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", "container-image-builders-check.yml"),
|
|
utils.get_data_files_path("ansible", "kolla-build.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "container-image-build.yml")
|
|
],
|
|
extra_vars={
|
|
"container_image_sets": (
|
|
"{{ seed_container_image_sets }}"),
|
|
"push_images": False,
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_container_image_build_with_regex(self, mock_run):
|
|
command = commands.SeedContainerImageBuild(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--push", "^regex1$", "^regex2$"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "container-image-builders-check.yml"),
|
|
utils.get_data_files_path("ansible", "kolla-build.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "container-image-build.yml")
|
|
],
|
|
extra_vars={
|
|
"container_image_regexes": "'^regex1$ ^regex2$'",
|
|
"push_images": True,
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_deployment_image_build(self, mock_run):
|
|
command = commands.SeedDeploymentImageBuild(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", "seed-ipa-build.yml"),
|
|
],
|
|
extra_vars={},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_seed_deployment_image_build_force_rebuild(self, mock_run):
|
|
command = commands.SeedDeploymentImageBuild(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--force-rebuild"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "seed-ipa-build.yml"),
|
|
],
|
|
extra_vars={"ipa_image_force_rebuild": True},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_seed")
|
|
def test_seed_service_deploy(self, mock_kolla_run, mock_run):
|
|
command = commands.SeedServiceDeploy(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")],
|
|
tags="config",
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[utils.get_data_files_path("ansible", "kolla-bifrost.yml")],
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-host-image-workaround-resolv.yml"), # noqa
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-host-image-workaround-cloud-init.yml"), # noqa
|
|
utils.get_data_files_path(
|
|
"ansible", "seed-introspection-rules.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "dell-switch-bmp.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"deploy-bifrost",
|
|
),
|
|
]
|
|
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_seed")
|
|
def test_seed_service_upgrade(self, mock_kolla_run, mock_run):
|
|
command = commands.SeedServiceUpgrade(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")],
|
|
tags="config",
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "kolla-bifrost.yml"),
|
|
utils.get_data_files_path("ansible",
|
|
"seed-service-upgrade-prep.yml")
|
|
],
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible",
|
|
"overcloud-host-image-workaround-resolv.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible",
|
|
"overcloud-host-image-workaround-cloud-init.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible",
|
|
"seed-introspection-rules.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible",
|
|
"dell-switch-bmp.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"deploy-bifrost",
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbook")
|
|
def test_overcloud_inventory_discover(self, mock_run):
|
|
command = commands.OvercloudInventoryDiscover(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", "overcloud-inventory-discover.yml"),
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "ip-allocation.yml"),
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
utils.get_data_files_path("ansible", "kolla-ansible.yml"),
|
|
tags="config",
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_hardware_inspect(self, mock_run):
|
|
command = commands.OvercloudHardwareInspect(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-bifrost-hostvars.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-hardware-inspect.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_provision(self, mock_run):
|
|
command = commands.OvercloudProvision(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-bifrost-hostvars.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-provision.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_deprovision(self, mock_run):
|
|
command = commands.OvercloudDeprovision(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", "overcloud-deprovision.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_overcloud")
|
|
def test_overcloud_host_configure(self, mock_kolla_run, mock_run,
|
|
mock_dump):
|
|
command = commands.OvercloudHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"controller0": {"kayobe_ansible_user": "stack"}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(mock.ANY, hosts="overcloud", tags="dump-config")
|
|
]
|
|
self.assertEqual(expected_calls, mock_dump.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "ip-allocation.yml"),
|
|
utils.get_data_files_path("ansible", "ssh-known-host.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kayobe-ansible-user.yml"),
|
|
utils.get_data_files_path("ansible", "pip.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kayobe-target-venv.yml"),
|
|
utils.get_data_files_path("ansible", "users.yml"),
|
|
utils.get_data_files_path("ansible", "yum.yml"),
|
|
utils.get_data_files_path("ansible", "dev-tools.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "disable-selinux.yml"),
|
|
utils.get_data_files_path("ansible", "network.yml"),
|
|
utils.get_data_files_path("ansible", "sysctl.yml"),
|
|
utils.get_data_files_path("ansible", "disable-glean.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "disable-cloud-init.yml"),
|
|
utils.get_data_files_path("ansible", "ntp.yml"),
|
|
utils.get_data_files_path("ansible", "lvm.yml"),
|
|
],
|
|
limit="overcloud",
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[utils.get_data_files_path("ansible", "kolla-ansible.yml")],
|
|
tags="config",
|
|
),
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path("ansible", "pip.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kolla-target-venv.yml"),
|
|
utils.get_data_files_path("ansible", "kolla-host.yml"),
|
|
utils.get_data_files_path("ansible", "docker.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "ceph-block-devices.yml"),
|
|
],
|
|
limit="overcloud",
|
|
extra_vars={"pip_applicable_users": [None]},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={"ansible_user": "stack"},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_overcloud")
|
|
def test_overcloud_host_configure_kayobe_venv(self, mock_kolla_run,
|
|
mock_run, mock_dump):
|
|
command = commands.OvercloudHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"controller0": {
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"kayobe_ansible_user": "stack",
|
|
}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"ansible_user": "stack",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_overcloud")
|
|
def test_overcloud_host_configure_kolla_venv(self, mock_kolla_run,
|
|
mock_run, mock_dump):
|
|
command = commands.OvercloudHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"controller0": {
|
|
"kayobe_ansible_user": "stack",
|
|
"kolla_ansible_target_venv": "/kolla/venv/bin/python",
|
|
}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={
|
|
"ansible_python_interpreter": "/usr/bin/python",
|
|
"ansible_user": "stack",
|
|
"virtualenv": "/kolla/venv/bin/python",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_config_dump")
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
@mock.patch.object(commands.KollaAnsibleMixin,
|
|
"run_kolla_ansible_overcloud")
|
|
def test_overcloud_host_configure_both_venvs(self, mock_kolla_run,
|
|
mock_run, mock_dump):
|
|
command = commands.OvercloudHostConfigure(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args([])
|
|
mock_dump.return_value = {
|
|
"controller0": {
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"kayobe_ansible_user": "stack",
|
|
"kolla_ansible_target_venv": "/kolla/venv/bin/python",
|
|
}
|
|
}
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
"bootstrap-servers",
|
|
extra_vars={
|
|
"ansible_python_interpreter": "/kayobe/venv/bin/python",
|
|
"ansible_user": "stack",
|
|
"virtualenv": "/kolla/venv/bin/python",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_kolla_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_host_package_update_all(self, mock_run):
|
|
command = commands.OvercloudHostPackageUpdate(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--packages", "*"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "host-package-update.yml"),
|
|
],
|
|
limit="overcloud",
|
|
extra_vars={
|
|
"host_package_update_packages": "*",
|
|
"host_package_update_security": False,
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_host_package_update_list(self, mock_run):
|
|
command = commands.OvercloudHostPackageUpdate(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--packages", "p1,p2"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "host-package-update.yml"),
|
|
],
|
|
limit="overcloud",
|
|
extra_vars={
|
|
"host_package_update_packages": "p1,p2",
|
|
"host_package_update_security": False,
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_host_package_update_security(self, mock_run):
|
|
command = commands.OvercloudHostPackageUpdate(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--packages", "*", "--security"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "host-package-update.yml"),
|
|
],
|
|
limit="overcloud",
|
|
extra_vars={
|
|
"host_package_update_packages": "*",
|
|
"host_package_update_security": True,
|
|
},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_host_upgrade(self, mock_run):
|
|
command = commands.OvercloudHostUpgrade(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", "kayobe-target-venv.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "kolla-target-venv.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-docker-sdk-upgrade.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-etc-hosts-fixup.yml"),
|
|
],
|
|
limit="overcloud",
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_container_image_build(self, mock_run):
|
|
command = commands.OvercloudContainerImageBuild(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", "container-image-builders-check.yml"),
|
|
utils.get_data_files_path("ansible", "kolla-build.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "container-image-build.yml")
|
|
],
|
|
extra_vars={
|
|
"container_image_sets": (
|
|
"{{ overcloud_container_image_sets }}"),
|
|
"push_images": False,
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_container_image_build_with_regex(self, mock_run):
|
|
command = commands.OvercloudContainerImageBuild(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--push", "^regex1$", "^regex2$"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "container-image-builders-check.yml"),
|
|
utils.get_data_files_path("ansible", "kolla-build.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "container-image-build.yml")
|
|
],
|
|
extra_vars={
|
|
"container_image_regexes": "'^regex1$ ^regex2$'",
|
|
"push_images": True,
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_deployment_image_build(self, mock_run):
|
|
command = commands.OvercloudDeploymentImageBuild(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", "overcloud-ipa-build.yml"),
|
|
],
|
|
extra_vars={},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_deployment_image_build_force_rebuild(self, mock_run):
|
|
command = commands.OvercloudDeploymentImageBuild(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--force-rebuild"])
|
|
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-ipa-build.yml"),
|
|
],
|
|
extra_vars={"ipa_image_force_rebuild": True},
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_overcloud_post_configure(self, mock_run):
|
|
command = commands.OvercloudPostConfigure(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", "overcloud-ipa-images.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-introspection-rules.yml"),
|
|
utils.get_data_files_path("ansible", "overcloud-introspection-rules-dell-lldp-workaround.yml"), # noqa
|
|
utils.get_data_files_path("ansible", "provision-net.yml"),
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-grafana-configure.yml")
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_inspect(self, mock_run):
|
|
command = commands.BaremetalComputeInspect(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", "baremetal-compute-inspect.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_manage(self, mock_run):
|
|
command = commands.BaremetalComputeManage(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", "baremetal-compute-manage.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_provide(self, mock_run):
|
|
command = commands.BaremetalComputeProvide(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", "baremetal-compute-provide.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_rename(self, mock_run):
|
|
command = commands.BaremetalComputeRename(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", "baremetal-compute-rename.yml"),
|
|
],
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_serial_console_enable(self, mock_run):
|
|
command = commands.BaremetalComputeSerialConsoleEnable(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", "baremetal-compute-serial-console.yml"),
|
|
|
|
],
|
|
extra_vars={
|
|
"cmd": "enable",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_serial_console_enable_with_limit(self,
|
|
mock_run):
|
|
command = commands.BaremetalComputeSerialConsoleEnable(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--baremetal-compute-limit",
|
|
"sand-6-1"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "baremetal-compute-serial-console.yml"),
|
|
|
|
],
|
|
extra_vars={
|
|
"cmd": "enable",
|
|
"console_compute_node_limit": "sand-6-1",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_serial_console_disable(self, mock_run):
|
|
command = commands.BaremetalComputeSerialConsoleDisable(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", "baremetal-compute-serial-console.yml"),
|
|
|
|
],
|
|
extra_vars={
|
|
"cmd": "disable",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_serial_console_disable_with_limit(self,
|
|
mock_run):
|
|
command = commands.BaremetalComputeSerialConsoleDisable(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--baremetal-compute-limit",
|
|
"sand-6-1"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "baremetal-compute-serial-console.yml"),
|
|
|
|
],
|
|
extra_vars={
|
|
"cmd": "disable",
|
|
"console_compute_node_limit": "sand-6-1",
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_update_deployment_image(self, mock_run):
|
|
command = commands.BaremetalComputeUpdateDeploymentImage(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", "overcloud-ipa-images.yml"),
|
|
],
|
|
extra_vars={
|
|
"ipa_images_update_ironic_nodes": True,
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|
|
|
|
@mock.patch.object(commands.KayobeAnsibleMixin,
|
|
"run_kayobe_playbooks")
|
|
def test_baremetal_compute_update_deployment_image_with_limit(
|
|
self, mock_run):
|
|
command = commands.BaremetalComputeUpdateDeploymentImage(TestApp(), [])
|
|
parser = command.get_parser("test")
|
|
parsed_args = parser.parse_args(["--baremetal-compute-limit",
|
|
"sand-6-1"])
|
|
result = command.run(parsed_args)
|
|
self.assertEqual(0, result)
|
|
expected_calls = [
|
|
mock.call(
|
|
mock.ANY,
|
|
[
|
|
utils.get_data_files_path(
|
|
"ansible", "overcloud-ipa-images.yml"),
|
|
],
|
|
extra_vars={
|
|
"ipa_images_compute_node_limit": "sand-6-1",
|
|
"ipa_images_update_ironic_nodes": True,
|
|
}
|
|
),
|
|
]
|
|
self.assertEqual(expected_calls, mock_run.call_args_list)
|