Merge "Build wheel cache for venvs"
This commit is contained in:
commit
37e03c906b
4
clean.sh
4
clean.sh
@ -119,6 +119,10 @@ if [[ -n "$SCREEN_LOGDIR" ]] && [[ -d "$SCREEN_LOGDIR" ]]; then
|
||||
sudo rm -rf $SCREEN_LOGDIR
|
||||
fi
|
||||
|
||||
# Clean up venvs
|
||||
DIRS_TO_CLEAN="$WHEELHOUSE"
|
||||
rm -rf $DIRS_TO_CLEAN
|
||||
|
||||
# Clean up files
|
||||
|
||||
FILES_TO_CLEAN=".localrc.auto docs/files docs/html shocco/ stack-screenrc test*.conf* test.ini*"
|
||||
|
7
files/debs/devlibs
Normal file
7
files/debs/devlibs
Normal file
@ -0,0 +1,7 @@
|
||||
libffi-dev # pyOpenSSL
|
||||
libmysqlclient-dev # MySQL-python
|
||||
libpq-dev # psycopg2
|
||||
libssl-dev # pyOpenSSL
|
||||
libxml2-dev # lxml
|
||||
libxslt1-dev # lxml
|
||||
python-dev # pyOpenSSL
|
@ -1 +0,0 @@
|
||||
python-psycopg2
|
6
files/rpms-suse/devlibs
Normal file
6
files/rpms-suse/devlibs
Normal file
@ -0,0 +1,6 @@
|
||||
libffi-devel # pyOpenSSL
|
||||
libopenssl-devel # pyOpenSSL
|
||||
libxml2-devel # lxml
|
||||
libxslt1-dev # lxml
|
||||
postgresql-devel # psycopg2
|
||||
python-devel # pyOpenSSL
|
@ -1 +0,0 @@
|
||||
python-psycopg2
|
8
files/rpms/devlibs
Normal file
8
files/rpms/devlibs
Normal file
@ -0,0 +1,8 @@
|
||||
libffi-devel # pyOpenSSL
|
||||
libxml2-devel # lxml
|
||||
libxslt1-devel # lxml
|
||||
mariadb-devel # MySQL-python f20,f21,rhel7
|
||||
mysql-devel # MySQL-python rhel6
|
||||
openssl-devel # pyOpenSSL
|
||||
postgresql-devel # psycopg2
|
||||
python-devel # pyOpenSSL
|
@ -1 +0,0 @@
|
||||
python-psycopg2
|
10
files/venv-requirements.txt
Normal file
10
files/venv-requirements.txt
Normal file
@ -0,0 +1,10 @@
|
||||
lxml
|
||||
MySQL-python
|
||||
netifaces
|
||||
numpy
|
||||
posix-ipc
|
||||
psycopg2
|
||||
pycrypto
|
||||
pyOpenSSL
|
||||
PyYAML
|
||||
xattr
|
@ -151,6 +151,9 @@ EOF
|
||||
else
|
||||
exit_distro_not_supported "mysql installation"
|
||||
fi
|
||||
|
||||
# Install Python client module
|
||||
pip_install MySQL-python
|
||||
}
|
||||
|
||||
function database_connection_url_mysql {
|
||||
|
@ -100,6 +100,9 @@ EOF
|
||||
else
|
||||
exit_distro_not_supported "postgresql installation"
|
||||
fi
|
||||
|
||||
# Install Python client module
|
||||
pip_install MySQL-python psycopg2
|
||||
}
|
||||
|
||||
function database_connection_url_postgresql {
|
||||
|
15
stack.sh
15
stack.sh
@ -671,6 +671,21 @@ fi
|
||||
source $TOP_DIR/tools/fixup_stuff.sh
|
||||
|
||||
|
||||
# Virtual Environment
|
||||
# -------------------
|
||||
|
||||
# Temporary hack for testing
|
||||
# This belongs in d-g functions.sh setup_host() or devstack-vm-gate.sh
|
||||
if [[ -d /var/cache/pip ]]; then
|
||||
sudo chown -R $STACK_USER:$STACK_USER /var/cache/pip
|
||||
fi
|
||||
|
||||
# Pre-build some problematic wheels
|
||||
if [[ ! -d ${WHEELHOUSE:-} ]]; then
|
||||
source tools/build_wheels.sh
|
||||
fi
|
||||
|
||||
|
||||
# Extras Pre-install
|
||||
# ------------------
|
||||
|
||||
|
5
stackrc
5
stackrc
@ -112,6 +112,11 @@ elif [[ -f $RC_DIR/.localrc.auto ]]; then
|
||||
source $RC_DIR/.localrc.auto
|
||||
fi
|
||||
|
||||
# Configure wheel cache location
|
||||
export WHEELHOUSE=${WHEELHOUSE:-$DEST/.wheelhouse}
|
||||
export PIP_WHEEL_DIR=${PIP_WHEEL_DIR:-$WHEELHOUSE}
|
||||
export PIP_FIND_LINKS=${PIP_FIND_LINKS:-file://$WHEELHOUSE}
|
||||
|
||||
# This can be used to turn database query logging on and off
|
||||
# (currently only implemented for MySQL backend)
|
||||
DATABASE_QUERY_LOGGING=$(trueorfalse True DATABASE_QUERY_LOGGING)
|
||||
|
77
tools/build_wheels.sh
Executable file
77
tools/build_wheels.sh
Executable file
@ -0,0 +1,77 @@
|
||||
#!/usr/bin/env bash
|
||||
#
|
||||
# **tools/build_wheels.sh** - Build a cache of Python wheels
|
||||
#
|
||||
# build_wheels.sh [package [...]]
|
||||
#
|
||||
# System package prerequisites listed in files/*/devlibs will be installed
|
||||
#
|
||||
# Builds wheels for all virtual env requirements listed in
|
||||
# ``venv-requirements.txt`` plus any supplied on the command line.
|
||||
#
|
||||
# Assumes ``tools/install_pip.sh`` has been run and a suitable pip/setuptools is available.
|
||||
|
||||
# If TOP_DIR is set we're being sourced rather than running stand-alone
|
||||
# or in a sub-shell
|
||||
if [[ -z "$TOP_DIR" ]]; then
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
|
||||
# Keep track of the devstack directory
|
||||
TOP_DIR=$(cd $(dirname "$0")/.. && pwd)
|
||||
FILES=$TOP_DIR/files
|
||||
|
||||
# Import common functions
|
||||
source $TOP_DIR/functions
|
||||
|
||||
GetDistro
|
||||
|
||||
source $TOP_DIR/stackrc
|
||||
|
||||
trap err_trap ERR
|
||||
|
||||
fi
|
||||
|
||||
# Get additional packages to build
|
||||
MORE_PACKAGES="$@"
|
||||
|
||||
# Set a fall-back default, assume that since this script is being called
|
||||
# package builds are to happen even if WHEELHOUSE is not configured
|
||||
export WHEELHOUSE=${WHEELHOUSE:-.wheelhouse}
|
||||
|
||||
# Exit on any errors so that errors don't compound
|
||||
function err_trap {
|
||||
local r=$?
|
||||
set +o xtrace
|
||||
|
||||
rm -rf $TMP_VENV_PATH
|
||||
|
||||
exit $r
|
||||
}
|
||||
|
||||
# Get system prereqs
|
||||
install_package $(get_packages devlibs)
|
||||
|
||||
# Get a modern ``virtualenv``
|
||||
pip_install virtualenv
|
||||
|
||||
# Prepare the workspace
|
||||
TMP_VENV_PATH=$(mktemp -d tmp-venv-XXXX)
|
||||
virtualenv $TMP_VENV_PATH
|
||||
|
||||
# Install modern pip and wheel
|
||||
$TMP_VENV_PATH/bin/pip install -U pip wheel
|
||||
|
||||
# VENV_PACKAGES is a list of packages we want to pre-install
|
||||
VENV_PACKAGE_FILE=$FILES/venv-requirements.txt
|
||||
if [[ -r $VENV_PACKAGE_FILE ]]; then
|
||||
VENV_PACKAGES=$(grep -v '^#' $VENV_PACKAGE_FILE)
|
||||
fi
|
||||
|
||||
for pkg in ${VENV_PACKAGES,/ } ${MORE_PACKAGES}; do
|
||||
$TMP_VENV_PATH/bin/pip wheel $pkg
|
||||
done
|
||||
|
||||
# Clean up wheel workspace
|
||||
rm -rf $TMP_VENV_PATH
|
Loading…
x
Reference in New Issue
Block a user