Skip to content

Commit

Permalink
initial work on new wheel release mechanism
Browse files Browse the repository at this point in the history
  • Loading branch information
PhilipDeegan committed Oct 27, 2023
1 parent 04dbb37 commit 90c76e3
Show file tree
Hide file tree
Showing 119 changed files with 1,433 additions and 2,172 deletions.
21 changes: 12 additions & 9 deletions .github/workflows/build_nix.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,11 @@ on:
branches: [ master ]

env:
TICK_DEBUG: 0
TICK_WERROR: 0
MKN_COMPILE_THREADS: 2
MKN_GCC_PREFERRED: 1
MKN_PYTHON_LIB_EMBED: 1
MKN_LIB_LINK_LIB: 1
KLOG: 3

jobs:
build:
Expand All @@ -21,10 +23,11 @@ jobs:
fail-fast: false
max-parallel: 4
matrix:
python-version: ['3.7', '3.9', '3.10', '3.11'] # '3.8' has "'tp_print' is deprecated [-Werror,-Wdeprecated-declarations]"
python-version: ['3.11']
# python-version: ['3.9', '3.10', '3.11'] # , '3.12' - not ready yet

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
with:
submodules: true

Expand All @@ -43,22 +46,22 @@ jobs:
gcc -v
swig -version
- name: pip
- name: pip # tensorflow not released for 3.12 as of 26-OCT-2023
run: |
python3 -m pip install wheel pip --upgrade
python3 -m pip install -r requirements.txt
python3 -m pip install tensorflow-cpu
[ "${{ matrix.python-version }}" != "3.12" ] && python3 -m pip install tensorflow-cpu
- name: build
run: |
curl -Lo mkn https://github.com/mkn/mkn/releases/download/latest/mkn_nix
chmod +x mkn
PATH=$PWD:$PATH KLOG=3 ./sh/mkn.sh
PATH=$PWD:$PATH mkn -C lib build -g 0 -dtOa "-fPIC -std=c++17"
- name: cpptest
run: |
PATH=$PWD:$PATH KLOG=3 ./sh/gtest.sh
PATH=$PWD:$PATH mkn -C lib -p gtest build run test -dOta "-fPIC -std=c++17 -DGTEST_LINKED_AS_SHARED_LIBRARY"
- name: pytest
run: |
python3 setup.py pytest
python3 -m unittest discover -v . "*_test.py"
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,10 @@ on:
branches: [ master ]

env:
TICK_DEBUG: 0
TICK_WERROR: 0

MKN_COMPILE_THREADS: 2
MKN_LIB_LINK_LIB: 1
MKN_PYTHON_LIB_EMBED: 1
KLOG: 3

jobs:
build:
Expand All @@ -21,10 +22,11 @@ jobs:
fail-fast: false
max-parallel: 4
matrix:
python-version: ['3.7', '3.9', '3.10'] # '3.8' has "'tp_print' is deprecated [-Werror,-Wdeprecated-declarations]"
python-version: ['3.11']
# python-version: ['3.9', '3.10', '3.11', '3.12']

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
with:
submodules: true

Expand All @@ -48,16 +50,18 @@ jobs:
python3 -m pip install wheel pip --upgrade
python3 -m pip install -r requirements.txt
- name: build
run: |
curl -Lo mkn https://github.com/mkn/mkn/releases/download/latest/mkn_osx
chmod +x mkn
PATH=$PWD:$PATH KLOG=3 ./sh/mkn.sh
PATH=$PWD:$PATH mkn -C lib build -g 0 -dtOa "-fPIC -std=c++17"
- name: cpptest
run: |
PATH=$PWD:$PATH KLOG=3 ./sh/gtest.sh
PATH=$PWD:$PATH mkn -C lib -p gtest build run test -dOta "-fPIC -std=c++17 -DGTEST_LINKED_AS_SHARED_LIBRARY"
- name: pytest
run: |
python -m unittest discover -v . "*_test.py"
# echo "Tests not run until test failures assessed./"
19 changes: 11 additions & 8 deletions .github/workflows/build_win.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@ on:
branches: [ master ]

env:
TICK_DEBUG: 0
TICK_WERROR: 0
MKN_CL_PREFERRED: 1
MKN_COMPILE_THREADS: 2
MKN_LIB_LINK_LIB: 2
KLOG: 3

jobs:
build:
Expand All @@ -22,7 +22,8 @@ jobs:
fail-fast: false
max-parallel: 4
matrix:
python-version: ['3.7', '3.8', '3.9', '3.10', '3.11']
python-version: ['3.11']
# python-version: ['3.9', '3.10', '3.11', '3.12']

steps:
- uses: actions/checkout@v3
Expand All @@ -49,15 +50,17 @@ jobs:
python3 -m pip install wheel pip --upgrade
python3 -m pip install -r requirements.txt
- name: build
run: | # MINGW link interferres with MSVC link.exe
bash -c "rm /bin/link"
bash -c "curl -Lo mkn.exe https://github.com/mkn/mkn/releases/download/latest/mkn.exe"
bash -c 'PATH=$PWD:$PATH KLOG=3 ./sh/mkn.sh'
shell: cmd
run: |
curl -Lo mkn.exe https://github.com/mkn/mkn/releases/download/latest/mkn.exe
mkn -C lib build -g 0 -dtOa "-std:c++17 -EHsc"
- name: cpptest
shell: cmd
run: |
bash -c 'PATH=$PWD:$PATH KLOG=3 ./sh/gtest.sh'
mkn -C lib -p gtest build run test -dOta "-std:c++17 -EHsc"
- name: pytest
run: |
Expand Down
112 changes: 112 additions & 0 deletions .github/workflows/merge_master.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
name: Master merge

# on:
# push:
# branches: [ master ]
# workflow_dispatch:

on:
push:
branches: [ master ]
pull_request:
branches: [ master ]

env:
MKN_COMPILE_THREADS: 2
MKN_GCC_PREFERRED: 1
MKN_LIB_LINK_LIB: 1
KLOG: 3

jobs:

build_linux:
runs-on: ubuntu-latest
container: quay.io/pypa/manylinux2014_x86_64

strategy:
fail-fast: false
max-parallel: 4
matrix:
python-version: ['cp311-cp311']
# python-version: ['cp39-cp39', 'cp310-cp310', 'cp311-cp311', 'cp312-cp312']

steps:
- name: add Python dir to path
run: |
echo "/opt/python/${{ matrix.python-version }}/bin" >> $GITHUB_PATH
- uses: actions/checkout@v3
with:
submodules: true
- name: Build for Python ${{ matrix.python-version }}
run: |
git config --global --add safe.directory '*'
python3 -V
python3 -m pip install -U pip
python3 -m pip install -U build twine wheel
python3 -m pip install -U -r requirements.txt
curl -Lo mkn https://github.com/mkn/mkn/releases/download/latest/mkn_manylinux
chmod +x mkn
PATH=$PWD:$PATH mkn -C lib build -g 0 -dtOa "-fPIC -std=c++17"
python3 -m build --wheel --no-isolation .
python3 -m twine check dist/*
rename 'linux_x86_64' 'manylinux_2_28_x86_64' dist/*.whl
- name: Make wheels universal
run: for wheel in $(ls dist/*.whl); do auditwheel repair $wheel; done
- name: Save packages as artifacts
uses: actions/upload-artifact@v3
with:
name: wheels
path: wheelhouse/*.whl


test_wheels:
needs: [build_linux]
strategy:
matrix:
os: [ubuntu-latest] # ,macos-11, windows-latest
python-version: ['3.11']
# python-version: ['3.9', '3.10', '3.11', '3.12']
runs-on: ${{ matrix.os }}
steps:
- name: Setup Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
architecture: x64
- uses: actions/download-artifact@v3
with:
name: wheels
path: dist
- name: install wheel (Unix)
if: runner.os != 'Windows'
run: |
pip install --find-links $GITHUB_WORKSPACE/dist tick
- name: install wheel (Windows)
if: runner.os == 'Windows'
run: |
pip install --find-links $env:GITHUB_WORKSPACE\dist tick
- uses: actions/checkout@v3
- name: run tests
run: | # hide tick dir to avoid conflicts but still run tests
python3 -V
rm -rf tick/tick_cpp && mv tick _tick
python3 -m unittest discover -v . "*_test.py"
upload_test_pypi:
needs: [test_wheels]
runs-on: ubuntu-latest
# upload to test PyPI on github pushes
# if: github.event_name == 'push' && github.repository_owner == 'Tick'
steps:
- uses: actions/download-artifact@v3
with:
name: wheels
path: dist
- uses: pypa/gh-action-pypi-publish@release/v1
with:
user: __token__
password: ${{ secrets.TEST_PYPI_PASSWORD }}
repository-url: https://test.pypi.org/legacy/
skip-existing: false
2 changes: 1 addition & 1 deletion .github/workflows/pythonpublish-linux.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ jobs:
runs-on: ubuntu-latest
container: jeandet/manylinuxcpp2017
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
with:
submodules: true

Expand Down
6 changes: 3 additions & 3 deletions .github/workflows/pythonpublish-osx.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,14 @@ jobs:
strategy:
max-parallel: 4
matrix:
python-version: ['3.7', '3.8', '3.9', '3.10']
python-version: ['3.7', '3.8', '3.9', '3.10', '3.11']
name: Python ${{ matrix.python-version }}
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
with:
submodules: true

- uses: actions/setup-python@v1
- uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
architecture: x64
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/pythonpublish-win.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,11 @@ jobs:
python-version: ['3.7', '3.8', '3.9', '3.10']
name: Python ${{ matrix.python-version }}
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
with:
submodules: true

- uses: actions/setup-python@v1
- uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
architecture: x64
Expand Down
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -58,3 +58,5 @@ tools/benchmark/data
env*/
venv*/
tickf.yml
dist
tick.egg-info/
48 changes: 0 additions & 48 deletions .travis.yml.off

This file was deleted.

9 changes: 2 additions & 7 deletions MANIFEST.in
Original file line number Diff line number Diff line change
@@ -1,8 +1,3 @@
# Setuptools is not aware of source headers, or non-module SWIG files, so we
# grab them here
global-include *.h
global-include *.i
global-include *.inl
recursive-include tick *
recursive-exclude lib *

# Getting the Cereal header-only library
recursive-include lib/third_party/cereal/include *.h *.hpp
Loading

0 comments on commit 90c76e3

Please sign in to comment.