[pre-commit.ci] pre-commit autoupdate #1810
This file contains hidden or 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
name: PyPI | |
on: | |
pull_request: | |
branches: [main] | |
push: | |
branches: [main] | |
release: | |
types: [published] | |
jobs: | |
build: | |
name: build source distribution | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: "3.11" | |
- name: Build the sdist and the wheel | |
run: | | |
pip install build | |
python3 -m build | |
- name: Check the sdist installs and imports | |
run: | | |
mkdir -p test-sdist | |
cd test-sdist | |
python -m venv venv-sdist | |
venv-sdist/bin/python -m pip install numpy | |
venv-sdist/bin/python -m pip install ../dist/pymc_extras*.tar.gz | |
echo "Checking import and version number (on release)" | |
venv-sdist/bin/python -c "import pymc_extras as pmx; assert pmx.__version__ == '${{ github.ref_name }}'[1:] if '${{ github.ref_type }}' == 'tag' else True; print(pmx.__version__)" | |
cd .. | |
- name: Check the bdist installs and imports | |
run: | | |
mkdir -p test-bdist | |
cd test-bdist | |
python -m venv venv-bdist | |
venv-bdist/bin/python -m pip install ../dist/pymc_extras*.whl | |
echo "Checking import and version number (on release)" | |
venv-bdist/bin/python -c "import pymc_extras as pmx; assert pmx.__version__ == '${{ github.ref_name }}'[1:] if '${{ github.ref_type }}' == 'tag' else pmx.__version__; print(pmx.__version__)" | |
cd .. | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: artifact | |
path: dist/* | |
publish: | |
name: upload release to PyPI | |
needs: [build] | |
runs-on: ubuntu-latest | |
if: github.repository_owner == 'pymc-devs' && github.event_name == 'release' && github.event.action == 'published' | |
# Use the `release` GitHub environment to protect the Trusted Publishing (OIDC) | |
# workflow by requiring signoff from a maintainer. | |
environment: release | |
permissions: | |
# write id-token is necessary for trusted publishing (OIDC) | |
id-token: write | |
steps: | |
- uses: actions/download-artifact@v4 | |
with: | |
name: artifact | |
path: dist | |
- uses: pypa/gh-action-pypi-publish@release/v1 |