X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=shell%2Fpython-tools-install.sh;h=b908e170bacd510b57731f14e9c557b94137b675;hb=568b22ef45e66def2e9b3361b3d438fd5b32fd97;hp=4506062c3ba14797b58dfd56b14f400dea97e52b;hpb=629c7f5421eb198902cbed38ecafe3411782f037;p=releng%2Fglobal-jjb.git diff --git a/shell/python-tools-install.sh b/shell/python-tools-install.sh index 4506062c..b908e170 100644 --- a/shell/python-tools-install.sh +++ b/shell/python-tools-install.sh @@ -1,4 +1,4 @@ -#!/bin/bash -l +#!/bin/bash # SPDX-License-Identifier: EPL-1.0 ############################################################################## # Copyright (c) 2018 The Linux Foundation and others. @@ -8,19 +8,36 @@ # which accompanies this distribution, and is available at # http://www.eclipse.org/legal/epl-v10.html ############################################################################## +echo "---> python-tools-install.sh" -set -eux -o pipefail +set -eufo pipefail -REQUIREMENTS_FILE=$(mktemp /tmp/requirements-XXXX.txt) +# This script will typically be called during pre-build & post-build. +# Create the user venv during pre-build. +if [[ ! -f /tmp/pre-build-complete ]]; then + requirements_file=$(mktemp /tmp/requirements-XXXX.txt) -cat << EOF > "$REQUIREMENTS_FILE" -lftools[openstack]~=0.18.0 -python-heatclient~=1.16.1 -python-openstackclient~=3.16.0 + # Note: To test lftools master branch change the lftools configuration below in + # the requirements file from "lftools[openstack]~=#.##.#" to + # git+https://github.com/lfit/releng-lftools.git#egg=lftools[openstack] + + echo "Generating Requirements File" + cat << 'EOF' > "$requirements_file" +lftools[openstack] +python-heatclient +python-openstackclient +python-magnumclient +kubernetes +niet~=1.4.2 +tox>=3.7.0 # Tox 3.7 or greater is necessary for parallel mode support +yq EOF -# Use `python -m pip` to ensure we are using the latest version of pip -python -m pip install --user --quiet --upgrade pip -python -m pip install --user --quiet --upgrade setuptools -python -m pip install --user --quiet --upgrade -r "$REQUIREMENTS_FILE" -pip freeze + # Use `python -m pip` to ensure we are using pip from user venv + python3 -m venv ~/.local + python3 -m pip install --user --quiet --upgrade pip + python3 -m pip install --user --quiet --upgrade setuptools + python3 -m pip install --user --quiet --upgrade --upgrade-strategy eager -r "$requirements_file" + rm -rf "$requirements_file" + touch /tmp/pre-build-complete +fi