Using trusted publishing for PyPI #29
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
## Build wheel and upload to TestPyPI (!! not PyPI !!) | |
## https://github.com/joerick/cibuildwheel/blob/master/examples/github-deploy.yml | |
## https://scikit-hep.org/developer/gha_wheels | |
name: Build wheel and upload to PyPI or TestPyPI | |
# When push on branch dev | |
on: | |
push: | |
if: "startsWith(github.ref, 'refs/tags/v')" | |
jobs: | |
build_wheels: | |
name: Build wheels on ${{ matrix.os }} | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v5 | |
name: Install Python | |
with: | |
python-version: '3.11' | |
- name: Install NumPy and cibuildwheel | |
run: | | |
python3 -m pip install --upgrade pip | |
python3 -m pip install cibuildwheel==2.16.2 | |
- name: Build wheels | |
run: | | |
python3 -m cibuildwheel --output-dir wheelhouse | |
env: | |
CIBW_BUILD: cp39-* cp310-* cp311-* | |
CIBW_SKIP: pp* | |
CIBW_BEFORE_BUILD: pip install numpy | |
- uses: actions/upload-artifact@v3 | |
with: | |
path: ./wheelhouse/*.whl | |
build_sdist: | |
name: Build source distribution | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v5 | |
name: Install Python | |
with: | |
python-version: '3.11' | |
- name: Install Python dependencies | |
run: | | |
python3 -m pip install --upgrade pip setuptools wheel | |
python3 -m pip install numpy | |
- name: Build sdist | |
run: python setup.py sdist | |
- uses: actions/upload-artifact@v3 | |
with: | |
path: dist/*.tar.gz | |
upload_pypi: | |
# Upload to PyPI for master branch | |
if: github.ref == 'refs/heads/master' | |
name: Upload to PyPI | |
needs: [build_wheels, build_sdist] | |
runs-on: ubuntu-latest | |
environment: | |
name: pypi | |
url: https://pypi.org/p/forestatrisk | |
permissions: | |
id-token: write # Mandatory for trusted publishing. | |
steps: | |
- uses: actions/download-artifact@v3 | |
with: | |
name: artifact | |
path: dist | |
- uses: pypa/gh-action-pypi-publish@release/v1 | |
upload_testpypi: | |
# Upload to TestPyPI for dev branch | |
if: github.ref == 'refs/heads/dev' | |
name: Upload to TestPyPI | |
needs: [build_wheels, build_sdist] | |
runs-on: ubuntu-latest | |
environment: | |
name: testpypi | |
url: https://test.pypi.org/p/forestatrisk | |
permissions: | |
id-token: write # Mandatory for trusted publishing. | |
steps: | |
- uses: actions/download-artifact@v3 | |
with: | |
name: artifact | |
path: dist | |
- uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
repository-url: https://test.pypi.org/legacy/ | |
# End |