blob: 05a8deb4ad489b778e67e8970ee1f974e9f737e1 [file] [log] [blame]
# Copyright 2017 Mirantis, Inc.
#
# 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 pytest
import time
from collections import Counter
from tcp_tests import logger
from tcp_tests.managers.jenkins.client import JenkinsClient
from tcp_tests import settings
from tcp_tests import managers
LOG = logger.logger
class TestOfflineDeployment(object):
"""docstring for TestOfflineDeployment"""
@pytest.mark.day1_underlay
def test_maas_provision(self, show_step, hardware, underlay,
day1_cfg_config):
"""Test for deploying an mcp dvr environment and check it
Scenario:
1. Prepare salt on hosts
2. Setup controller nodes
3. Setup compute nodes
"""
show_step(1)
show_step(2)
show_step(3)
cfg_node = 'cfg01.virtual-mcp-pike-dvr.local'
ssh_test_key = day1_cfg_config.config.underlay.ssh_keys[0]['public']
verbose = True
cfg_admin_iface = next(i for i in hardware.master_nodes[0].interfaces
if i.network.name == 'admin')
admin_net = cfg_admin_iface.network.address_pool.ip_network
underlay.check_call(
node_name=cfg_node, verbose=verbose,
cmd='maas logout mirantis && '
'maas login mirantis '
'http://localhost:5240/MAAS/api/2.0/ '
'FTvqwe7ybBp68gPar2:5mcctTAXVL8mns4ef4:zrA9LZwu2tMc8BAZpsPUfwWwTyQnAtDN') # noqa
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="maas mirantis package-repository update main_archive "
"disabled_pockets=backports,security")
underlay.check_call(
node_name=cfg_node, verbose=verbose,
cmd="maas mirantis ipranges create "
"type=dynamic start_ip={start} end_ip={end} "
"subnet=$(maas mirantis subnets read | jq '.[] | select(.name==\"{net}\") | .id')".format( # noqa
start=admin_net[191],
end=admin_net[253],
net=admin_net))
underlay.check_call(node_name=cfg_node, verbose=verbose,
cmd="maas mirantis vlan update "
"$(maas mirantis subnets read | jq '.[] | select(.name==\"{net}\") | .vlan.fabric_id') " # noqa
"0 dhcp_on=True primary_rack='cfg01'".format(net=admin_net))
underlay.check_call(
node_name=cfg_node, verbose=verbose,
cmd="ssh-keygen -y -f ~root/.ssh/id_rsa > ~root/.ssh/id_rsa.pub")
underlay.check_call(
node_name=cfg_node, verbose=verbose,
cmd='maas mirantis sshkeys create '
'key="$(cat ~root/.ssh/id_rsa.pub)"')
r, f = day1_cfg_config.salt.enforce_state('cfg01*', 'maas.machines')
LOG.info(r)
LOG.info(f)
# show_step(8)
# nodes_amount = len(hardware.slave_nodes)
# cmd = """ timeout 600s bash -c 'hosts=$(maas mirantis nodes read | jq -r ".[] | select(.node_type_name==\\"Machine\\") | select(.status_name==\\"Ready\\") | .hostname "); while ! [ $(echo "$hosts" | wc -w) -eq {amount} ]; do echo "Ready hosts:\n$hosts"; sleep 30; hosts=$(maas mirantis nodes read | jq -r ".[] | select(.node_type_name==\\"Machine\\") | select(.status_name==\\"Ready\\") | .hostname "); done ' """.format(amount=nodes_amount) # noqa
cmd = """salt-call state.sls maas.machines.wait_for_ready"""
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
underlay.check_call(node_name=cfg_node, verbose=verbose,
cmd='salt-key')
r, f = day1_cfg_config.salt.enforce_state(
'cfg01*',
'maas.machines.assign_ip')
LOG.info(r)
LOG.info(f)
# show_step(9)
underlay.check_call(
node_name=cfg_node, verbose=verbose,
cmd='salt-call state.sls maas.machines.deploy')
# show_step(10)
underlay.check_call(
node_name=cfg_node, verbose=verbose,
cmd='salt-call state.sls maas.machines.wait_for_deployed')
underlay.check_call(node_name=cfg_node, verbose=verbose,
cmd='salt-key')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key root '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key root '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key ubuntu '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key ubuntu '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
result = \
day1_cfg_config.salt.get_pillar(cfg_node,
'_param:jenkins_salt_api_url')
result = result[0].get(cfg_node)
jenkins = JenkinsClient(
host='http://{host}:8081'.format(
host=day1_cfg_config.config.salt.salt_master_host),
username='admin',
password='r00tme')
params = jenkins.make_defults_params('deploy_openstack')
params['SALT_MASTER_URL'] = result
params['STACK_INSTALL'] = "core,openstack,ovs"
build = jenkins.run_build('deploy_openstack', params)
jenkins.wait_end_of_build(
name=build[0],
build_id=build[1],
timeout=60 * 60 * 2)
assert \
jenkins.build_info(
name=build[0], build_id=build[1])['result'] == 'SUCCESS', \
"Deploy openstack was failed"
openstack = managers.openstack_manager.OpenstackManager(
day1_cfg_config.config, underlay, hardware,
day1_cfg_config.salt)
if settings.RUN_TEMPEST:
openstack.run_tempest(pattern=settings.PATTERN)
openstack.download_tempest_report()
LOG.info("*************** DONE **************")
def test_deploy_day1(self, show_step, config, underlay, hardware,
core_deployed, salt_deployed):
"""Test for deploying an mcp from day01 images
Scenario:
1. Wait salt master
2. Addition config of MaaS
3. Wait dhcpd server
4. Start comissioning node via MaaS
5. Wait of comissioning node by MaaS
6. Start deploing node via MaaS
7. Wait of deploing node by
8. Accept all keys
9. Configure and baremetal nodes after MaaS deployment
10. Run deploy OS job
"""
# group = hardware._get_default_node_group()
nodes = underlay.node_names()
LOG.info("Nodes - {}".format(nodes))
cfg_node = 'cfg01.offline-ocata-vxlan.local'
tempest_node = 'gtw01.offline-ocata-vxlan.local'
verbose = True
ssh_test_key = config.underlay.ssh_keys[0]['public']
show_step(1)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="""timeout 300s /bin/bash -c """
"""'while ! salt-call test.ping; do """
"""echo "salt master still isnt running"; sleep 10; done'"""
) # noqa
show_step(2)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt-call saltutil.sync_all')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key root '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key root '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key ubuntu '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key ubuntu '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
# underlay.check_call(
# node_name=cfg_node,
# verbose=verbose,
# cmd='salt-call state.sls maas.region')
# underlay.check_call(
# node_name=cfg_node,
# verbose=verbose,
# cmd='maas logout mirantis && '
# 'maas login mirantis '
# 'http://localhost:5240/MAAS/api/2.0/ '
# 'FTvqwe7ybBp68gPar2:5mcctTAXVL8mns4ef4:zrA9LZwu2tMc8BAZpsPUfwWwTyQnAtDN' # noqa
# )
# underlay.check_call(
# node_name=cfg_node,
# verbose=verbose,
# cmd="maas mirantis maas set-config "
# "name=upstream_dns value='10.10.0.15 8.8.8.8 8.8.4.4'")
# underlay.check_call(
# node_name=cfg_node,
# verbose=verbose,
# cmd="maas mirantis ipranges create "
# "type=dynamic start_ip=10.10.191.255 end_ip=10.10.255.254 "
# "subnet=$(maas mirantis subnets read | jq '.[] | "
# "select(.name==\"10.10.0.0/16\") | .id')")
# underlay.check_call(
# node_name=cfg_node,
# verbose=verbose,
# cmd="maas mirantis vlan update "
# "$(maas mirantis subnets read | jq '.[] | "
# "select(.name==\"10.10.0.0/16\") | .vlan.fabric_id') "
# "0 dhcp_on=True primary_rack='cfg01'")
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="ssh-keygen -y -f ~root/.ssh/id_rsa > ~root/.ssh/id_rsa.pub")
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='maas mirantis sshkeys create '
'key="$(cat ~root/.ssh/id_rsa.pub)"')
show_step(3)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="""timeout 90s /bin/bash -c 'while ! pidof dhcpd; do """
"""echo "dhcpd still isnt running"; sleep 10; done'""")
show_step(4)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt-call state.sls maas.machines')
show_step(5)
# cmd = """ timeout 1200s bash -c 'hosts=$(maas mirantis nodes read | jq -r ".[] | select(.node_type_name==\\"Machine\\") | select(.status_name==\\"Ready\\") | .hostname "); while ! [ $(echo "$hosts" | wc -w) -eq 10 ]; do echo "Ready hosts:\n$hosts"; sleep 30; hosts=$(maas mirantis nodes read | jq -r ".[] | select(.node_type_name==\\"Machine\\") | select(.status_name==\\"Ready\\") | .hostname "); done ' """ # noqa
cmd = """salt-call state.sls maas.machines.wait_for_ready"""
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
underlay.check_call(
node_name=cfg_node, verbose=verbose, cmd='salt-key')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt-call state.sls maas.machines.assign_ip')
show_step(6)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt-call state.sls maas.machines.deploy')
show_step(7)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt-call state.sls maas.machines.wait_for_deployed')
underlay.check_call(
node_name=cfg_node, verbose=verbose, cmd='salt-key')
show_step(8)
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
expected=[0, 1],
cmd='salt-key -A -y --include-denied --include-rejected')
underlay.check_call(
node_name=cfg_node, verbose=verbose, cmd='salt-key')
show_step(9)
cmd = "salt '*' saltutil.refresh_pillar"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
cmd = "salt '*' saltutil.sync_all"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
underlay.check_call(
node_name=cfg_node, verbose=verbose, cmd="reclass-salt --top")
cmd = "salt -C " \
"'I@salt:control or I@nova:compute or I@ceph:osd' " \
"cmd.run 'touch /run/is_rebooted'"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
cmd = "salt --async -C " \
"'I@salt:control' cmd.run 'salt-call state.sls " \
"linux.system.user,openssh,linux.network;reboot'"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
cmd = "salt --async -C " \
"'I@nova:compute' cmd.run 'salt-call state.sls " \
"linux.system.user,openssh,linux.network;reboot'"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
cmd = "salt --async -C " \
"'I@ceph:osd' cmd.run 'salt-call state.sls " \
"linux.system.user,openssh,linux.network;reboot'"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
time.sleep(360) # TODO: Add ssh waiter
cmd = "salt -C " \
"'I@salt:control or I@nova:compute or I@ceph:osd'" \
" test.ping"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
cmd = """salt -C """ \
"""'I@salt:control or I@nova:compute or I@ceph:osd' """ \
"""cmd.run '[ -f "/run/is_rebooted" ] && """ \
"""echo "Has not been rebooted!" || echo "Rebooted"' """
ret = underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
count = Counter(ret['stdout_str'].split())
assert count['Rebooted'] == 13, "Should be rebooted 13 baremetal nodes"
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key root '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key root '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key ubuntu '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key ubuntu '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
salt_api = \
salt_deployed.get_pillar(cfg_node, '_param:jenkins_salt_api_url')
salt_api = salt_api[0].get(cfg_node)
show_step(10)
jenkins = JenkinsClient(
host='http://172.16.44.33:8081',
username='admin',
password='r00tme')
params = jenkins.make_defults_params('deploy_openstack')
params['SALT_MASTER_URL'] = salt_api
params['STACK_INSTALL'] = \
'core,kvm,ceph,cicd,openstack,stacklight,finalize'
build = jenkins.run_build('deploy_openstack', params)
jenkins.wait_end_of_build(
name=build[0], build_id=build[1], timeout=60 * 60 * 4)
with open("{path}/cfg01_jenkins_deploy_openstack_console.log".format(
path=settings.LOGS_DIR), 'w') as f:
LOG.info("Save jenkins console log")
console_log = \
jenkins.get_build_output('deploy_openstack', build[1])
f.write(console_log)
assert \
jenkins.build_info(
name=build[0], build_id=build[1])['result'] == 'SUCCESS', \
"Deploy openstack was failed"
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key root '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key root '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd="salt '*' ssh.set_auth_key ubuntu '{}'".format(ssh_test_key))
underlay.check_call(
node_name=cfg_node,
verbose=verbose,
cmd='salt "*" ssh.set_auth_key ubuntu '
'"$(ssh-keygen -y -f ~/.ssh/id_rsa | cut -d " " -f 2)"')
salt_nodes = salt_deployed.get_ssh_data()
nodes_list = \
[node for node in salt_nodes
if not any(node['node_name'] == n['node_name']
for n in config.underlay.ssh)]
config.underlay.ssh = config.underlay.ssh + nodes_list
underlay.add_config_ssh(nodes_list)
time.sleep(120) # debug sleep
cmd = "salt '*' test.ping"
underlay.check_call(node_name=cfg_node, verbose=verbose, cmd=cmd)
openstack = managers.openstack_manager.OpenstackManager(
config, underlay, hardware, salt_deployed)
if settings.RUN_TEMPEST:
openstack.run_tempest(
pattern=settings.PATTERN,
node_name=tempest_node)
openstack.download_tempest_report()