[vcp] Increase timeout till VCP VMs online
[fuel.git] / mcp / config / states / virtual_control_plane
1 #!/bin/bash -e
2 ##############################################################################
3 # Copyright (c) 2017 Mirantis Inc., Enea AB and others.
4 # All rights reserved. This program and the accompanying materials
5 # are made available under the terms of the Apache License, Version 2.0
6 # which accompanies this distribution, and is available at
7 # http://www.apache.org/licenses/LICENSE-2.0
8 ##############################################################################
9
10 CI_DEBUG=${CI_DEBUG:-0}; [[ "${CI_DEBUG}" =~ (false|0) ]] || set -x
11
12 # shellcheck disable=SC1090
13 source "$(dirname "${BASH_SOURCE[0]}")/../../scripts/lib.sh"
14
15 # KVM, compute node prereqs (libvirt first), VCP deployment
16 salt -C 'kvm*' pkg.install bridge-utils
17 salt -C 'kvm*' state.apply linux.network
18 salt -C 'cmp*' state.apply linux.system
19 salt -C 'cmp*' state.apply linux.network || true
20 salt -C 'kvm* or cmp*' system.reboot
21 wait_for 90 "! salt -C 'kvm* or cmp*' test.ping | " \
22   "tee /dev/stderr | grep -Fq 'Not connected'"
23
24 salt -C '* and not cfg01* and not mas01*' state.apply linux,ntp
25
26 wait_for 5 "salt -C 'kvm*' state.sls libvirt"
27
28 salt -C '* and not cfg01* and not mas01*' state.apply salt
29 salt -C 'kvm*' saltutil.sync_all
30 wait_for 10 "! salt -C 'kvm*' state.sls salt.control | " \
31   "tee /dev/stderr | grep -Fq 'Not connected'"
32
33 vcp_nodes=$(salt --out yaml 'kvm01*' pillar.get salt:control:cluster:internal:node | \
34             awk '/\s+\w+:$/ {gsub(/:$/, "*"); print $1}')
35
36 # Check all vcp nodes are available
37 rc=1
38 attempt=0
39 total_attempts=50
40 while [ $rc -ne 0 ] && [ ${attempt} -lt ${total_attempts} ]; do
41   rc=0
42   for node in $vcp_nodes; do
43     salt "$node" test.ping 2>/dev/null || { rc=$?; break; };
44   done
45   sleep 5
46   ((attempt+=1))
47 done
48
49 wait_for 10 "salt -C '* and not cfg01* and not mas01*' saltutil.sync_all"
50 wait_for 10 "salt -C 'E@^(?!cfg01|mas01|kvm|cmp00).*' state.apply salt"
51 wait_for 10 "! salt -C 'E@^(?!cfg01|mas01|kvm|cmp00).*' state.apply linux,ntp | " \
52   "tee /dev/stderr | grep -Fq 'Not connected'"
53
54 wait_for 10 "salt -C 'E@^(?!cfg01|mas01|kvm|cmp00).*' ssh.set_auth_key ${SUDO_USER} \
55   $(awk 'NR==1{print $2}' "$(eval echo "~${SUDO_USER}/.ssh/authorized_keys")")"