#!/bin/bash
+echo "----------> Copy ssh public keys to csit lab"
+
+# shellcheck disable=SC1090
+source "$WORKSPACE/.venv-openstack/bin/activate"
+
function copy-ssh-keys-to-slave() {
RETRIES=60
for j in $(seq 1 $RETRIES); do
- if `ssh-copy-id -i /home/jenkins/.ssh/id_rsa.pub "jenkins@${i}" > /dev/null 2>&1`; then
- ssh jenkins@${i} 'echo "$(facter ipaddress_eth0) $(/bin/hostname)" | sudo tee -a /etc/hosts'
+ if ssh-copy-id -i /home/jenkins/.ssh/id_rsa.pub "jenkins@${i}" > /dev/null 2>&1; then
+ ssh "jenkins@${i}" 'echo "$(facter ipaddress_eth0) $(/bin/hostname)" | sudo tee -a /etc/hosts'
echo "Successfully copied public keys to slave ${i}"
break
- elif [ $j -eq $RETRIES ]; then
+ elif [ "$j" -eq $RETRIES ]; then
echo "SSH not responding on ${i} after $RETIRES tries. Giving up."
exit 1
else
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
}
-# TODO: Remove condition when we no longer use JClouds plugin
-if [ -z "$JCLOUDS_IPS" ]; then
- # If JCLOUDS_IPS is not set then we will spawn instances with
- # OpenStack Heat.
- 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)
-else
- echo "OpenStack IPS are ${JCLOUDS_IPS}"
- IFS=',' read -ra ADDR <<< "${JCLOUDS_IPS}"
-fi
+# 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 ) &
# Detect when a process failed to copy ssh keys and fail build
for p in $pids; do
- if wait $p; then
+ if wait "$p"; then
echo "Process $p successfully copied ssh keys."
else
echo "Process $p failed to copy ssh keys."