X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=shell%2Fpython-tools-install.sh;h=578923c87ebabb40882157434fb85ff7d82d44eb;hb=b9eb4581940562effcf67863704a3ec2c47ceca0;hp=603fece47c74e973ae6990c5176228580265bc9d;hpb=573fe2c6a78b283ec118c988454595ccf187e850;p=releng%2Fglobal-jjb.git diff --git a/shell/python-tools-install.sh b/shell/python-tools-install.sh index 603fece4..578923c8 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. @@ -10,33 +10,12 @@ ############################################################################## echo "---> python-tools-install.sh" -set -eu -o pipefail +set -eufo pipefail -# Generate a list of 'pip' packages pre-build/post-build -# During post-build, perform a diff on the two lists and copy files to archive directory -echo "Listing pip packages" -pip_list_pre=/tmp/pip-list-pre.txt -pip_list_post=/tmp/pip-list-post.txt -pip_list_diffs=/tmp/pip-list-diffs.txt -if [[ -f $pip_list_pre ]]; then - pip list > $pip_list_post - echo "Compare pip packages before/after..." - if diff --suppress-common-lines $pip_list_pre $pip_list_post \ - | tee $pip_list_diffs; then - echo "No diffs" | tee $pip_list_diffs - fi - mkdir -p "$WORKSPACE/archives" - cp "$pip_list_pre" "$pip_list_post" "$pip_list_diffs" "$WORKSPACE/archives" - rm -rf "$pip_list_pre" "$pip_list_post" "$pip_list_diffs" - ls "$WORKSPACE/archives" - # Would just like to 'exit 0' here but we can't because the - # log-deploy.sh script is 'appended' to this file and it would not - # be executed. -else - pip list > "$pip_list_pre" - # These 'pip installs' only need to be executed during pre-build - - 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-XXXXXX) # Note: To test lftools master branch change the lftools configuration below in # the requirements file from "lftools[openstack]~=#.##.#" to @@ -44,19 +23,41 @@ else echo "Generating Requirements File" cat << 'EOF' > "$requirements_file" -lftools[openstack]~=0.26.2 -python-heatclient~=1.16.1 -python-openstackclient~=3.16.0 -dogpile.cache~=0.6.8 # Version 0.7.[01] seems to break openstackclient -more-itertools~=5.0.0 -niet~=1.4.2 # Extract values from yaml -tox>=3.7.0. # Tox 3.7 or greater is necessary for parallel mode support -yq~=2.7.2 +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 + +# PINNED INDIRECT DEPENDENCIES +# ============================ +# The libraries listed below should be considered workarounds and thus need +# to have a link to a JIRA and any relevant pkg versions and support packages +# necessary so that future maintainers of this file can make decisions to +# remove the workarounds in the future. +importlib-resources<2.0.0 # virtualenv 20.0.21 requires importlib-resources<2.0.0 (RELENG-2993) 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" + #Python 3.5 in Ubuntu 16.04 workaround + if [[ -f /etc/lsb-release ]]; then + # shellcheck disable=SC1091 + source /etc/lsb-release + if [[ $DISTRIB_RELEASE == "16.04" ]]; then + echo "WARNING: Python projects should move to Ubuntu 18.04 to continue receiving support" + echo "zipp==1.1.0" >> "$requirements_file" + fi + fi + # Use `python -m pip` to upgrade to the latest pip into user site-packages + python3 -m pip install --user --quiet --upgrade pip + python3 -m pip install --user --quiet --no-warn-script-location --upgrade setuptools + python3 -m pip install --user --quiet --no-warn-script-location --upgrade --upgrade-strategy eager -r "$requirements_file" + # installs are silent, show version details in log + python3 --version + python3 -m pip --version + python3 -m pip freeze rm -rf "$requirements_file" + touch /tmp/pre-build-complete fi