From 41e98c2a84e5e1068247cff938054ae0fca1b889 Mon Sep 17 00:00:00 2001 From: puerling Date: Fri, 6 Dec 2024 15:55:25 +0100 Subject: [PATCH] CI: split pypi build and deploy tasks --- .github/workflows/ci.yml | 60 +++++++++++++++++++++++++++++----------- 1 file changed, 44 insertions(+), 16 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index fde4f6004..b32701180 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -766,7 +766,7 @@ jobs: path: ui-cpp/ui-imgui/webapp/ if-no-files-found: error - deploy-pypi: + build-pypi: if: github.event_name != 'pull_request' needs: - lint @@ -780,7 +780,13 @@ jobs: strategy: fail-fast: false matrix: - os: [ubuntu-latest, macos-latest, windows-latest] + include: + - platform: linux + os: ubuntu-latest + - platform: macos + os: macos-latest + - platform: windows + os: windows-latest env: BUILD_TYPE: Release CMAKE_FLAGS: -DSPIRIT_UI_USE_IMGUI=OFF -DSPIRIT_UI_CXX_USE_QT=OFF @@ -823,21 +829,43 @@ jobs: echo "Add suffix to spirit version tag for python package $SPIRIT_ADD_VERSION_SUFFIX" python setup.py sdist bdist_wheel - - name: 🚀 Deploy to TestPyPI - working-directory: ./core/python - env: - TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} - TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} - if: github.ref != 'refs/heads/master' - run: twine upload --skip-existing --repository testpypi dist/* + - uses: actions/upload-artifact@v4 + with: + name: dist-${{ matrix.platform }} + path: ./core/python/dist + if-no-files-found: error - - name: 🚀 Deploy to PyPI - working-directory: ./core/python - env: - TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} - TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} - if: github.ref == 'refs/heads/master' - run: twine upload --skip-existing dist/* + deploy-pypi: + if: github.event_name != 'pull_request' + needs: ['build-pypi'] + environment: 'publish' + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + os: [ubuntu-latest, macos-latest, windows-latest] + + steps: + - uses: actions/download-artifact@v4 + + - name: 📚 Install necessary packages + run: | + python -m pip install --upgrade pip + python -m pip install twine + + - name: 🚀 Deploy to TestPyPI + env: + TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} + TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} + if: github.ref != 'refs/heads/master' + run: twine upload --skip-existing --repository testpypi dist/* + + - name: 🚀 Deploy to PyPI + env: + TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} + TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} + if: github.ref == 'refs/heads/master' + run: twine upload --skip-existing dist/* deploy-package: if: github.event_name != 'pull_request'