#!/bin/bash -xe # Copyright (C) 2014 Hewlett-Packard Development Company, L.P. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or # implied. # # See the License for the specific language governing permissions and # limitations under the License. if [ -f /etc/dib-builddate.txt ]; then echo "Image build date" echo "================" cat /etc/dib-builddate.txt fi source /etc/nodepool/provider NODEPOOL_MIRROR_HOST=${NODEPOOL_MIRROR_HOST:-mirror.$NODEPOOL_REGION.$NODEPOOL_CLOUD.openstack.org} NODEPOOL_MIRROR_HOST=$(echo $NODEPOOL_MIRROR_HOST|tr '[:upper:]' '[:lower:]') # Double check that when the node is made ready it is able # to resolve names against DNS. # NOTE(pabelanger): Because it is possible for nodepool to SSH into a node but # DNS has not been fully started, we try up to 300 seconds (10 attempts) to # resolve DNS once. for COUNT in {1..10}; do set +e host -W 30 git.openstack.org res=$? set -e if [ $res == 0 ]; then break elif [ $COUNT == 10 ]; then exit 1 fi done host $NODEPOOL_MIRROR_HOST # Generate the AFS Slug from the host system. source /usr/local/jenkins/slave_scripts/afs-slug.sh LSBDISTID=$(lsb_release -is) LSBDISTCODENAME=$(lsb_release -cs) NODEPOOL_DEBIAN_MIRROR=${NODEPOOL_DEBIAN_MIRROR:-http://$NODEPOOL_MIRROR_HOST/debian} NODEPOOL_PYPI_MIRROR=${NODEPOOL_PYPI_MIRROR:-http://$NODEPOOL_MIRROR_HOST/pypi/simple} NODEPOOL_WHEEL_MIRROR=${NODEPOOL_WHEEL_MIRROR:-http://$NODEPOOL_MIRROR_HOST/wheel/$AFS_SLUG} NODEPOOL_UBUNTU_MIRROR=${NODEPOOL_UBUNTU_MIRROR:-http://$NODEPOOL_MIRROR_HOST/ubuntu} NODEPOOL_CENTOS_MIRROR=${NODEPOOL_CENTOS_MIRROR:-http://$NODEPOOL_MIRROR_HOST/centos} NODEPOOL_DEBIAN_OPENSTACK_MIRROR=${NODEPOOL_DEBIAN_OPENSTACK_MIRROR:-http://$NODEPOOL_MIRROR_HOST/debian-openstack} NODEPOOL_EPEL_MIRROR=${NODEPOOL_EPEL_MIRROR:-http://$NODEPOOL_MIRROR_HOST/epel} NODEPOOL_CEPH_MIRROR=${NODEPOOL_CEPH_MIRROR:-http://$NODEPOOL_MIRROR_HOST/ceph-deb-hammer} NODEPOOL_UCA_MIRROR=${NODEPOOL_UCA_MIRROR:-http://$NODEPOOL_MIRROR_HOST/ubuntu-cloud-archive} NODEPOOL_NPM_MIRROR=${NODEPOOL_NPM_MIRROR:-http://$NODEPOOL_MIRROR_HOST/npm/} PIP_CONF="\ [global] timeout = 60 index-url = $NODEPOOL_PYPI_MIRROR trusted-host = $NODEPOOL_MIRROR_HOST extra-index-url = $NODEPOOL_WHEEL_MIRROR" PYDISTUTILS_CFG="\ [easy_install] index_url = $NODEPOOL_PYPI_MIRROR allow_hosts = *.openstack.org" NPMRC="\ registry = $NODEPOOL_NPM_MIRROR # Retry settings fetch-retries=10 # The number of times to retry getting a package. fetch-retry-mintimeout=60000 # Minimum fetch timeout: 1 minute (default 10 seconds) fetch-retry-maxtimeout=300000 # Maximum fetch timeout: 5 minute (default 1 minute)" UBUNTU_SOURCES_LIST="\ deb $NODEPOOL_UBUNTU_MIRROR $LSBDISTCODENAME main universe deb $NODEPOOL_UBUNTU_MIRROR $LSBDISTCODENAME-updates main universe deb $NODEPOOL_UBUNTU_MIRROR $LSBDISTCODENAME-backports main universe deb $NODEPOOL_UBUNTU_MIRROR $LSBDISTCODENAME-security main universe" CEPH_SOURCES_LIST="deb $NODEPOOL_CEPH_MIRROR $LSBDISTCODENAME main" UCA_SOURCES_LIST="deb $NODEPOOL_UCA_MIRROR $LSBDISTCODENAME-updates main" APT_CONF_UNAUTHENTICATED="APT::Get::AllowUnauthenticated \"true\";" DEBIAN_DEFAULT_SOURCES_LIST="\ deb $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME main deb-src $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME main" DEBIAN_UPDATES_SOURCES_LIST="\ deb $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME-updates main deb-src $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME-updates main" DEBIAN_BACKPORTS_SOURCES_LIST="\ deb $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME-backports main deb-src $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME-backports main" DEBIAN_SECURITY_SOURCES_LIST="\ deb $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME-security main deb-src $NODEPOOL_DEBIAN_MIRROR $LSBDISTCODENAME-security main" DEBIAN_OPENSTACK_NEWTON_SOURCES_LIST="\ deb $NODEPOOL_DEBIAN_OPENSTACK_MIRROR $LSBDISTCODENAME-newton main deb $NODEPOOL_DEBIAN_OPENSTACK_MIRROR $LSBDISTCODENAME-newton-backports main" YUM_REPOS_CENTOS_BASE="\ [base] name=CentOS-\$releasever - Base baseurl=$NODEPOOL_CENTOS_MIRROR/\$releasever/os/\$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-\$releasever #released updates [updates] name=CentOS-\$releasever - Updates baseurl=$NODEPOOL_CENTOS_MIRROR/\$releasever/updates/\$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-\$releasever #additional packages that may be useful [extras] name=CentOS-\$releasever - Extras baseurl=$NODEPOOL_CENTOS_MIRROR/\$releasever/extras/\$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-\$releasever" YUM_REPOS_EPEL="\ [epel] name=Extra Packages for Enterprise Linux \$releasever - \$basearch baseurl=$NODEPOOL_EPEL_MIRROR/\$releasever/\$basearch failovermethod=priority enabled=1 gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-\$releasever" # Write global pip configuration echo "$PIP_CONF" >/tmp/pip.conf sudo mv /tmp/pip.conf /etc/ sudo chown root:root /etc/pip.conf sudo chmod 0644 /etc/pip.conf # Write jenkins user distutils/setuptools configuration used by easy_install echo "$PYDISTUTILS_CFG" >/home/jenkins/.pydistutils.cfg # Write jenkins user npm configuration echo "$NPMRC" >/home/jenkins/.npmrc # NOTE(pabelanger): We don't actually have mirrors for ubuntu-precise, so skip # them. if [ "$LSBDISTID" == "Ubuntu" ] && [ "$LSBDISTCODENAME" != 'precise' ]; then echo "$UBUNTU_SOURCES_LIST" >/tmp/sources.list sudo mv /tmp/sources.list /etc/apt/ sudo chown root:root /etc/apt/sources.list sudo chmod 0644 /etc/apt/sources.list # Opt in repos. Jobs that want to take advantage of them can copy or # symlink them into /etc/apt/sources.list.d/ sudo mkdir -p /etc/apt/sources.list.available.d # Ceph echo "$CEPH_SOURCES_LIST" >/tmp/ceph-deb-hammer.list sudo mv /tmp/ceph-deb-hammer.list /etc/apt/sources.list.available.d/ # Ubuntu Cloud Archive echo "$UCA_SOURCES_LIST" >/tmp/ubuntu-cloud-archive.list sudo mv /tmp/ubuntu-cloud-archive.list /etc/apt/sources.list.available.d/ sudo chown root:root /etc/apt/sources.list.available.d/* sudo chmod 0644 /etc/apt/sources.list.available.d/* if [ "$LSBDISTCODENAME" != 'precise' ] ; then # Turn off multi-arch sudo dpkg --remove-architecture i386 fi # Turn off checking of GPG signatures echo "$APT_CONF_UNAUTHENTICATED" >/tmp/99unauthenticated sudo mv /tmp/99unauthenticated /etc/apt/apt.conf.d/ sudo chown root:root /etc/apt/apt.conf.d/99unauthenticated sudo chmod 0644 /etc/apt/apt.conf.d/99unauthenticated elif [ "$LSBDISTID" == "Debian" ] ; then echo "$DEBIAN_DEFAULT_SOURCES_LIST" >/tmp/default.list sudo mv /tmp/default.list /etc/apt/sources.list.d/ echo "$DEBIAN_UPDATES_SOURCES_LIST" >/tmp/updates.list sudo mv /tmp/updates.list /etc/apt/sources.list.d/ echo "$DEBIAN_BACKPORTS_SOURCES_LIST" >/tmp/backports.list sudo mv /tmp/backports.list /etc/apt/sources.list.d/ echo "$DEBIAN_SECURITY_SOURCES_LIST" >/tmp/security.list sudo mv /tmp/security.list /etc/apt/sources.list.d/ sudo chown root:root /etc/apt/sources.list.d/*.list sudo chmod 0644 /etc/apt/sources.list.d/*.list # Opt in repos. Jobs that want to take advantage of them can copy or # symlink them into /etc/apt/sources.list.d/ sudo mkdir -p /etc/apt/sources.list.available.d # Debian OpenStack Newton echo "$DEBIAN_OPENSTACK_NEWTON_SOURCES_LIST" >/tmp/debian-openstack-newton.list sudo mv /tmp/debian-openstack-newton.list /etc/apt/sources.list.available.d/ sudo chown root:root /etc/apt/sources.list.available.d/* sudo chmod 0644 /etc/apt/sources.list.available.d/* # Turn off checking of GPG signatures echo "$APT_CONF_UNAUTHENTICATED" >/tmp/99unauthenticated sudo mv /tmp/99unauthenticated /etc/apt/apt.conf.d/ sudo chown root:root /etc/apt/apt.conf.d/99unauthenticated sudo chmod 0644 /etc/apt/apt.conf.d/99unauthenticated elif [ "$LSBDISTID" == "CentOS" ]; then echo "$YUM_REPOS_CENTOS_BASE" >/tmp/CentOS-Base.repo sudo mv /tmp/CentOS-Base.repo /etc/yum.repos.d/ echo "$YUM_REPOS_EPEL" >/tmp/epel.repo sudo mv /tmp/epel.repo /etc/yum.repos.d/ sudo chown root:root /etc/yum.repos.d/* sudo chmod 0644 /etc/yum.repos.d/* fi