Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

github actions update - windows, linux, and cibuildwheel #38

Merged
merged 8 commits into from
Jun 3, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/cpp-test.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: C++ test linux
name: Test bmdscore Linux

on:
pull_request:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Python test linux
name: Test pybmds Linux

on:
pull_request:
Expand All @@ -7,29 +7,31 @@ on:
- main
workflow_dispatch:

concurrency:
group: ${{ github.workflow }}-${{ github.ref_name }}
cancel-in-progress: true

jobs:
test:
runs-on: ${{ matrix.os }}
strategy:
max-parallel: 4
matrix:
python-version: ["3.11"]
os: ["ubuntu-22.04"]
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
python-version: "3.12"
cache: pip
- name: Install dependencies and build pybmds
- name: Install dependencies
run: |
source ./tools/linux_ci_setup.sh
- name: Build pybmds
run: |
source ./tools/linux_ci_env.sh
python -m pip install -U pip wheel
python -m pip install -e ".[dev,docs]"
stubgen -p pybmds.bmdscore -o src
ruff format src/pybmds/bmdscore.pyi
python -c "import pybmds; print(pybmds.bmdscore.version())"
- name: Check linked files
run: |
ls -lah src/pybmds
Expand Down
80 changes: 25 additions & 55 deletions .github/workflows/python-test-windows.yml
Original file line number Diff line number Diff line change
@@ -1,88 +1,58 @@
name: Python test windows
name: Test pybmds Windows

on:
push:
branches:
- main
workflow_dispatch:

env:
PYTHON_LIBRARY_DIR: $Env:CONDA\Lib\site-packages
PYTHON_EXECUTABLE: $Env:CONDA\python.exe
BUILD_TYPE: Release

concurrency:
group: ${{ github.workflow }}-${{ github.ref_name }}
cancel-in-progress: true

jobs:
test:
runs-on: ${{ matrix.os }}
strategy:
max-parallel: 4
matrix:
python-version: ["3.11"]
os: ["windows-2022"]

runs-on: windows-2022
steps:
- uses: actions/checkout@v4
- name: set up python ${{ matrix.python-version }}
- name: set up Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
python-version: "3.12"
cache: pip
- name: set dependency directory
run: echo "DEPENDENCY_DIR=$HOME\github-deps" >> $env:GITHUB_ENV
- name: restore github dependencies from cache
id: cache-github
- name: Set dependency path
shell: bash
run: |
DEP="$GITHUB_WORKSPACE/deps"
echo "DEPENDENCY_DIR=$DEP" >> $GITHUB_ENV
echo "EIGEN_DIR=$DEP\eigen" >> $GITHUB_ENV
echo "NLOPT_DIR=$DEP\nlopt\src\api;$DEP\nlopt\build\Release;$DEP\nlopt\build" >> $GITHUB_ENV
echo "GSL_DIR=$DEP\gsl\build\Release;$DEP\gsl\build" >> $GITHUB_ENV
- name: Restore dependencies from cache
id: cache-dependencies
uses: actions/cache@v4
with:
path: ${{ env.DEPENDENCY_DIR }}
key: ${{runner.os}}-github-deps
- name: create dependency dir
if: steps.cache-github.outputs.cache-hit != 'true'
run: mkdir ${{ env.DEPENDENCY_DIR }}
- name: download eigen
if: steps.cache-github.outputs.cache-hit != 'true'
run: |
cd ${{ env.DEPENDENCY_DIR }}
git clone --depth 1 https://github.com/libigl/eigen.git
- name: install nlopt
if: steps.cache-github.outputs.cache-hit != 'true'
run: |
cd ${{ env.DEPENDENCY_DIR }}
git clone --depth 1 https://github.com/stevengj/nlopt.git
cd nlopt
mkdir build
cd build
cmake -DBUILD_SHARED_LIBS=OFF ..
cmake --build . --config Release
- name: install gsl
if: steps.cache-github.outputs.cache-hit != 'true'
run: |
cd ${{ env.DEPENDENCY_DIR }}
git clone --depth 1 https://github.com/ampl/gsl.git
cd gsl
mkdir build
cd build
cmake .. -DNO_AMPL_BINDINGS=1
cmake --build . --config Release
- name: set eigen/nlopt/gsl directories
run: |
echo "EIGEN_DIR=${{ env.DEPENDENCY_DIR }}\eigen" >> $env:GITHUB_ENV
echo "NLOPT_DIR=${{ env.DEPENDENCY_DIR }}\nlopt\src\api;${{ env.DEPENDENCY_DIR }}\nlopt\build\Release;${{ env.DEPENDENCY_DIR }}\nlopt\build" >> $env:GITHUB_ENV
echo "GSL_DIR=${{ env.DEPENDENCY_DIR }}\gsl\build\Release;${{ env.DEPENDENCY_DIR }}\gsl\build" >> $env:GITHUB_ENV
key: ${{runner.os}}-cache-dependencies
- name: Build dependencies
if: steps.cache-dependencies.outputs.cache-hit != 'true'
shell: bash
run: tools/windows_ci.sh
- name: Build package
run: |
python -m pip install -U pip wheel
python -m pip install -e ".[dev,docs]"
python -m pip install -e ".[dev]"
stubgen -p pybmds.bmdscore -o src
ruff format src/pybmds/bmdscore.pyi
python setup.py bdist_wheel
python -c "import pybmds; print(pybmds.bmdscore.version())"
- name: Check shared object linked files
run: |
python -m pip install pefile
python -c "from pathlib import Path; import pefile; fn = str(list(Path('src/pybmds').glob('bmdscore*'))[0].resolve()); pe = pefile.PE(fn); print([i.dll for i in pe.DIRECTORY_ENTRY_IMPORT])"
- name: Build package
run: |
python -m pip install -U pip wheel
python setup.py bdist_wheel
- uses: actions/upload-artifact@v4
with:
path: ./dist/*.whl
44 changes: 44 additions & 0 deletions .github/workflows/wheels.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
name: Build Python Packages

on:
schedule:
- cron: '30 3 1 */1 *' # At 03:30 on the 1st of every month
tags:
workflow_dispatch:

jobs:

build_wheels:
name: Build wheels on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-22.04, windows-2022, macos-14]
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Show wheels that will be built
run: |
python -m pip install cibuildwheel==2.18.1
cibuildwheel --print-build-identifiers
- name: Build wheels
uses: pypa/[email protected]
env:
MACOSX_DEPLOYMENT_TARGET: "14.0"
- uses: actions/upload-artifact@v4
with:
name: cibw-wheels-${{ matrix.os }}-${{ strategy.job-index }}
path: ./wheelhouse/*.whl

merge_wheels:
runs-on: ubuntu-22.04
needs: build_wheels
steps:
- name: Merge Artifacts
uses: actions/upload-artifact/merge@v4
with:
name: wheels
delete-merged: true
2 changes: 0 additions & 2 deletions CMAKE_README.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,6 @@ Visual Studio 19 or greater
|NLOPT_DIR|path to nlopt lib directory|/home/username/libs/nlopt-2.6.2/lib64|
|CMAKE_C_COMPILER|path to c compiler|/usr/local/apps/gcc/9.1.0/bin/gcc|
|CMAKE_CXX_COMPILER|path to c++ compiler|/usr/local/apps/gcc/9.1.0/bin/g++|
|PYTHON_EXECUTABLE|path to python executable |/home/username/mambaforge/bin/python|
|PYTHON_LIBRARY_DIR|path to python site-packages directory| /home/username/venv/Lib/site-packages|

## Build process

Expand Down
8 changes: 0 additions & 8 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,6 @@ ENDIF()
IF(DEFINED ENV{CMAKE_CXX_COMPILER})
set(CMAKE_CXX_COMPILER $ENV{CMAKE_CXX_COMPILER})
ENDIF()
IF(DEFINED ENV{PYTHON_LIBRARY_DIR})
set(PYTHON_LIBRARY_DIR $ENV{PYTHON_LIBRARY_DIR})
ENDIF()

IF(WIN32)
add_compile_definitions(RBMDS_EXPORTS)
Expand Down Expand Up @@ -88,8 +85,3 @@ IF(WIN32)
ELSE()
target_link_libraries(bmdscore PUBLIC GSL::gsl GSL::gslcblas ${NLOPT_LIB})
ENDIF(WIN32)

install(TARGETS bmdscore
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@cwsimmon I removed this; it doesn't appear to be needed?

COMPONENT python
LIBRARY DESTINATION "${PYTHON_LIBRARY_DIR}"
)
39 changes: 38 additions & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -57,9 +57,46 @@ requires = [
build-backend = "setuptools.build_meta"

[tool.cibuildwheel]
test-requires = "pytest"
archs = ["auto64"]
build = ["cp311-*", "cp312-*"]
skip = [
"*-win32",
"*-win_arm64",
"*musllinux*",
"*i686",
"*-macosx_x86_64",
"*-macosx_universal2",
]
manylinux-x86_64-image = "manylinux_2_28"
manylinux-aarch64-image = "manylinux_2_28"
test-requires = ["pytest", "pytest-mpl"]
test-command = "pytest {project}/tests"

[tool.cibuildwheel.windows]
before-build = "bash tools/windows_ci.sh"

[tool.cibuildwheel.windows.environment]
EIGEN_DIR="D:/a/bmds/bmds/deps/eigen"
NLOPT_DIR="D:/a/bmds/bmds/deps/nlopt/src/api;D:/a/bmds/bmds/deps/nlopt/build/Release;D:/a/bmds/bmds/deps/nlopt/build"
GSL_DIR="D:/a/bmds/bmds/deps/gsl/build/Release;D:/a/bmds/bmds/deps/gsl/build"

[tool.cibuildwheel.linux]
before-build = "tools/cibuildwheel-linux.sh"

[tool.cibuildwheel.linux.environment]
EIGEN_DIR="/usr/include/eigen3"
NLOPT_DIR="/usr/local/lib64/"
CMAKE_C_COMPILER="/opt/rh/gcc-toolset-12/root/usr/bin/gcc"
CMAKE_CXX_COMPILER="/opt/rh/gcc-toolset-12/root/usr/bin/g++"

[tool.cibuildwheel.macos]
before-build = "tools/cibuildwheel-mac.sh"

[tool.cibuildwheel.macos.environment]
EIGEN_DIR="/opt/homebrew/Cellar/eigen/3.4.0_1/include/eigen3"
GSL_DIR="/opt/homebrew/Cellar/gsl/2.7.1"
NLOPT_DIR="/opt/homebrew/Cellar/nlopt/2.7.1/include"

[tool.coverage.run]
include = [
"src/pybmds/*"
Expand Down
11 changes: 11 additions & 0 deletions tools/cibuildwheel-linux.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#!/bin/bash

set -xe

yum update -y
yum install -y cmake gsl-devel eigen3-devel

cp ./vendor/nlopt-2.7.1.tar.gz ~
cd ~
tar -xf nlopt-2.7.1.tar.gz && cd nlopt-2.7.1 && mkdir build && cd build && cmake -DBUILD_SHARED_LIBS=OFF .. && make install
cd $GITHUB_WORKSPACE
9 changes: 9 additions & 0 deletions tools/cibuildwheel-mac.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash

set -xe

brew install gsl --quiet
brew install nlopt --quiet
brew install eigen --quiet

cd $GITHUB_WORKSPACE
9 changes: 9 additions & 0 deletions tools/linux_ci.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash

sudo apt-get update -y
sudo apt-get install -y automake build-essential libtool make cmake libgslcblas0 libgsl-dev libeigen3-dev libnlopt-dev libnlopt-cxx-dev lcov

export "EIGEN_DIR=/usr/include/eigen3"
export "NLOPT_DIR=/usr/lib/x86_64-linux-gnu/"
export "CMAKE_C_COMPILER=/usr/bin/gcc-12"
export "CMAKE_CXX_COMPILER=/usr/bin/g++-12"
2 changes: 0 additions & 2 deletions tools/linux_ci_env.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,4 @@ export EIGEN_DIR="/usr/include/eigen3"
export NLOPT_DIR="/usr/lib/x86_64-linux-gnu/"
export CMAKE_C_COMPILER="/usr/bin/gcc-11"
export CMAKE_CXX_COMPILER="/usr/bin/g++-11"
export PYTHON_EXECUTABLE=$(which python)
export PYTHON_LIBRARY_DIR=$(python -c "import site; print(site.getsitepackages()[0])")
export TEST_EXC="'/usr/include/*'"
33 changes: 33 additions & 0 deletions tools/windows_ci.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
#!/bin/bash

set -xe

# only do this first time
DEPS="$GITHUB_WORKSPACE/deps"
if [ -d "$DEPS" ]; then
exit 0
fi
mkdir -p $DEPS

# filenames and versions
EIGEN="eigen-3.4.0"
NLOPT="nlopt-2.7.1"
GSL="ampl-gsl-60539d2"

# eigen
cp $GITHUB_WORKSPACE/vendor/$EIGEN.tar.gz $DEPS
cd $DEPS && tar -xf $EIGEN.tar.gz && mv $EIGEN eigen && rm $EIGEN.tar.gz

# nlopt
cp $GITHUB_WORKSPACE/vendor/$NLOPT.tar.gz $DEPS
cd $DEPS && tar -xf $NLOPT.tar.gz && mv $NLOPT nlopt && rm $NLOPT.tar.gz
cd nlopt && mkdir build && cd build
cmake -DBUILD_SHARED_LIBS=OFF ..
cmake --build . --config Release

# gsl
cp $GITHUB_WORKSPACE/vendor/$GSL.tar.gz $DEPS
cd $DEPS && tar -xf $GSL.tar.gz && mv gsl-master gsl && rm $GSL.tar.gz
cd gsl && mkdir build && cd build
cmake -DNO_AMPL_BINDINGS=1 ..
cmake --build . --config Release
Binary file added vendor/ampl-gsl-60539d2.tar.gz
Binary file not shown.