X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Fopendaylight-infra-copy-ssh-keys.sh;h=493f776b7549cda38814220fa9dfcf1ab70c63b6;hb=93a5304ef04620630cbd6de14694607048bf2aa3;hp=2b2267786d357a08ba0843c8b1b6d9d822b1ac6d;hpb=c63f16d4cc357b4e3449ae5f0950be3a5165f221;p=releng%2Fbuilder.git diff --git a/jjb/opendaylight-infra-copy-ssh-keys.sh b/jjb/opendaylight-infra-copy-ssh-keys.sh index 2b2267786..493f776b7 100644 --- a/jjb/opendaylight-infra-copy-ssh-keys.sh +++ b/jjb/opendaylight-infra-copy-ssh-keys.sh @@ -1,17 +1,31 @@ -#!/bin/bash -echo "----------> Copy ssh public keys to csit lab" +#!/bin/bash -l +# SPDX-License-Identifier: EPL-1.0 +############################################################################## +# Copyright (c) 2017 The Linux Foundation and others. +# +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Eclipse Public License v1.0 +# which accompanies this distribution, and is available at +# http://www.eclipse.org/legal/epl-v10.html +############################################################################## -source $WORKSPACE/.venv-openstack/bin/activate +echo "----------> Copy ssh public keys to csit lab" function copy-ssh-keys-to-slave() { RETRIES=60 for j in $(seq 1 $RETRIES); do + # shellcheck disable=SC2006,SC2092 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' + 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." + + server=$(openstack port list -f value -c device_id --fixed-ip ip-address="${i}") + echo "Dumping console logs for $server ${i}" + openstack console log show "$server" + exit 1 else echo "SSH not responding on ${i}. Retrying in 10 seconds..." @@ -19,7 +33,7 @@ function copy-ssh-keys-to-slave() { fi # ping test to see if connectivity is available - if ping -c1 ${i} &> /dev/null; then + if ping -c1 "${i}" &> /dev/null; then echo "Ping to ${i} successful." else echo "Ping to ${i} failed." @@ -29,9 +43,10 @@ function copy-ssh-keys-to-slave() { # 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 +openstack stack show -c outputs "$STACK_NAME" -ADDR=(`openstack --os-cloud rackspace stack show -f json -c outputs $STACK_NAME | \ +# shellcheck disable=SC2006,SC2207 +ADDR=(`openstack stack show -f json -c outputs "$STACK_NAME" | \ jq -r '.outputs[] | \ select(.output_key | match("^vm_[0-9]+_ips\$")) | \ .output_value | .[]'`) @@ -44,7 +59,7 @@ done # 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."