summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorNikhil Komawar <nik.komawar@gmail.com>2016-06-02 13:36:37 -0400
committerIan Cordasco <graffatcolmingov@gmail.com>2016-06-03 11:59:23 -0500
commitea4483c0bfb39a39d6d4c4634d04cbfaca4de7f5 (patch)
treeda05a710237aa1bda2b6d8289b494087c2402704 /tools
parent9a588122aabf96a1e8dfa14abcb93c65431557fc (diff)
downloadglance_store-ea4483c0bfb39a39d6d4c4634d04cbfaca4de7f5.tar.gz
tox respects upper-constraints.txt
This will force pip install to use the upper-constraints.txt specified version of pip modules. When you don't do this, you are out on the bleeding edge and become unstable everytime some python library in the wide world changes in a way that you don't expect. There are a few 'post' jobs as Andreas has mentioned on this review, that have the install_command overridden (until that will be supported in upstream infra). This change has been inspired by Ie1133e4c020106e8098685ba9125f84b356d8e0c , notes from jaegerandi in the openstack/glance's tox.ini file and Ihar's python-neutronclient's fix I33302cdcab980a42c39dc9ec1e430add459615ff Change-Id: I1f8be8184683c9a3671f750ebaa87c38163c9795 Closes-Bug: 1563038
Diffstat (limited to 'tools')
-rwxr-xr-xtools/tox_install.sh55
1 files changed, 55 insertions, 0 deletions
diff --git a/tools/tox_install.sh b/tools/tox_install.sh
new file mode 100755
index 0000000..90beef8
--- /dev/null
+++ b/tools/tox_install.sh
@@ -0,0 +1,55 @@
+#!/usr/bin/env bash
+
+# Library constraint file contains version pin that is in conflict with
+# installing the library from source. We should replace the version pin in
+# the constraints file before applying it for from-source installation.
+
+ZUUL_CLONER=/usr/zuul-env/bin/zuul-cloner
+BRANCH_NAME=master
+LIB_NAME=glance_store
+requirements_installed=$(echo "import openstack_requirements" | python 2>/dev/null ; echo $?)
+
+set -e
+
+CONSTRAINTS_FILE=$1
+shift
+
+install_cmd="pip install"
+if [ $CONSTRAINTS_FILE != "unconstrained" ]; then
+
+ mydir=$(mktemp -dt "$LIB_NAME-tox_install-XXXXXXX")
+ localfile=$mydir/upper-constraints.txt
+ if [[ $CONSTRAINTS_FILE != http* ]]; then
+ CONSTRAINTS_FILE=file://$CONSTRAINTS_FILE
+ fi
+ curl $CONSTRAINTS_FILE -k -o $localfile
+ install_cmd="$install_cmd -c$localfile"
+
+ if [ $requirements_installed -eq 0 ]; then
+ echo "ALREADY INSTALLED" > /tmp/tox_install.txt
+ echo "Requirements already installed; using existing package"
+ elif [ -x "$ZUUL_CLONER" ]; then
+ export ZUUL_BRANCH=${ZUUL_BRANCH-$BRANCH}
+ echo "ZUUL CLONER" > /tmp/tox_install.txt
+ pushd $mydir
+ $ZUUL_CLONER --cache-dir \
+ /opt/git \
+ --branch $BRANCH_NAME \
+ git://git.openstack.org \
+ openstack/requirements
+ cd openstack/requirements
+ $install_cmd -e .
+ popd
+ else
+ echo "PIP HARDCODE" > /tmp/tox_install.txt
+ if [ -z "$REQUIREMENTS_PIP_LOCATION" ]; then
+ REQUIREMENTS_PIP_LOCATION="git+https://git.openstack.org/openstack/requirements@$BRANCH_NAME#egg=requirements"
+ fi
+ $install_cmd -U -e ${REQUIREMENTS_PIP_LOCATION}
+ fi
+
+ edit-constraints $localfile -- $LIB_NAME "-e file://$PWD#egg=$LIB_NAME"
+fi
+
+$install_cmd -U $*
+exit $?