4d0203bc46
The nodes in the OpenStack CI may already have the epel repo present but it could be disabled by default. As such, try to enable it as early as possible. Change-Id: Ib06f5aaf7f577d101b5b87f8cd81441380e56783
175 lines
4.9 KiB
Bash
175 lines
4.9 KiB
Bash
#!/bin/bash
|
|
set -eu
|
|
|
|
declare -A PKG_MAP
|
|
|
|
CHECK_CMD_PKGS=(
|
|
gcc
|
|
libffi
|
|
libopenssl
|
|
lsb-release
|
|
make
|
|
net-tools
|
|
python-devel
|
|
python
|
|
venv
|
|
wget
|
|
)
|
|
|
|
# Check zypper before apt-get in case zypper-aptitude
|
|
# is installed
|
|
if [ -x '/usr/bin/zypper' ]; then
|
|
OS_FAMILY="Suse"
|
|
INSTALLER_CMD="sudo -H -E zypper install -y --no-recommends"
|
|
CHECK_CMD="zypper search --match-exact --installed"
|
|
PKG_MAP=(
|
|
[gcc]=gcc
|
|
[libffi]=libffi-devel
|
|
[libopenssl]=libopenssl-devel
|
|
[lsb-release]=lsb-release
|
|
[make]=make
|
|
[net-tools]=net-tools
|
|
[python]=python
|
|
[python-devel]=python-devel
|
|
[venv]=python-virtualenv
|
|
[wget]=wget
|
|
)
|
|
EXTRA_PKG_DEPS=( python-xml )
|
|
# NOTE (cinerama): we can't install python without removing this package
|
|
# if it exists
|
|
if $(${CHECK_CMD} patterns-openSUSE-minimal_base-conflicts &> /dev/null); then
|
|
sudo -H zypper remove -y patterns-openSUSE-minimal_base-conflicts
|
|
fi
|
|
elif [ -x '/usr/bin/apt-get' ]; then
|
|
OS_FAMILY="Debian"
|
|
INSTALLER_CMD="sudo -H -E apt-get -y install"
|
|
CHECK_CMD="dpkg -l"
|
|
PKG_MAP=(
|
|
[gcc]=gcc
|
|
[libffi]=libffi-dev
|
|
[libopenssl]=libssl-dev
|
|
[lsb-release]=lsb-release
|
|
[make]=make
|
|
[net-tools]=net-tools
|
|
[python]=python-minimal
|
|
[python-devel]=libpython-dev
|
|
[venv]=python-virtualenv
|
|
[wget]=wget
|
|
)
|
|
EXTRA_PKG_DEPS=()
|
|
elif [ -x '/usr/bin/dnf' ] || [ -x '/usr/bin/yum' ]; then
|
|
OS_FAMILY="RedHat"
|
|
PKG_MANAGER=$(which dnf || which yum)
|
|
INSTALLER_CMD="sudo -H -E ${PKG_MANAGER} -y install"
|
|
CHECK_CMD="rpm -q"
|
|
PKG_MAP=(
|
|
[gcc]=gcc
|
|
[libffi]=libffi-devel
|
|
[libopenssl]=openssl-devel
|
|
[lsb-release]=redhat-lsb
|
|
[make]=make
|
|
[net-tools]=net-tools
|
|
[python]=python
|
|
[python-devel]=python-devel
|
|
[venv]=python-virtualenv
|
|
[wget]=wget
|
|
)
|
|
EXTRA_PKG_DEPS=()
|
|
else
|
|
echo "ERROR: Supported package manager not found. Supported: apt, dnf, yum, zypper"
|
|
fi
|
|
|
|
# if running in OpenStack CI, then make sure epel is enabled
|
|
# since it may already be present (but disabled) on the host
|
|
if env | grep -q ^ZUUL; then
|
|
if [[ -x '/usr/bin/yum' ]]; then
|
|
${INSTALLER_CMD} yum-utils
|
|
sudo yum-config-manager --enable epel || true
|
|
fi
|
|
fi
|
|
|
|
if ! $(python --version &>/dev/null); then
|
|
${INSTALLER_CMD} ${PKG_MAP[python]}
|
|
fi
|
|
if ! $(gcc -v &>/dev/null); then
|
|
${INSTALLER_CMD} ${PKG_MAP[gcc]}
|
|
fi
|
|
if ! $(wget --version &>/dev/null); then
|
|
${INSTALLER_CMD} ${PKG_MAP[wget]}
|
|
fi
|
|
if [ -n "${VENV-}" ]; then
|
|
if ! $(python -m virtualenv --version &>/dev/null); then
|
|
${INSTALLER_CMD} ${PKG_MAP[venv]}
|
|
fi
|
|
fi
|
|
|
|
for pkg in ${CHECK_CMD_PKGS[@]}; do
|
|
if ! $(${CHECK_CMD} ${PKG_MAP[$pkg]} &>/dev/null); then
|
|
${INSTALLER_CMD} ${PKG_MAP[$pkg]}
|
|
fi
|
|
done
|
|
|
|
if [ -n "${EXTRA_PKG_DEPS-}" ]; then
|
|
for pkg in ${EXTRA_PKG_DEPS}; do
|
|
if ! $(${CHECK_CMD} ${pkg} &>/dev/null); then
|
|
${INSTALLER_CMD} ${pkg}
|
|
fi
|
|
done
|
|
fi
|
|
|
|
if [ -n "${VENV-}" ]; then
|
|
echo "NOTICE: Using virtualenv for this installation."
|
|
if [ ! -f ${VENV}/bin/activate ]; then
|
|
# only create venv if one doesn't exist
|
|
sudo -H -E python -m virtualenv --no-site-packages ${VENV}
|
|
fi
|
|
# Note(cinerama): activate is not compatible with "set -u";
|
|
# disable it just for this line.
|
|
set +u
|
|
source ${VENV}/bin/activate
|
|
set -u
|
|
VIRTUAL_ENV=${VENV}
|
|
else
|
|
echo "NOTICE: Not using virtualenv for this installation."
|
|
fi
|
|
|
|
# If we're using a venv, we need to work around sudo not
|
|
# keeping the path even with -E.
|
|
PYTHON=$(which python)
|
|
|
|
# To install python packages, we need pip.
|
|
#
|
|
# We can't use the apt packaged version of pip since
|
|
# older versions of pip are incompatible with
|
|
# requests, one of our indirect dependencies (bug 1459947).
|
|
#
|
|
# Note(cinerama): We use pip to install an updated pip plus our
|
|
# other python requirements. pip breakages can seriously impact us,
|
|
# so we've chosen to install/upgrade pip here rather than in
|
|
# requirements (which are synced automatically from the global ones)
|
|
# so we can quickly and easily adjust version parameters.
|
|
# See bug 1536627.
|
|
#
|
|
# Note(cinerama): If pip is linked to pip3, the rest of the install
|
|
# won't work. Remove the alternatives. This is due to ansible's
|
|
# python 2.x requirement.
|
|
if [[ $(readlink -f /etc/alternatives/pip) =~ "pip3" ]]; then
|
|
sudo -H update-alternatives --remove pip $(readlink -f /etc/alternatives/pip)
|
|
fi
|
|
|
|
if ! which pip; then
|
|
wget -O /tmp/get-pip.py https://bootstrap.pypa.io/get-pip.py
|
|
sudo -H -E ${PYTHON} /tmp/get-pip.py
|
|
fi
|
|
|
|
PIP=$(which pip)
|
|
|
|
sudo -H -E ${PIP} install "pip>6.0"
|
|
sudo -H -E ${PIP} install -r "$(dirname $0)/../requirements.txt"
|
|
|
|
# Install the rest of required packages using bindep
|
|
sudo -H -E ${PIP} install bindep
|
|
|
|
# bindep returns 1 if packages are missing
|
|
bindep -b &> /dev/null || ${INSTALLER_CMD} $(bindep -b)
|