#!/bin/bash
+echo "----------> Copy ssh public keys to csit lab"
+
+source $WORKSPACE/.venv-openstack/bin/activate
+
function copy-ssh-keys-to-slave() {
RETRIES=60
for j in $(seq 1 $RETRIES); do
echo "SSH not responding on ${i}. Retrying in 10 seconds..."
sleep 10
fi
+
+ # ping test to see if connectivity is available
+ if ping -c1 ${i} &> /dev/null; then
+ echo "Ping to ${i} successful."
+ else
+ echo "Ping to ${i} failed."
+ fi
done
}
-source $WORKSPACE/.venv-openstack/bin/activate
-CONTROLLER_IPS=`openstack --os-cloud rackspace stack show -f json -c outputs $STACK_NAME | jq -r '.outputs[] | select(.output_key=="vm_0_ips") | .output_value[]'`
-MININET_IPS=`openstack --os-cloud rackspace stack show -f json -c outputs $STACK_NAME | jq -r '.outputs[] | select(.output_key=="vm_1_ips") | .output_value[]'`
-ADDR=($CONTROLLER_IPS $MININET_IPS)
+# Print the Stack outputs parameters so that we can identify which IPs belong
+# to which VM types.
+openstack --os-cloud rackspace stack show -c outputs $STACK_NAME
+ADDR=(`openstack --os-cloud rackspace stack show -f json -c outputs $STACK_NAME | \
+ jq -r '.outputs[] | \
+ select(.output_key | match("^vm_[0-9]+_ips\$")) | \
+ .output_value | .[]'`)
pids=""
for i in "${ADDR[@]}"; do
( copy-ssh-keys-to-slave ) &