Skip to content

Commit

Permalink
optional system deps
Browse files Browse the repository at this point in the history
  • Loading branch information
rmdg88 committed Oct 4, 2024
1 parent 73ac4b6 commit 7a4b26f
Show file tree
Hide file tree
Showing 21 changed files with 556 additions and 424 deletions.
9 changes: 8 additions & 1 deletion .github/actions/setup-poetry/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,17 @@ runs:
- name: Install poetry
run: pipx install poetry==1.8.3
shell: bash
- uses: actions/setup-python@v4
- uses: actions/setup-python@v5
id: py
with:
python-version: ${{ inputs.python-version }}
update-environment: false
cache: 'poetry'
- name: Setup poetry env with correct python
run: |
poetry env use ${{ steps.py.outputs.python-path }}
poetry run python --version
shell: bash
- name: Install only dependencies and not the package itself
run: poetry install --all-extras --no-root
shell: bash
36 changes: 36 additions & 0 deletions .github/scripts/build_rhel.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
#!/bin/bash

set -e # trigger failure on error - do not remove!
set -x # display command on output

# Build the Python package with Poetry
poetry build -f sdist

# Docker build
docker build -f - . <<EOF
FROM quay.io/centos/centos:stream9
RUN dnf config-manager --set-enabled crb
RUN dnf copr -y enable cheimes/deepsearch-glm rhel-9-x86_64
RUN dnf install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm \
&& dnf clean all
RUN dnf install -y --nodocs \
gcc gcc-c++ git make cmake pkgconfig ninja-build glibc-devel \
python3.11 python3.11-pip python3.11-devel \
libjpeg-turbo-devel libpng-devel zlib-devel \
cxxopts-devel fasttext-devel fmt-devel json-schema-validator-devel \
loguru-devel sentencepiece-devel pcre2-devel utf8cpp-devel \
&& dnf clean all
RUN mkdir /src
COPY ./dist/*.tar.gz /src/
RUN USE_SYSTEM_DEPS=ON pip3.11 install /src/deepsearch_glm*.tar.gz
COPY ./tests /src/tests
RUN cd /src \
&& pip3.11 install pytest \
&& pytest ./tests/test_structs.py -v \
&& pytest ./tests/test_nlp.py -v \
&& pytest ./tests/test_glm.py -v \
|| { echo "Tests failed"; exit 1; }
EOF
5 changes: 4 additions & 1 deletion .github/workflows/checks.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,10 @@ jobs:
with:
python-version: ${{ matrix.python-version }}
- name: Install with poetry
run: poetry install --all-extras
run: |
poetry install --all-extras
ls -l
ls -l deepsearch_glm
- name: Run styling check
run: poetry run pre-commit run --all-files
- name: Testing
Expand Down
3 changes: 2 additions & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,5 @@ jobs:
uses: ./.github/workflows/checks.yml
build-wheels:
uses: ./.github/workflows/wheels.yml

rhel-build:
uses: ./.github/workflows/rhel.yml
12 changes: 12 additions & 0 deletions .github/workflows/rhel.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
on:
workflow_call:

jobs:
run-checks:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: ./.github/actions/setup-poetry
- name: Run build in docker
run: ./.github/scripts/build_rhel.sh
shell: bash
80 changes: 70 additions & 10 deletions .github/workflows/wheels.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,11 +51,21 @@ jobs:

- name: Setup Python
uses: actions/setup-python@v5
id: py
with:
python-version: ${{ matrix.python-version }}
update-environment: false

- name: Install Poetry
run: python -m pip install poetry==1.8.3
run: |
which python
python --version
which python3
python3 --version
echo "pythonpath: ${{ steps.py.outputs.python-path }}"
${{ steps.py.outputs.python-path }} --version
pipx install poetry==1.8.3
poetry env use ${{ steps.py.outputs.python-path }}
- name: Set up custom PATH and set py version to cpXYZ [windows]
if: ${{matrix.os.platform_id == 'win_amd64'}}
Expand Down Expand Up @@ -97,9 +107,15 @@ jobs:
CIBW_ENVIRONMENT: "MACOSX_DEPLOYMENT_TARGET=${{ matrix.os.macos_version }}.0"
ARCHFLAGS: -arch x86_64
BUILD_THREADS: "4"
PYTORCH_MPS_HIGH_WATERMARK_RATIO: "0.0"
run: |
echo "Building wheel ${CIBW_BUILD}"
PY_CACHE_TAG=$(poetry run python -c 'import sys;print(sys.implementation.cache_tag)')
echo "Building wheel ${CIBW_BUILD} ${{ env.CIBW_BUILD }}"
echo "Building cp: ${{ env.python_cp_version }}"
echo "Building cache_tag: ${PY_CACHE_TAG}"
echo "Building platform_id: ${{ matrix.os.platform_id }}"
poetry run python --version
poetry run python --version | grep ${{ matrix.python-version }}
poetry install --no-root --only=build
cat ./pyproject.toml
poetry run python -m cibuildwheel --output-dir wheelhouse
Expand All @@ -115,8 +131,12 @@ jobs:
for file in ./wheelhouse/*.whl; do
echo "Inspecting $file"
poetry run python -m zipfile --list "$file"
echo "Checking if .so is contained in the wheel"
poetry run python -m zipfile --list "$file" | grep \\.so
echo "Checking if the correct python version is contained in the wheel"
poetry run python -m zipfile --list "$file" | grep ${PY_CACHE_TAG}
done
mkdir ./dist
mkdir -p ./dist
cp wheelhouse/*.whl ./dist/
# there is an error with the tagging of wheels for macosx-arm64
Expand All @@ -137,9 +157,16 @@ jobs:
CIBW_ENVIRONMENT: "MACOSX_DEPLOYMENT_TARGET=${{ matrix.os.macos_version }}.0"
ARCHFLAGS: -arch arm64
BUILD_THREADS: "4"
PYTORCH_MPS_HIGH_WATERMARK_RATIO: "0.0"
CUDA_VISIBLE_DEVICES: "cpu"
run: |
echo "Building wheel ${CIBW_BUILD}"
PY_CACHE_TAG=$(poetry run python -c 'import sys;print(sys.implementation.cache_tag)')
echo "Building wheel ${CIBW_BUILD} ${{ env.CIBW_BUILD }}"
echo "Building cp: ${{ env.python_cp_version }}"
echo "Building cache_tag: ${PY_CACHE_TAG}"
echo "Building platform_id: ${{ matrix.os.platform_id }}"
poetry run python --version
poetry run python --version | grep ${{ matrix.python-version }}
poetry install --no-root --only=build
cat ./pyproject.toml
poetry run python -m cibuildwheel --output-dir wheelhouse
Expand All @@ -155,8 +182,12 @@ jobs:
for file in ./wheelhouse/*.whl; do
echo "Inspecting $file"
poetry run python -m zipfile --list "$file"
echo "Checking if .so is contained in the wheel"
poetry run python -m zipfile --list "$file" | grep \\.so
echo "Checking if the correct python version is contained in the wheel"
poetry run python -m zipfile --list "$file" | grep ${PY_CACHE_TAG}
done
mkdir ./dist
mkdir -p ./dist
cp wheelhouse/*.whl ./dist/
- name: Set up QEMU [linux]
Expand All @@ -165,28 +196,43 @@ jobs:
with:
platforms: all

- name: Build sdist
# build only on Linux to avoid too many duplicates of the sdist
if: matrix.os.name == 'ubuntu-latest'
run: |
echo "Building wheel ${CIBW_BUILD}"
poetry build -f sdist
- name: Build wheels [linux]
if: matrix.os.name == 'ubuntu-latest'
env:
# CIBW_BUILD: ${{ env.python_cp_version }}-${{ matrix.os.platform_id }}
## CIBW_BUILD: ${{ env.python_cp_version }}-${{ matrix.os.platform_id }}
CIBW_ARCHS: auto x86_64 aarch64
CIBW_PLATFORM: linux
CIBW_SKIP: "pp* *musllinux_* *_i686* *_s390* *pypy*"
CIBW_PROJECT_REQUIRES_PYTHON: "~=${{ matrix.python-version }}.0"
CIBW_BUILD_VERBOSITY: 3
BUILD_THREADS: "8"
run: |
echo "Building wheel ${CIBW_BUILD}"
PY_CACHE_TAG=$(poetry run python -c 'import sys;print(sys.implementation.cache_tag)')
echo "Building cp: ${{ env.python_cp_version }}"
echo "Building cache_tag: ${PY_CACHE_TAG}"
echo "Building platform_id: ${{ matrix.os.platform_id }}"
poetry run python --version
poetry run python --version | grep ${{ matrix.python-version }}
poetry install --no-root --only=build
cat ./pyproject.toml
poetry run python -m cibuildwheel --output-dir ./wheelhouse
ls -l ./wheelhouse
for file in ./wheelhouse/*.whl; do
echo "Inspecting $file"
poetry run python -m zipfile --list "$file"
echo "Checking if .so is contained in the wheel"
poetry run python -m zipfile --list "$file" | grep \\.so
echo "Checking if the correct python version is contained in the wheel"
poetry run python -m zipfile --list "$file" | grep ${PY_CACHE_TAG}
done
mkdir ./dist
mkdir -p ./dist
cp wheelhouse/*.whl ./dist/
- name: Set up MSYS2
Expand Down Expand Up @@ -238,9 +284,23 @@ jobs:
- name: publish wheels (dry run)
run: |
poetry publish --dry-run --no-interaction -vvv
poetry publish --skip-existing --dry-run --no-interaction -vvv
- name: publish wheels (on publishing) [for releases only]
if: ${{ startsWith(github.ref, 'refs/tags/') }}
run: |
poetry publish --no-interaction -vvv
poetry publish --skip-existing --no-interaction -vvv
# - name: Upload wheels [windows]
# if: ${{ matrix.os.platform_id == 'win_amd64' }}
# uses: actions/upload-artifact@v4
# with:
# name: wheels-windows
# path: ./dist/*.whl

# - name: Upload wheels [linux]
# if: ${{ matrix.os.platform_id == 'manylinux_x86_64' }}
# uses: actions/upload-artifact@v4
# with:
# name: wheels-linux
# path: ./dist/*.whl
94 changes: 0 additions & 94 deletions .gitignore

This file was deleted.

Loading

0 comments on commit 7a4b26f

Please sign in to comment.