Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 1 | # Copyright 2016 Mirantis, Inc. |
| 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 4 | # not use this file except in compliance with the License. You may obtain |
| 5 | # a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 11 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 12 | # License for the specific language governing permissions and limitations |
| 13 | # under the License. |
| 14 | import copy |
Dennis Dmitriev | a982b2d | 2016-10-21 16:52:50 +0300 | [diff] [blame] | 15 | import time |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 16 | |
| 17 | import pytest |
| 18 | |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 19 | from tcp_tests import settings |
| 20 | from tcp_tests.helpers import ext |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 21 | from tcp_tests import logger |
| 22 | |
| 23 | LOG = logger.logger |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 24 | |
| 25 | |
| 26 | @pytest.mark.deploy |
| 27 | class TestTCPInstaller(object): |
| 28 | """Test class for testing TCP deployment""" |
| 29 | |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 30 | #salt_cmd = 'salt -l debug ' # For debug output |
| 31 | #salt_call_cmd = 'salt-call -l debug ' # For debug output |
Dennis Dmitriev | 21d0ff0 | 2016-10-25 13:45:17 +0300 | [diff] [blame] | 32 | salt_cmd = 'salt --state-output=mixed --state-verbose=False ' # For cause only output |
| 33 | salt_call_cmd = 'salt-call --state-output=mixed --state-verbose=False ' # For cause only output |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 34 | #salt_cmd = 'salt --state-output=terse --state-verbose=False ' # For reduced output |
| 35 | #salt_call_cmd = 'salt-call --state-output=terse --state-verbose=False ' # For reduced output |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 36 | |
| 37 | |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 38 | steps_mk22_lab_advanced = [ |
| 39 | { |
| 40 | 'description': "Run 'linux' formula on cfg01", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 41 | 'cmd': salt_cmd + "'cfg01*' state.sls linux", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 42 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 43 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 44 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 45 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 46 | { |
| 47 | 'description': "Run 'openssh' formula on cfg01", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 48 | 'cmd': (salt_cmd + "'cfg01*' state.sls openssh;" |
| 49 | "sed -i 's/PasswordAuthentication no/" |
| 50 | "PasswordAuthentication yes/' " |
| 51 | "/etc/ssh/sshd_config && service ssh restart"), |
| 52 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 53 | 'retry': {'count': 3, 'delay': 5}, |
| 54 | 'skip_fail': False, |
| 55 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 56 | { |
| 57 | 'description': ("*Workaround* of the bug" |
| 58 | " https://mirantis.jira.com/browse/PROD-7962"), |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 59 | 'cmd': "echo ' StrictHostKeyChecking no' >> /root/.ssh/config", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 60 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 61 | 'retry': {'count': 1, 'delay': 1}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 62 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 63 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 64 | { |
| 65 | 'description': "Run 'salt' formula on cfg01", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 66 | 'cmd': salt_cmd + "'cfg01*' state.sls salt", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 67 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 68 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 69 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 70 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 71 | { |
Dennis Dmitriev | 7080d8d | 2016-10-26 13:43:37 +0300 | [diff] [blame^] | 72 | 'description': "Accept salt keys from all the nodes", |
| 73 | 'cmd': "salt-key -A -y", |
| 74 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
| 75 | 'retry': {'count': 1, 'delay': 5}, |
| 76 | 'skip_fail': False, |
| 77 | }, |
| 78 | { |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 79 | 'description': ("Generate inventory for all the nodes to the" |
| 80 | " /srv/salt/reclass/nodes/_generated"), |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 81 | 'cmd': salt_cmd + "'cfg01*' state.sls reclass.storage", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 82 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 83 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 84 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 85 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 86 | { |
| 87 | 'description': "Refresh pillars on all minions", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 88 | 'cmd': salt_cmd + "'*' saltutil.refresh_pillar", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 89 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 90 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 91 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 92 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 93 | { |
| 94 | 'description': "Configure ntp on controllers", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 95 | 'cmd': salt_cmd + "'ctl*' state.sls ntp", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 96 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 7080d8d | 2016-10-26 13:43:37 +0300 | [diff] [blame^] | 97 | 'retry': {'count': 5, 'delay': 10}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 98 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 99 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 100 | { |
| 101 | 'description': "Configure linux on controllers", |
| 102 | 'cmd': salt_cmd + "'ctl*' state.sls linux", |
| 103 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
| 104 | 'retry': {'count': 5, 'delay': 5}, |
| 105 | 'skip_fail': False, |
| 106 | }, |
| 107 | { |
| 108 | 'description': "Configure openssh on controllers", |
| 109 | 'cmd': (salt_cmd + "'ctl*' state.sls openssh;" |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 110 | + salt_cmd + "'ctl*' cmd.run " |
| 111 | "\"sed -i 's/PasswordAuthentication no/" |
| 112 | "PasswordAuthentication yes/' /etc/ssh/sshd_config && " |
| 113 | "service ssh restart\""), |
| 114 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 115 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 116 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 117 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 118 | { |
| 119 | 'description': "Configure salt.minion on controllers", |
| 120 | 'cmd': salt_cmd + "'ctl*' state.sls salt.minion", |
| 121 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
| 122 | 'retry': {'count': 3, 'delay': 5}, |
| 123 | 'skip_fail': False, |
| 124 | }, |
| 125 | { |
| 126 | 'description': "Install keepalived on primary controller", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 127 | 'cmd': salt_cmd + "'ctl01*' state.sls keepalived", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 128 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 129 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 130 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 131 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 132 | { |
| 133 | 'description': "Show VIP on primary controller", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 134 | 'cmd': salt_cmd + "'ctl01*' cmd.run 'ip a'", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 135 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 136 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 137 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 138 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 139 | { |
| 140 | 'description': "Install keepalived on other controllers", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 141 | 'cmd': salt_cmd + "'ctl0[23].*' state.sls keepalived", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 142 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 143 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 144 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 145 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 146 | { |
| 147 | 'description': "Install glusterfs on all controllers", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 148 | 'cmd': salt_cmd + "'ctl*' state.sls glusterfs.server.service", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 149 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 150 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 151 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 152 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 153 | { |
| 154 | 'description': "Setup glusterfs on primary controller", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 155 | 'cmd': salt_call_cmd + "state.sls glusterfs.server.setup", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 156 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 157 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 158 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 159 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 160 | { |
| 161 | 'description': "Show glusterfs peer status", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 162 | 'cmd': "gluster peer status", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 163 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 164 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 165 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 166 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 167 | { |
| 168 | 'description': "Show glusterfs volume status", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 169 | 'cmd': "gluster volume status", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 170 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 171 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 172 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 173 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 174 | { |
| 175 | 'description': "Install RabbitMQ on all controllers", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 176 | 'cmd': salt_cmd + "'ctl*' state.sls rabbitmq", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 177 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 178 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 179 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 180 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 181 | { |
| 182 | 'description': ("*Workaround* Update salt-formula-galera on" |
| 183 | " config node to the latest version"), |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 184 | 'cmd': "apt-get -y --force-yes install salt-formula-galera", |
| 185 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 186 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 187 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 188 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 189 | { |
| 190 | 'description': "Install Galera on primary controller", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 191 | 'cmd': salt_call_cmd + "state.sls galera", |
| 192 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 193 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 194 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 195 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 196 | { |
| 197 | 'description': "Install Galera on other controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 198 | 'cmd': salt_cmd + "'ctl0[23]*' state.sls galera", |
| 199 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 200 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 201 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 202 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 203 | { |
| 204 | 'description': "Check Galera addresses", |
| 205 | 'cmd': (salt_cmd + "'ctl01*' mysql.status |" |
| 206 | " grep -A1 'wsrep_incoming_addresses:'"), |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 207 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 208 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 209 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 210 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 211 | { |
| 212 | 'description': "Install haproxy on all controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 213 | 'cmd': salt_cmd + "'ctl*' state.sls haproxy", |
| 214 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 215 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 216 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 217 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 218 | { |
| 219 | 'description': "Check haproxy on all controllers with Galera port", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 220 | 'cmd': salt_cmd + "'ctl*' cmd.run 'netstat -tulnp | grep 3306'", |
| 221 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 222 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 223 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 224 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 225 | { |
| 226 | 'description': "Install memcached and keystone on ctl01", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 227 | 'cmd': salt_call_cmd + "state.sls memcached,keystone", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 228 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 229 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 230 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 231 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 232 | { |
| 233 | 'description': "Install memcached and keystone on ctl02", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 234 | 'cmd': salt_call_cmd + "state.sls memcached,keystone", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 235 | 'node_name': 'ctl02.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 236 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 237 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 238 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 239 | { |
| 240 | 'description': "Install memcached and keystone on ctl03", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 241 | 'cmd': salt_call_cmd + "state.sls memcached,keystone", |
| 242 | 'node_name': 'ctl03.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 243 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 244 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 245 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 246 | { |
| 247 | 'description': "Check keystone user-list", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 248 | 'cmd': "source ~/keystonerc; keystone user-list", |
| 249 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 250 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 251 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 252 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 253 | { |
| 254 | 'description': "Check keystone tenant-list", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 255 | 'cmd': "source ~/keystonerc; keystone tenant-list", |
| 256 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 257 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 258 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 259 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 260 | { |
| 261 | 'description': "Check keystone endpoint-list", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 262 | 'cmd': "source ~/keystonerc; keystone endpoint-list", |
| 263 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 264 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 265 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 266 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 267 | { |
| 268 | 'description': "Install glance on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 269 | 'cmd': salt_cmd + "'ctl*' state.sls glance", |
| 270 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 271 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 272 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 273 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 274 | { |
| 275 | 'description': "Install glusterfs on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 276 | 'cmd': salt_cmd + "'ctl*' state.sls glusterfs.client", |
| 277 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 278 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 279 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 280 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 281 | { |
| 282 | 'description': "Check that glusterfs was added on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 283 | 'cmd': salt_cmd + "'ctl*' cmd.run 'df -h'", |
| 284 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 285 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 286 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 287 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 288 | { |
| 289 | 'description': ("*Workaround* Re-run keystone formula on ctl01 to" |
| 290 | " create fernet keys"), |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 291 | 'cmd': salt_call_cmd + "state.sls keystone", |
| 292 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
| 293 | 'retry': {'count': 3, 'delay': 5}, |
| 294 | 'skip_fail': False, |
| 295 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 296 | { |
| 297 | 'description': "Check glance on ctl01", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 298 | 'cmd': ("source ~/keystonerc;" |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 299 | "wget http://download.cirros-cloud.net/0.3.4/" |
| 300 | "cirros-0.3.4-i386-disk.img;" |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 301 | "glance image-create --name 'cirros-0.3.4'" |
| 302 | " --disk-format qcow2 --container-format bare" |
| 303 | " --progress --file /root/cirros-0.3.4-i386-disk.img;" |
| 304 | "glance image-list;"), |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 305 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 306 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 307 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 308 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 309 | { |
| 310 | 'description': "Check keystone fernet keys on controllers", |
| 311 | 'cmd': (salt_cmd + "'ctl*' cmd.run 'ls -la" |
| 312 | " /var/lib/keystone/fernet-keys' "), |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 313 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 314 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 315 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 316 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 317 | { |
| 318 | 'description': "Install cinder on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 319 | 'cmd': salt_cmd + "'ctl*' cinder", |
| 320 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 321 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 322 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 323 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 324 | { |
| 325 | 'description': "Install nova on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 326 | 'cmd': salt_cmd + "'ctl*' nova", |
| 327 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 328 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 329 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 330 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 331 | { |
| 332 | 'description': "Check cinder status", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 333 | 'cmd': "source ~/keystonerc; cinder list", |
| 334 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 335 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 336 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 337 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 338 | { |
| 339 | 'description': "Check nova services status", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 340 | 'cmd': "source ~/keystonerc; nova-manage service list", |
| 341 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 342 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 343 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 344 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 345 | { |
| 346 | 'description': "Check nova status", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 347 | 'cmd': "source ~/keystonerc; nova list", |
| 348 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 349 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 350 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 351 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 352 | { |
| 353 | 'description': "Install neutron on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 354 | 'cmd': salt_cmd + "'ctl*' state.sls neutron", |
| 355 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 356 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 357 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 358 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 359 | { |
| 360 | 'description': "Create a neutron subnet", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 361 | 'cmd': ("source ~/keystonerc;" |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 362 | "neutron net-create --router:external=true" |
| 363 | " --shared external;" |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 364 | "neutron subnet-create external 10.177.0.0/24;" |
| 365 | "neutron floatingip-create;"), |
| 366 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 367 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 368 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 369 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 370 | { |
| 371 | 'description': "Install contrail database on controllers", |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 372 | 'cmd': salt_cmd + "'ctl*' state.sls opencontrail.database", |
| 373 | 'node_name': 'cfg01.mk22-lab-advanced.local', # hardcoded for now |
| 374 | 'retry': {'count': 3, 'delay': 5}, |
| 375 | 'skip_fail': False, |
| 376 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 377 | { |
| 378 | 'description': "Check cassandra status on ctl01", |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 379 | 'cmd': ("nodetool status;" |
| 380 | "nodetool compactionstats;" |
| 381 | "nodetool describecluster;"), |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 382 | 'node_name': 'ctl01.mk22-lab-advanced.local', # hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 383 | 'retry': {'count': 3, 'delay': 5}, |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 384 | 'skip_fail': False, |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 385 | }, |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 386 | ] |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 387 | |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 388 | |
| 389 | @pytest.mark.steps(steps_mk22_lab_advanced) |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 390 | @pytest.mark.revert_snapshot(ext.SNAPSHOT.underlay) |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 391 | # @pytest.mark.snapshot_needed |
| 392 | # @pytest.mark.fail_snapshot |
| 393 | def test_tcp_install_default(self, underlay, tcp_actions, steps, show_step): |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 394 | """Test for deploying an tcp environment and check it |
| 395 | |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 396 | Scenario: |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 397 | 1. Prepare salt on hosts |
| 398 | 2. Setup controller nodes |
| 399 | 3. Setup compute nodes |
Dennis Dmitriev | 6f59add | 2016-10-18 13:45:27 +0300 | [diff] [blame] | 400 | |
Dennis Dmitriev | 75fce1b | 2016-10-18 15:04:28 +0300 | [diff] [blame] | 401 | """ |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 402 | for n, step in enumerate(steps): |
| 403 | LOG.info(" ####################################################") |
| 404 | LOG.info(" *** [ STEP #{0} ] {1} ***" |
| 405 | .format(n+1, step['description'])) |
| 406 | |
| 407 | with underlay.remote(node_name=step['node_name']) as remote: |
| 408 | for x in range(step['retry']['count'], 0, -1): |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 409 | |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 410 | result = remote.execute(step['cmd'], verbose=True) |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 411 | |
| 412 | # Workaround of exit code 0 from salt in case of failures |
| 413 | failed = 0 |
| 414 | for s in result['stdout']: |
| 415 | if s.startswith("Failed:"): |
| 416 | failed += int(s.split("Failed:")[1]) |
| 417 | |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 418 | if result.exit_code != 0: |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 419 | time.sleep(step['retry']['delay']) |
| 420 | LOG.info(" === RETRY ({0}/{1}) =========================" |
| 421 | .format(x-1, step['retry']['count'])) |
Dennis Dmitriev | 0ebe9f3 | 2016-10-25 11:01:44 +0300 | [diff] [blame] | 422 | elif failed != 0: |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 423 | LOG.error(" === SALT returned exit code = 0 while " |
| 424 | "there are failed modules! ===") |
| 425 | LOG.info(" === RETRY ({0}/{1}) =======================" |
| 426 | .format(x-1, step['retry']['count'])) |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 427 | else: |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 428 | # Workarounds for crashed services |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 429 | tcp_actions.check_salt_service( |
| 430 | "salt-master", |
| 431 | "cfg01.mk22-lab-advanced.local", |
| 432 | "salt-call pillar.items") # Hardcoded for now |
| 433 | tcp_actions.check_salt_service( |
| 434 | "salt-minion", |
| 435 | "cfg01.mk22-lab-advanced.local", |
| 436 | "salt 'cfg01*' pillar.items") # Hardcoded for now |
Dennis Dmitriev | 474e3f7 | 2016-10-21 16:46:09 +0300 | [diff] [blame] | 437 | break |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 438 | |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 439 | if x == 1 and step['skip_fail'] == False: |
Dennis Dmitriev | 423a7ff | 2016-10-21 18:31:36 +0300 | [diff] [blame] | 440 | # In the last retry iteration, raise an exception |
Dennis Dmitriev | 4be178c | 2016-10-25 13:17:46 +0300 | [diff] [blame] | 441 | raise Exception("Step '{0}' failed" |
| 442 | .format(step['description'])) |