Avoid tox_install.sh for constraints support
We do not need tox_install.sh, pip can handle constraints itself and install the project correctly. Thus update tox.ini and remove the now obsolete tools/tox_install.sh file. This follows https://review.openstack.org/#/c/508061 to remove tools/tox_install.sh. tox_install.sh was also building ovs for functional test. Move this into tools/setup-ovs.sh and call it from functional tox environment. Change-Id: I5857c8ae3e945328c0f24bda37629ce7e0faefa7
This commit is contained in:
parent
124b52c425
commit
163ee83ce8
11
tools/setup-ovs.sh
Executable file
11
tools/setup-ovs.sh
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash -xe
|
||||||
|
|
||||||
|
# We require at least OVS 2.7. Testing infrastructure doesn't support it yet,
|
||||||
|
# so build it. Eventually, we should run some checks to see what is actually
|
||||||
|
# installed and see if we can use it instead.
|
||||||
|
if [ "$OVS_SRCDIR" -a ! -d "$OVS_SRCDIR" ]; then
|
||||||
|
echo "Building OVS in $OVS_SRCDIR"
|
||||||
|
mkdir -p $OVS_SRCDIR
|
||||||
|
git clone git://github.com/openvswitch/ovs.git $OVS_SRCDIR
|
||||||
|
(cd $OVS_SRCDIR && ./boot.sh && PYTHON=/usr/bin/python ./configure && make -j$(($(nproc) + 1)))
|
||||||
|
fi
|
@ -1,61 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Library constraint file contains this library 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=ovsdbapp
|
|
||||||
requirements_installed=$(echo "import openstack_requirements" | python 2>/dev/null ; echo $?)
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
CONSTRAINTS_FILE=$1
|
|
||||||
shift
|
|
||||||
|
|
||||||
install_cmd="pip install"
|
|
||||||
mydir=$(mktemp -dt "$LIB_NAME-tox_install-XXXXXXX")
|
|
||||||
trap "rm -rf $mydir" EXIT
|
|
||||||
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 "Requirements already installed; using existing package"
|
|
||||||
elif [ -x "$ZUUL_CLONER" ]; then
|
|
||||||
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
|
|
||||||
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
|
|
||||||
|
|
||||||
# This is the main purpose of the script: Allow local installation of
|
|
||||||
# the current repo. It is listed in constraints file and thus any
|
|
||||||
# install will be constrained and we need to unconstrain it.
|
|
||||||
edit-constraints $localfile -- $LIB_NAME "-e file://$PWD#egg=$LIB_NAME"
|
|
||||||
|
|
||||||
# We require at least OVS 2.7. Testing infrastructure doesn't support it yet,
|
|
||||||
# so build it. Eventually, we should run some checks to see what is actually
|
|
||||||
# installed and see if we can use it instead.
|
|
||||||
if [ "$OVS_SRCDIR" -a ! -d "$OVS_SRCDIR" ]; then
|
|
||||||
echo "Building OVS in $OVS_SRCDIR"
|
|
||||||
mkdir -p $OVS_SRCDIR
|
|
||||||
git clone git://github.com/openvswitch/ovs.git $OVS_SRCDIR
|
|
||||||
(cd $OVS_SRCDIR && ./boot.sh && PYTHON=/usr/bin/python ./configure && make -j$(($(nproc) + 1)))
|
|
||||||
fi
|
|
||||||
$install_cmd -U $*
|
|
||||||
exit $?
|
|
11
tox.ini
11
tox.ini
@ -9,9 +9,11 @@ setenv =
|
|||||||
VIRTUAL_ENV={envdir}
|
VIRTUAL_ENV={envdir}
|
||||||
PYTHONWARNINGS=default::DeprecationWarning
|
PYTHONWARNINGS=default::DeprecationWarning
|
||||||
OS_TEST_PATH=./ovsdbapp/tests/unit
|
OS_TEST_PATH=./ovsdbapp/tests/unit
|
||||||
CLIENT_NAME=ovsdbapp
|
install_command = pip install {opts} {packages}
|
||||||
install_command = {toxinidir}/tools/tox_install.sh {env:UPPER_CONSTRAINTS_FILE:https://git.openstack.org/cgit/openstack/requirements/plain/upper-constraints.txt} {opts} {packages}
|
deps =
|
||||||
deps = -r{toxinidir}/test-requirements.txt
|
-c{env:UPPER_CONSTRAINTS_FILE:https://git.openstack.org/cgit/openstack/requirements/plain/upper-constraints.txt}
|
||||||
|
-r{toxinidir}/test-requirements.txt
|
||||||
|
-r{toxinidir}/requirements.txt
|
||||||
commands = python setup.py testr --slowest --testr-args='{posargs}'
|
commands = python setup.py testr --slowest --testr-args='{posargs}'
|
||||||
|
|
||||||
[testenv:pep8]
|
[testenv:pep8]
|
||||||
@ -39,6 +41,9 @@ setenv = {[testenv]setenv}
|
|||||||
OS_TEST_PATH=./ovsdbapp/tests/functional
|
OS_TEST_PATH=./ovsdbapp/tests/functional
|
||||||
OVS_SRCDIR={envdir}/src/ovs
|
OVS_SRCDIR={envdir}/src/ovs
|
||||||
passenv = KEEP_VENV
|
passenv = KEEP_VENV
|
||||||
|
commands =
|
||||||
|
{toxinidir}/tools/setup-ovs.sh
|
||||||
|
{[testenv]commands}
|
||||||
|
|
||||||
[flake8]
|
[flake8]
|
||||||
# E123, E125 skipped as they are invalid PEP-8.
|
# E123, E125 skipped as they are invalid PEP-8.
|
||||||
|
Loading…
Reference in New Issue
Block a user