Skip to content

Commit

Permalink
Fixes to test framework and GitHub workflow
Browse files Browse the repository at this point in the history
After many tries, I think I finally manage to find the right combination of
tweaks to make pytest, tox, and GitHub actions to work.

This also adds caching of the librocksdb compilation, which is a very slow
step, and restricts building of wheels and other artifacts to run only when
pushing to main.
  • Loading branch information
NightTsarina committed Nov 12, 2021
1 parent 0828318 commit 9cbbea6
Show file tree
Hide file tree
Showing 4 changed files with 176 additions and 95 deletions.
152 changes: 60 additions & 92 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,128 +4,96 @@ name: 'Build'
on: ['push', 'pull_request']

jobs:
test:
name: 'Test'
# Build the RocksDB C library and cache the result.
librocksdb:
name: 'Build librocksdb'
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest]
#py_ver: ['3.7', '3.8', '3.9']
#rocksdb_ver: ['v6.14.6', 'v6.11.4', 'v5.17.2']
py_ver: ['3.9']
rocksdb_ver: ['v6.14.6']
rocksdb_ver: ['v6.14.6', 'v6.11.4']

steps:
- uses: actions/checkout@v2
name: 'Checkout source repository'

- uses: actions/setup-python@v2
name: 'Set up Python ${{ matrix.py_ver }}'
- uses: actions/cache@v2
id: cache-librocksdb
with:
python-version: ${{ matrix.py_ver }}
key: ${{ matrix.os }}-librocksdb-${{ matrix.rocksdb_ver }}
path: /opt/rocksdb
restore-keys: |
librocksdb-${{ matrix.os }}-
librocksdb-
- name: 'Install dependencies'
run: |
sudo apt install -y libsnappy-dev libbz2-dev liblz4-dev libz-dev libgflags-dev libzstd-dev
if: steps.cache-librocksdb.outputs.cache-hit != 'true'
run: >
sudo apt install -y libsnappy-dev libbz2-dev liblz4-dev libz-dev
libgflags-dev libzstd-dev
- name: 'Install RocksDB ${{ matrix.rocksdb_ver }}'
- name: 'Clone & build RocksDB ${{ matrix.rocksdb_ver }}'
if: steps.cache-librocksdb.outputs.cache-hit != 'true'
run: |
pushd /opt &&
git clone https://github.com/facebook/rocksdb &&
cd rocksdb &&
git reset --hard ${{ matrix.rocksdb_ver }} &&
CXXFLAGS='-flto -Os -s' PORTABLE=1 make shared_lib -j 4 &&
make shared_lib &&
sudo make install-shared &&
popd
- name: Install python-rocksdb
run: |
sudo python3 setup.py install
- name: Run tests
run: |
python3 setup.py test
build_wheels:
name: 'Build wheels'
runs-on: ubuntu-latest
test:
name: 'Build and test python-rocksdb'
needs: librocksdb
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest]
py_ver: ['3.7', '3.8', '3.9']
rocksdb_ver: ['v6.14.6', 'v6.11.4']

steps:
- uses: actions/checkout@v2
name: 'Checkout source repository'

- uses: actions/setup-python@v2
name: 'Set up Python 3.9'
with:
python-version: '3.9'

- name: 'Install cibuildwheel'
run: |
python3 -m pip install cibuildwheel==1.7.1
- name: 'Build wheels'
run: |
python3 -m cibuildwheel --output-dir dist
env:
ROCKSDB_VERSION: 'v6.14.6'
CIBW_MANYLINUX_X86_64_IMAGE: 'manylinux2014'
CIBW_BUILD: 'cp3*'
CIBW_SKIP: '*-manylinux_i686'
CIBW_TEST_REQUIRES: '.[test] pytest'
CIBW_TEST_COMMAND: 'python3 -m pytest {project}/rocksdb/tests'
CIBW_BEFORE_BUILD: |
yum install -y bzip2-devel lz4-devel snappy-devel zlib-devel &&
pushd /opt &&
git clone https://github.com/facebook/rocksdb &&
cd rocksdb &&
git reset --hard $ROCKSDB_VERSION &&
CXXFLAGS='-flto -Os -s' PORTABLE=1 make shared_lib -j 4 &&
make install-shared &&
popd
- uses: actions/upload-artifact@v2
name: 'Upload build artifacts'
name: 'Set up Python ${{ matrix.py_ver }}'
with:
path: 'dist/*.whl'

python-version: ${{ matrix.py_ver }}

build_sdist:
name: 'Build source distribution'
runs-on: 'ubuntu-latest'
steps:
- uses: actions/checkout@v2
name: 'Checkout source repository'
- name: 'Install C libraries'
# XXX(Tina): The non-development versions are sufficient, but package
# names are difficult to predict.
run: >
sudo apt install -y libsnappy-dev libbz2-dev liblz4-dev libz-dev
libgflags-dev libzstd-dev
- uses: actions/setup-python@v2
name: 'Set up Python 3.9'
# Recover the pre-built C library.
- uses: actions/cache@v2
id: cache-librocksdb
with:
python-version: '3.9'
key: ${{ matrix.os }}-librocksdb-${{ matrix.rocksdb_ver }}
path: /opt/rocksdb

- name: 'Build sdist'
- name: 'Install RocksDB ${{ matrix.rocksdb_ver }}'
if: steps.cache-librocksdb.outputs.cache-hit == 'true'
# DO NOT FORGET to call `ldconfig`!
run: |
python3 setup.py sdist
- uses: actions/upload-artifact@v2
name: 'Upload build artifacts'
with:
path: 'dist/*.tar.gz'
pushd /opt/rocksdb &&
sudo make install-shared &&
sudo ldconfig &&
popd
- name: Build and install python-rocksdb
# Use `pip install` instead of `setup.py` so build-dependencies from
# `pyproject.toml` are installed, in particular `Cython`, without which
# the build fails in confusing ways.
run: |
python3 -m pip install '.[test]'
# upload_pypi:
# name: 'Upload packages'
# needs: ['build_wheels', 'build_sdist']
# runs-on: 'ubuntu-latest'
# if: github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/v')
# steps:
# - uses: actions/download-artifact@v2
# name: 'Download artifacts'
# with:
# name: 'artifact'
# path: 'dist'
#
# - uses: pypa/gh-action-pypi-publish@master
# name: 'Publish built packages'
# with:
# user: '__token__'
# password: '${{ secrets.PYPI_API_TOKEN }}'
- name: Run tests
# Use `--pyargs` to interpret parameter as module to import, not as a
# path, and do not use `python3 -m pytest`. This way we prevent
# importing the module from the current directory instead of the
# installed package, and failing when it cannot find the shared
# library.
run: |
pytest --pyargs rocksdb
102 changes: 102 additions & 0 deletions .github/workflows/dist.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
# vim:ts=2:sw=2:et:ai:sts=2
name: 'Build distribution'

on:
# Only run when pushing to main/merging PRs.
push:
branches:
- main

jobs:
build_wheels:
name: 'Build wheels'
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v2
name: 'Checkout source repository'

- uses: actions/setup-python@v2
name: 'Set up Python 3.9'
with:
python-version: '3.9'

- name: 'Install cibuildwheel'
run: |
python3 -m pip install cibuildwheel==1.7.1
- name: 'Build wheels'
run: |
python3 -m cibuildwheel --output-dir dist
env:
ROCKSDB_VERSION: 'v6.14.6'
CIBW_MANYLINUX_X86_64_IMAGE: 'manylinux2014'
CIBW_BUILD: 'cp3*'
CIBW_SKIP: '*-manylinux_i686'
# Install python package and test-deps.
CIBW_TEST_REQUIRES: '.[test] pytest'
# Use `--pyargs` to interpret parameter as module to import, not as a
# path, and do not use `python3 -m pytest`. This way we prevent
# importing the module from the current directory instead of the
# installed package, and failing when it cannot find the shared
# library.
CIBW_TEST_COMMAND: 'pytest --pyargs rocksdb'
# Avoid re-building the C library in every iteration by testing for
# the build directory.
CIBW_BEFORE_BUILD: >
yum install -y bzip2-devel lz4-devel snappy-devel zlib-devel
python3-Cython &&
pushd /opt &&
test -d rocksdb || (
git clone https://github.com/facebook/rocksdb &&
cd rocksdb &&
git reset --hard $ROCKSDB_VERSION &&
CXXFLAGS='-flto -Os -s' PORTABLE=1 make shared_lib -j 4 &&
make install-shared
) &&
popd
- uses: actions/upload-artifact@v2
name: 'Upload build artifacts'
with:
path: 'dist/*.whl'

build_sdist:
name: 'Build source distribution'
runs-on: 'ubuntu-latest'
steps:
- uses: actions/checkout@v2
name: 'Checkout source repository'

- uses: actions/setup-python@v2
name: 'Set up Python 3.9'
with:
python-version: '3.9'

- name: 'Build sdist'
run: |
python3 setup.py sdist
- uses: actions/upload-artifact@v2
name: 'Upload build artifacts'
with:
path: 'dist/*.tar.gz'


# upload_pypi:
# name: 'Upload packages'
# needs: ['build_wheels', 'build_sdist']
# runs-on: 'ubuntu-latest'
# if: github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/v')
# steps:
# - uses: actions/download-artifact@v2
# name: 'Download artifacts'
# with:
# name: 'artifact'
# path: 'dist'
#
# - uses: pypa/gh-action-pypi-publish@master
# name: 'Publish built packages'
# with:
# user: '__token__'
# password: '${{ secrets.PYPI_API_TOKEN }}'
2 changes: 2 additions & 0 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ where = .
doc =
sphinx
sphinx_rtd_theme
test =
pytest

[build_sphinx]
source-dir = docs
Expand Down
15 changes: 12 additions & 3 deletions tox.ini
Original file line number Diff line number Diff line change
@@ -1,15 +1,24 @@
[tox]
envlist = py35,py36,py37,py38,py39
minversion = 2.0
isolated_build = True
skipsdist = True

[testenv]
deps = pytest
commands = pytest {posargs:rocksdb/tests}
# Install the module in `.` and its `test` extra dependencies from
# setup.cfg.
deps =
.[test]
changedir = /
# Point directly to the installed package, and do not use `python3 -m pytest`.
# This way we prevent importing the module from the current directory instead
# of the installed package, and failing when it cannot find the shared library.
commands = pytest {envsitepackagesdir}/rocksdb

[testenv:docs]
deps = .[doc]
commands = python3 setup.py build_sphinx -W

[pytest]
addopts = --verbose
addopts = --verbose --pyargs
norecursedirs = .tox

0 comments on commit 9cbbea6

Please sign in to comment.