| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
| 3 | ## |
| 4 | # Copyright 2015 Telefónica Investigación y Desarrollo, S.A.U. |
| 5 | # This file is part of openmano |
| 6 | # All Rights Reserved. |
| 7 | # |
| 8 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 9 | # not use this file except in compliance with the License. You may obtain |
| 10 | # a copy of the License at |
| 11 | # |
| 12 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 13 | # |
| 14 | # Unless required by applicable law or agreed to in writing, software |
| 15 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 16 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 17 | # License for the specific language governing permissions and limitations |
| 18 | # under the License. |
| 19 | # |
| 20 | # For those usages not covered by the Apache License, Version 2.0 please |
| 21 | # contact with: nfvlabs@tid.es |
| 22 | ## |
| 23 | |
| 24 | #This script can be used as a basic test of openmano. |
| 25 | #WARNING: It destroy the database content |
| 26 | |
| 27 | |
| 28 | function usage(){ |
| 29 | echo -e "usage: ${BASH_SOURCE[0]} [OPTIONS] <action>\n test openmano using openvim as a VIM" |
| 30 | echo -e " the OPENVIM_HOST, OPENVIM_PORT shell variables indicate openvim location" |
| tierno | 72f35a5 | 2016-07-15 13:18:30 +0200 | [diff] [blame] | 31 | echo -e " by default localhost:9080" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 32 | echo -e " <action> is a list of the following items (by default 'reset add-openvim create delete del-openvim')" |
| 33 | echo -e " reset resets the openmano database content and creates osm tenant" |
| 34 | echo -e " add-openvim adds and attaches a local openvim datacenter" |
| 35 | echo -e " del-openvim detaches and deletes the local openvim datacenter" |
| 36 | echo -e " create creates VNFs, scenarios and instances" |
| 37 | echo -e " delete deletes the created instances, scenarios and VNFs" |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 38 | echo -e " OPTIONS:" |
| 39 | echo -e " -f --force does not prompt for confirmation" |
| 40 | echo -e " -h --help shows this help" |
| tierno | 7684184 | 2016-09-27 09:18:28 +0000 | [diff] [blame] | 41 | echo -e " --screen forces to run openmano (and openvim) service in a screen" |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 42 | echo -e " --insert-bashrc insert the created tenant,datacenter variables at" |
| 43 | echo -e " ~/.bashrc to be available by openmano CLI" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 44 | echo -e " --install-openvim installs openvim in test mode" |
| 45 | echo -e " --init-openvim --initopenvim if openvim runs locally, initopenvim is called to clean openvim"\ |
| 46 | "database, create osm tenant and add fake hosts" |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 47 | } |
| 48 | |
| 49 | function is_valid_uuid(){ |
| 50 | echo "$1" | grep -q -E '^[0-9a-f]{8}-([0-9a-f]{4}-){3}[0-9a-f]{12}$' && return 0 |
| 51 | return 1 |
| 52 | } |
| 53 | |
| 54 | #detect if is called with a source to use the 'exit'/'return' command for exiting |
| tierno | 7684184 | 2016-09-27 09:18:28 +0000 | [diff] [blame] | 55 | DIRNAME=$(dirname $(readlink -f ${BASH_SOURCE[0]})) |
| 56 | DIRmano=$(dirname $DIRNAME) |
| 57 | DIRscript=${DIRmano}/scripts |
| 58 | |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 59 | #detect paths of executables, preceding the relative paths |
| 60 | openmano=openmano && [[ -x "${DIRmano}/openmano" ]] && openmano="${DIRmano}/openmano" |
| 61 | service_openmano=service-openmano && [[ -x "$DIRscript/service-openmano" ]] && |
| 62 | service_openmano="$DIRscript/service-openmano" |
| 63 | initopenvim="initopenvim" |
| 64 | openvim="openvim" |
| 65 | |
| tierno | b6884bd | 2016-07-15 14:09:47 +0200 | [diff] [blame] | 66 | [[ ${BASH_SOURCE[0]} != $0 ]] && _exit="return" || _exit="exit" |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 67 | |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 68 | |
| tierno | 7684184 | 2016-09-27 09:18:28 +0000 | [diff] [blame] | 69 | #process options |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 70 | source ${DIRscript}/get-options.sh "force:f help:h insert-bashrc init-openvim:initopenvim install-openvim screen" \ |
| 71 | $* || $_exit 1 |
| tierno | 205d102 | 2016-07-21 11:26:22 +0200 | [diff] [blame] | 72 | |
| tierno | 7684184 | 2016-09-27 09:18:28 +0000 | [diff] [blame] | 73 | #help |
| 74 | [ -n "$option_help" ] && usage && $_exit 0 |
| 75 | |
| 76 | #check correct arguments |
| 77 | force_param="" && [[ -n "$option_force" ]] && force_param=" -f" |
| 78 | insert_bashrc_param="" && [[ -n "$option_insert_bashrc" ]] && insert_bashrc_param=" --insert-bashrc" |
| 79 | screen_mano_param="" && [[ -n "$option_screen" ]] && screen_mano_param=" --screen-name=mano" |
| 80 | screen_vim_param="" && [[ -n "$option_screen" ]] && screen_vim_param=" --screen-name=vim" |
| 81 | |
| 82 | action_list="" |
| 83 | |
| 84 | for argument in $params |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 85 | do |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 86 | if [[ $argument == reset ]] || [[ $argument == create ]] || [[ $argument == delete ]] || |
| 87 | [[ $argument == add-openvim ]] || [[ $argument == del-openvim ]] || [[ -z "$argument" ]] |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 88 | then |
| tierno | 205d102 | 2016-07-21 11:26:22 +0200 | [diff] [blame] | 89 | action_list="$action_list $argument" |
| 90 | continue |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 91 | fi |
| tierno | 205d102 | 2016-07-21 11:26:22 +0200 | [diff] [blame] | 92 | echo "invalid argument '$argument'? Type -h for help" >&2 && $_exit 1 |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 93 | done |
| 94 | |
| tierno | b6884bd | 2016-07-15 14:09:47 +0200 | [diff] [blame] | 95 | export OPENMANO_HOST=localhost |
| 96 | export OPENMANO_PORT=9090 |
| tierno | 7684184 | 2016-09-27 09:18:28 +0000 | [diff] [blame] | 97 | [[ -n "$option_insert_bashrc" ]] && echo -e "\nexport OPENMANO_HOST=localhost" >> ~/.bashrc |
| 98 | [[ -n "$option_insert_bashrc" ]] && echo -e "\nexport OPENMANO_PORT=9090" >> ~/.bashrc |
| tierno | b6884bd | 2016-07-15 14:09:47 +0200 | [diff] [blame] | 99 | |
| 100 | |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 101 | #by default action should be reset and create |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 102 | [[ -z $action_list ]] && action_list="reset add-openvim create delete del-openvim" |
| tierno | aa5832d | 2016-12-07 16:20:25 +0100 | [diff] [blame] | 103 | |
| 104 | if [[ -n "$option_install_openvim" ]] |
| 105 | then |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 106 | echo |
| 107 | echo "action: install openvim" |
| 108 | echo "################################" |
| tierno | a6003ee | 2016-12-21 16:18:00 +0100 | [diff] [blame] | 109 | mkdir -p ${DIRNAME}/local |
| 110 | pushd ${DIRNAME}/local |
| 111 | echo "installing openvim at ${DIRNAME}/openvim ... " |
| tierno | aa5832d | 2016-12-07 16:20:25 +0100 | [diff] [blame] | 112 | wget -O install-openvim.sh "https://osm.etsi.org/gitweb/?p=osm/openvim.git;a=blob_plain;f=scripts/install-openvim.sh" |
| 113 | chmod +x install-openvim.sh |
| 114 | sudo ./install-openvim.sh --no-install-packages --force --quiet --develop |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 115 | openvim="${DIRNAME}/local/openvim/openvim" |
| 116 | #force inito-penvim |
| 117 | option_init_openvim="-" |
| 118 | initopenvim="${DIRNAME}/local/openvim/scripts/initopenvim" |
| tierno | aa5832d | 2016-12-07 16:20:25 +0100 | [diff] [blame] | 119 | popd |
| 120 | fi |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 121 | |
| 122 | if [[ -n "$option_init_openvim" ]] |
| 123 | then |
| 124 | echo |
| 125 | echo "action: init openvim" |
| 126 | echo "################################" |
| 127 | ${initopenvim} ${force_param}${insert_bashrc_param}${screen_vim_param} || \ |
| 128 | echo "WARNING openvim cannot be initialized. The rest of test can fail!" |
| 129 | fi |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 130 | |
| tierno | 72f35a5 | 2016-07-15 13:18:30 +0200 | [diff] [blame] | 131 | #check openvim client variables are set |
| 132 | #fail="" |
| 133 | #[[ -z $OPENVIM_HOST ]] && echo "OPENVIM_HOST variable not defined" >&2 && fail=1 |
| 134 | #[[ -z $OPENVIM_PORT ]] && echo "OPENVIM_PORT variable not defined" >&2 && fail=1 |
| 135 | #[[ -n $fail ]] && $_exit 1 |
| 136 | |
| 137 | |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 138 | for action in $action_list |
| 139 | do |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 140 | echo |
| 141 | echo "action: $action" |
| 142 | echo "################################" |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 143 | #if [[ $action == "install-openvim" ]] |
| 144 | #echo "Installing and starting openvim" |
| 145 | #mkdir -p temp |
| 146 | #pushd temp |
| 147 | #wget https://github.com/nfvlabs/openvim/raw/v0.4/scripts/install-openvim.sh |
| 148 | #chmod -x install-openvim.sh |
| 149 | #fi |
| 150 | |
| 151 | if [[ $action == "reset" ]] |
| 152 | then |
| 153 | |
| 154 | #ask for confirmation if argument is not -f --force |
| tierno | 72f35a5 | 2016-07-15 13:18:30 +0200 | [diff] [blame] | 155 | force_=y |
| tierno | 7684184 | 2016-09-27 09:18:28 +0000 | [diff] [blame] | 156 | [[ -z "$option_force" ]] && read -e -p "WARNING: reset openmano database, content will be lost!!! Continue(y/N) " force_ |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 157 | [[ $force_ != y ]] && [[ $force_ != yes ]] && echo "aborted!" && $_exit |
| 158 | |
| 159 | echo "Stopping openmano" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 160 | $service_openmano mano stop${screen_mano_param} |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 161 | echo "Initializing openmano database" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 162 | $DIRmano/database_utils/init_mano_db.sh -u mano -p manopw |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 163 | echo "Starting openmano" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 164 | $service_openmano mano start${screen_mano_param} |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 165 | echo |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 166 | printf "%-50s" "Creating openmano tenant 'osm': " |
| 167 | result=`$openmano tenant-create osm --description="created by basictest.sh"` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 168 | nfvotenant=`echo $result |gawk '{print $1}'` |
| 169 | #check a valid uuid is obtained |
| 170 | ! is_valid_uuid $nfvotenant && echo "FAIL" && echo " $result" && $_exit 1 |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 171 | export OPENMANO_TENANT=osm |
| 172 | [[ -n "$option_insert_bashrc" ]] && echo -e "\nexport OPENMANO_TENANT=osm" >> ~/.bashrc |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 173 | echo $nfvotenant |
| 174 | |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 175 | elif [[ $action == "delete" ]] |
| 176 | then |
| 177 | result=`openmano tenant-list osm` |
| 178 | nfvotenant=`echo $result |gawk '{print $1}'` |
| 179 | #check a valid uuid is obtained |
| 180 | is_valid_uuid $nfvotenant || ! echo "Tenant osm not found. Already delete?" >&2 || $_exit 1 |
| 181 | export OPENMANO_TENANT=$nfvotenant |
| 182 | $openmano instance-scenario-delete -f simple-instance || echo "fail" |
| 183 | $openmano instance-scenario-delete -f complex-instance || echo "fail" |
| 184 | $openmano instance-scenario-delete -f complex2-instance || echo "fail" |
| 185 | $openmano instance-scenario-delete -f complex3-instance || echo "fail" |
| 186 | $openmano instance-scenario-delete -f complex4-instance || echo "fail" |
| 187 | $openmano instance-scenario-delete -f complex5-instance || echo "fail" |
| 188 | $openmano scenario-delete -f simple || echo "fail" |
| 189 | $openmano scenario-delete -f complex || echo "fail" |
| 190 | $openmano scenario-delete -f complex2 || echo "fail" |
| 191 | $openmano scenario-delete -f complex3 || echo "fail" |
| 192 | $openmano scenario-delete -f complex4 || echo "fail" |
| 193 | $openmano scenario-delete -f complex5 || echo "fail" |
| 194 | $openmano vnf-delete -f linux || echo "fail" |
| 195 | $openmano vnf-delete -f linux_2VMs_v02 || echo "fail" |
| 196 | $openmano vnf-delete -f dataplaneVNF_2VMs || echo "fail" |
| 197 | $openmano vnf-delete -f dataplaneVNF_2VMs_v02 || echo "fail" |
| 198 | $openmano vnf-delete -f dataplaneVNF4 || echo "fail" |
| 199 | $openmano vnf-delete -f dataplaneVNF2 || echo "fail" |
| 200 | $openmano vnf-delete -f dataplaneVNF3 || echo "fail" |
| 201 | |
| 202 | elif [[ $action == "del-openvim" ]] |
| 203 | then |
| 204 | $openmano datacenter-detach local-openvim || echo "fail" |
| 205 | $openmano datacenter-delete -f local-openvim || echo "fail" |
| 206 | |
| 207 | elif [[ $action == "add-openvim" ]] |
| 208 | then |
| 209 | |
| 210 | printf "%-50s" "Creating datacenter 'local-openvim' at openmano:" |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 211 | [[ -z $OPENVIM_HOST ]] && OPENVIM_HOST=localhost |
| 212 | [[ -z $OPENVIM_PORT ]] && OPENVIM_PORT=9080 |
| 213 | URL_ADMIN_PARAM="" |
| tierno | 8008c3a | 2016-10-13 15:34:28 +0000 | [diff] [blame] | 214 | [[ -n $OPENVIM_ADMIN_PORT ]] && URL_ADMIN_PARAM=" --url_admin=http://${OPENVIM_HOST}:${OPENVIM_ADMIN_PORT}/openvim" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 215 | result=`$openmano datacenter-create local-openvim "http://${OPENVIM_HOST}:${OPENVIM_PORT}/openvim" \ |
| 216 | --type=openvim${URL_ADMIN_PARAM} --config="{test: no use just for test}"` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 217 | datacenter=`echo $result |gawk '{print $1}'` |
| 218 | #check a valid uuid is obtained |
| 219 | ! is_valid_uuid $datacenter && echo "FAIL" && echo " $result" && $_exit 1 |
| 220 | echo $datacenter |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 221 | export OPENMANO_DATACENTER=local-openvim |
| 222 | [[ -n "$option_insert_bashrc" ]] && echo -e "\nexport OPENMANO_DATACENTER=local-openvim" >> ~/.bashrc |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 223 | |
| 224 | printf "%-50s" "Attaching openmano tenant to the datacenter:" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 225 | result=`$openmano datacenter-attach local-openvim --vim-tenant-name=osm --config="{test: no use just for test}"` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 226 | [[ $? != 0 ]] && echo "FAIL" && echo " $result" && $_exit 1 |
| 227 | echo OK |
| 228 | |
| 229 | printf "%-50s" "Updating external nets in openmano: " |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 230 | result=`$openmano datacenter-netmap-delete -f --all` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 231 | [[ $? != 0 ]] && echo "FAIL" && echo " $result" && $_exit 1 |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 232 | result=`$openmano datacenter-netmap-import -f` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 233 | [[ $? != 0 ]] && echo "FAIL" && echo " $result" && $_exit 1 |
| 234 | echo OK |
| 235 | |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 236 | elif [[ $action == "create" ]] |
| 237 | then |
| garciadeblas | 9a241aa | 2016-09-30 12:25:59 +0200 | [diff] [blame] | 238 | for VNF in linux dataplaneVNF1 dataplaneVNF2 dataplaneVNF_2VMs dataplaneVNF_2VMs_v02 dataplaneVNF3 linux_2VMs_v02 dataplaneVNF4 |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 239 | do |
| 240 | printf "%-50s" "Creating VNF '${VNF}': " |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 241 | result=`$openmano vnf-create $DIRmano/vnfs/examples/${VNF}.yaml` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 242 | vnf=`echo $result |gawk '{print $1}'` |
| 243 | #check a valid uuid is obtained |
| 244 | ! is_valid_uuid $vnf && echo FAIL && echo " $result" && $_exit 1 |
| 245 | echo $vnf |
| 246 | done |
| garciadeblas | 1448045 | 2017-01-10 13:08:07 +0100 | [diff] [blame] | 247 | for NS in simple complex complex2 complex3 complex4 complex5 |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 248 | do |
| 249 | printf "%-50s" "Creating scenario '${NS}':" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 250 | result=`$openmano scenario-create $DIRmano/scenarios/examples/${NS}.yaml` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 251 | scenario=`echo $result |gawk '{print $1}'` |
| 252 | ! is_valid_uuid $scenario && echo FAIL && echo " $result" && $_exit 1 |
| 253 | echo $scenario |
| 254 | done |
| 255 | |
| garciadeblas | 1448045 | 2017-01-10 13:08:07 +0100 | [diff] [blame] | 256 | for IS in simple complex complex2 complex3 complex5 |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 257 | do |
| 258 | printf "%-50s" "Creating instance-scenario '${IS}':" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 259 | result=`$openmano instance-scenario-create --scenario ${IS} --name ${IS}-instance` |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 260 | instance=`echo $result |gawk '{print $1}'` |
| 261 | ! is_valid_uuid $instance && echo FAIL && echo " $result" && $_exit 1 |
| 262 | echo $instance |
| 263 | done |
| 264 | |
| garciadeblas | 9f8456e | 2016-09-05 05:02:59 +0200 | [diff] [blame] | 265 | printf "%-50s" "Creating instance-scenario 'complex4':" |
| tierno | 75dc678 | 2017-05-05 15:53:41 +0200 | [diff] [blame] | 266 | result=`$openmano instance-scenario-create $DIRmano/instance-scenarios/examples/instance-creation-complex4.yaml` |
| garciadeblas | 9f8456e | 2016-09-05 05:02:59 +0200 | [diff] [blame] | 267 | instance=`echo $result |gawk '{print $1}'` |
| 268 | ! is_valid_uuid $instance && echo FAIL && echo " $result" && $_exit 1 |
| 269 | echo $instance |
| 270 | |
| tierno | 96d9cd4 | 2016-07-13 12:28:19 +0200 | [diff] [blame] | 271 | echo |
| 272 | #echo "Check virtual machines are deployed" |
| 273 | #vms_error=`openvim vm-list | grep ERROR | wc -l` |
| 274 | #vms=`openvim vm-list | wc -l` |
| 275 | #[[ $vms -ne 8 ]] && echo "WARNING: $vms VMs created, must be 8 VMs" >&2 && $_exit 1 |
| 276 | #[[ $vms_error -gt 0 ]] && echo "WARNING: $vms_error VMs with ERROR" >&2 && $_exit 1 |
| 277 | fi |
| 278 | done |
| 279 | |
| 280 | echo |
| 281 | echo DONE |
| 282 | |
| 283 | |