1
0
mirror of https://github.com/TREX-CoE/trexio.git synced 2025-01-05 11:00:30 +01:00

more flexible build_manylinux_wheels bash script

This commit is contained in:
q-posev 2021-09-14 17:28:05 +02:00
parent 264faf9c74
commit 816fe72949

View File

@ -6,38 +6,9 @@ set -e
export H5_LDFLAGS=-L/usr/local/lib export H5_LDFLAGS=-L/usr/local/lib
export H5_CFLAGS=-I/usr/local/include export H5_CFLAGS=-I/usr/local/include
# install emacs for Debian
#apt-get update # build wheel directly from developer-provided .tar.gz of TREXIO (generated with `python setup.py sdist`)
#apt install software-properties-common -y # note: trexio-VERSION.tar.gz has to be in the root directory of the host machine and provided as an argument to this script
#apt-get install wget -y
#wget -q http://emacs.ganneff.de/apt.key -O- | apt-key add
#add-apt-repository "deb http://emacs.ganneff.de/ stretch main"
#apt-get update
#apt-get install emacs-snapshot -y
#update-alternatives --config emacsclient
# ===============================
# install TREXIO in the container from the GitHub repo clone
#apt-get install git -y
#git clone https://github.com/TREX-CoE/trexio.git
#cd trexio
#git checkout swig-python
#./autogen.sh
#TREXIO_DEVEL=1 ./configure --enable-silent-rules
#make
#make check
# ===============================
# alternatively: build wheel directly from developer-provided .tar.gz of TREXIO (generated with `python setup.py sdist`)
# note: trexio-VERSION.tar.gz has to be in the root directory of the host machine
# process input: first argument is the name of the .tar.gz with the source code of the Python API # process input: first argument is the name of the .tar.gz with the source code of the Python API
if [[ -z "$1" ]]; then if [[ -z "$1" ]]; then
@ -45,144 +16,80 @@ if [[ -z "$1" ]]; then
exit 1 exit 1
fi fi
# derive TREXIO version from the file name
TREXIO_SOURCE=${1} TREXIO_SOURCE=${1}
# remove prefix that ends with "-" # remove prefix that ends with "-"
tmp=${TREXIO_SOURCE#*-} tmp=${TREXIO_SOURCE#*-}
# remove suffix that ends with ".tar.gz" # remove suffix that ends with ".tar.gz"
TR_VERSION=${tmp%.tar.gz*} TR_VERSION=${tmp%.tar.gz*}
# print the computed version
echo "TREXIO VERSION:" ${TR_VERSION} echo "TREXIO VERSION:" ${TR_VERSION}
# unzip and enter the folder with TREXIO Python API # unzip and enter the folder with TREXIO Python API
gzip -cd /tmp/trexio-${TR_VERSION}.tar.gz | tar xvf - gzip -cd /tmp/trexio-${TR_VERSION}.tar.gz | tar xvf -
cd trexio-${TR_VERSION} cd trexio-${TR_VERSION}
# create and activate a virtual environment based on CPython version 3.6 # the function below build manylinux wheels based on the provided version of python (e.g. build_wheel_for_py 36)
/opt/python/cp36-cp36m/bin/python3 -m venv --clear trexio-manylinux-py36 function build_wheel_for_py()
source trexio-manylinux-py36/bin/activate {
python3 --version
# upgrade pip, otherwise it complains that manylinux wheel is "...not supported wheel on this platform" if [[ -z "$1" ]]; then
pip install --upgrade pip echo "Empty string provided instead of the Python version"
# install dependencies needed to build manylinux wheel exit 1
pip install --upgrade setuptools wheel auditwheel numpy fi
# set an environment variable needed to locate numpy header files # derive PYVERSION from the input argument
source tools/set_NUMPY_INCLUDEDIR.sh PYVERSION=${1}
# produce conventional (non-manylinux) wheel # python versions <= 3.7 required additional "m" in the platform tag, e.g. cp37-cp37m
python3 setup.py bdist_wheel if [[ ${PYVERSION} -eq 36 ]] || [[ ${PYVERSION} -eq 37 ]]; then
PYM="m"
else
PYM=""
fi
# use auditwheel from PyPA to repair all wheels and make them manylinux-compatible CPYTHON="cp${PYVERSION}-cp${PYVERSION}${PYM}"
auditwheel repair dist/trexio-${TR_VERSION}-cp36-cp36m-*.whl
# install the produced manylinux wheel in the virtual environment # create and activate a virtual environment based on CPython version ${PYVERSION}
python3 -m pip install wheelhouse/trexio-${TR_VERSION}-cp36-cp36m-manylinux*.whl /opt/python/${CPYTHON}/bin/python3 -m venv --clear trexio-manylinux-py${PYVERSION}
source trexio-manylinux-py${PYVERSION}/bin/activate
python3 --version
# run test script # upgrade pip, otherwise it complains that manylinux wheel is "...not supported wheel on this platform"
cd test && python3 test_api.py && cd .. pip install --upgrade pip
# install dependencies needed to build manylinux wheel
pip install --upgrade setuptools wheel auditwheel numpy
# cleaning # set an environment variable needed to locate numpy header files
rm -rf -- dist/ build/ trexio.egg-info/ source tools/set_NUMPY_INCLUDEDIR.sh
# deactivate the current environment # produce conventional (non-manylinux) wheel
deactivate python3 setup.py bdist_wheel
# create and activate a virtual environment based on CPython version 3.7 # use auditwheel from PyPA to repair all wheels and make them manylinux-compatible
/opt/python/cp37-cp37m/bin/python3 -m venv --clear trexio-manylinux-py37 auditwheel repair dist/trexio-${TR_VERSION}-${CPYTHON}-*.whl
source trexio-manylinux-py37/bin/activate
python3 --version
# upgrade pip, otherwise it complains that manylinux wheel is "...not supported wheel on this platform" # install the produced manylinux wheel in the virtual environment
pip install --upgrade pip python3 -m pip install wheelhouse/trexio-${TR_VERSION}-${CPYTHON}-manylinux*.whl
# install dependencies needed to build manylinux wheel
pip install --upgrade setuptools wheel auditwheel numpy
# set an environment variable needed to locate numpy header files # run test script
source tools/set_NUMPY_INCLUDEDIR.sh cd test && python3 test_api.py && cd ..
# produce conventional (non-manylinux) wheel # cleaning
python3 setup.py bdist_wheel rm -rf -- dist/ build/ trexio.egg-info/
# use auditwheel from PyPA to repair all wheels and make them manylinux-compatible # deactivate the current environment
auditwheel repair dist/trexio-${TR_VERSION}-cp37-cp37m-*.whl deactivate
# install the produced manylinux wheel in the virtual environment # remove the virtual environment
python3 -m pip install wheelhouse/trexio-${TR_VERSION}-cp37-cp37m-manylinux*.whl rm -rf -- trexio-manylinux-py${PYVERSION}
# run test script }
cd test && python3 test_api.py && cd ..
# cleaning
rm -rf -- dist/ build/ trexio.egg-info/
# deactivate the current environment # build wheels for all versions of CPython in this container
deactivate for CPYVERSION in 36 37 38 39
do
# create and activate a virtual environment based on CPython version 3.8 build_wheel_for_py ${CPYVERSION}
# NOTE: starting from CPython 3.8 there is no need to add m in the abi-tag, e.g. use cp38-cp38 instead of cp38-cp38m done
/opt/python/cp38-cp38/bin/python3 -m venv --clear trexio-manylinux-py38
source trexio-manylinux-py38/bin/activate
python3 --version
# upgrade pip, otherwise it complains that manylinux wheel is "...not supported wheel on this platform"
pip install --upgrade pip
# install dependencies needed to build manylinux wheel
pip3 install --upgrade setuptools wheel auditwheel numpy
# set an environment variable needed to locate numpy header files
source tools/set_NUMPY_INCLUDEDIR.sh
# produce conventional (non-manylinux) wheel
python3 setup.py bdist_wheel
# use auditwheel from PyPA to repair all wheels and make them manylinux-compatible
auditwheel repair dist/trexio-${TR_VERSION}-cp38-cp38-*.whl
# install the produced manylinux wheel in the virtual environment
python3 -m pip install wheelhouse/trexio-${TR_VERSION}-cp38-cp38-manylinux*.whl
# run test script
cd test && python3 test_api.py && cd ..
# cleaning
rm -rf -- dist/ build/ trexio.egg-info/
# deactivate the current environment
deactivate
# create and activate a virtual environment based on CPython version 3.8
/opt/python/cp39-cp39/bin/python3 -m venv --clear trexio-manylinux-py39
source trexio-manylinux-py39/bin/activate
python3 --version
# upgrade pip, otherwise it complains that manylinux wheel is "...not supported wheel on this platform"
pip install --upgrade pip
# install dependencies needed to build manylinux wheel
pip3 install --upgrade setuptools wheel auditwheel numpy
# produce conventional (non-manylinux) wheel
python3 setup.py bdist_wheel
# use auditwheel from PyPA to repair all wheels and make them manylinux-compatible
auditwheel repair dist/trexio-${TR_VERSION}-cp39-cp39-*.whl
# install the produced manylinux wheel in the virtual environment
python3 -m pip install wheelhouse/trexio-${TR_VERSION}-cp39-cp39-manylinux*.whl
# run test script
cd test && python3 test_api.py && cd ..
# cleaning
rm -rf -- dist/ build/ trexio.egg-info/
# deactivate the current environment
deactivate
# remove all virtual environments used to produce the wheels
rm -rf -- trexio-manylinux-py39 \
trexio-manylinux-py38 \
trexio-manylinux-py37 \
trexio-manylinux-py36