Bump the github-workflows group across 1 directory with 4 updates #549
Workflow file for this run
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
name: package-server | |
on: | |
workflow_call: | |
inputs: | |
version: | |
description: The version to use | |
type: string | |
required: true | |
version_patch_run_id: | |
description: | | |
The run id where the version.patch artifact was uploaded. | |
If not provided, the workflow will generate the patch by itself. | |
type: string | |
required: true | |
commit_sha: | |
required: true | |
type: string | |
description: The commit SHA to use when checkout'ing the repository | |
default: ${{ github.sha }} | |
# PS: If you trigger manually the packaging, take into account that it will use the workflow as defined in the main branch not in the target branch. | |
workflow_dispatch: | |
inputs: | |
version: | |
description: The version to use (if not provided will generated one from the code space version) | |
type: string | |
required: false | |
pull_request: | |
paths: | |
- .github/workflows/package-server.yml | |
- server/packaging | |
- server/build.py | |
- server/pyproject.toml | |
# We set `concurrency` to prevent having this workflow being run on code that is not up-to-date on a PR (a user make multiple push in a quick manner). | |
# But on the main branch, we don't want that behavior. | |
# Having the workflow run on each merge commit is something we would like, that could help us where a regression was made and missed by previous checks. | |
# | |
# For that we use `head_ref` that is only defined on `pull-request` and fallback to `run_id` (this is a counter, so it's value is unique between workflow call). | |
concurrency: | |
group: package-server-${{ github.workflow }}-${{ github.head_ref || github.run_id }} | |
cancel-in-progress: true | |
env: | |
node-version: 18.12.0 | |
poetry-version: 1.5.1 | |
permissions: | |
contents: read | |
jobs: | |
version: | |
if: ${{ inputs.version_patch_run_id == '' }} | |
uses: ./.github/workflows/_parse_version.yml | |
with: | |
version: ${{ inputs.version }} | |
commit_sha: ${{ inputs.commit_sha }} | |
package-wheel: | |
needs: version | |
# Always run the job if `version` job is skipped otherwise only if `version` job was successful. | |
if: ${{ inputs.version_patch_run_id != '' && always() || success() }} | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- name: 🐧 Linux | |
platform: linux | |
os: ubuntu-22.04 | |
- name: 🍎 macOS | |
platform: macos | |
os: macos-12 | |
- name: 🏁 Windows | |
platform: windows | |
os: windows-2022 | |
name: "${{ matrix.name }}: 📦 Packaging (build Wheel)" | |
runs-on: ${{ matrix.os }} | |
steps: | |
- uses: actions/checkout@44c2b7a8a4ea60a981eaca3cf939b5f4305c123b # pin v4.1.5 | |
with: | |
ref: ${{ inputs.commit_sha }} | |
timeout-minutes: 5 | |
- uses: ./.github/actions/setup-python-poetry | |
with: | |
poetry-version: ${{ env.poetry-version }} | |
project-path: ./server | |
timeout-minutes: 10 | |
- name: Download version.patch artifact | |
uses: actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # pin v4.1.7 | |
with: | |
name: version.patch | |
path: ${{ runner.temp }}/version.patch | |
run-id: ${{ inputs.version_patch_run_id || github.run_id }} | |
- name: Apply version.patch | |
run: git apply --allow-empty ${{ runner.temp }}/version.patch/version.patch | |
- name: Build wheel | |
uses: pypa/cibuildwheel@711a3d017d0729f3edde18545fee967f03d65f65 # pin v2.18.0 | |
with: | |
package-dir: server | |
output-dir: dist | |
timeout-minutes: 50 | |
- name: Set file for wheel version | |
run: cp -v libparsec/version dist/version | |
- name: Hack the wheel macos version | |
if: startsWith(matrix.os, 'macos-') | |
shell: bash | |
run: | | |
set -eux | |
# Old wheel name | |
OLD_WHEEL_NAME=$(basename dist/parsec_cloud-*.whl) | |
# Unzip the wheel | |
mkdir temp | |
cd temp | |
unzip ../dist/$OLD_WHEEL_NAME | |
# Get platform new wheel name | |
python -m pip install -U pip wheel setuptools | |
PLATFORM=$(python -c "from wheel.bdist_wheel import get_platform; print(get_platform('.'))") | |
NEW_WHEEL_NAME=$(basename ../dist/parsec_cloud-*.whl | sed "s/macosx_.*_x86_64/$PLATFORM/") | |
# Update archive and zip back | |
sed -i "" "s/macosx_.*_x86_64/$PLATFORM/" parsec_cloud-*.dist-info/WHEEL | |
zip -r $NEW_WHEEL_NAME * | |
cd .. | |
# Replace old wheel with the new one | |
mv temp/$NEW_WHEEL_NAME dist/ | |
rm dist/$OLD_WHEEL_NAME | |
rm -rf temp | |
- name: Generate requirements & constraints infos | |
run: python server/packaging/wheel/wheel_it.py ./server --output dist --skip-wheel | |
# Install syft | |
- uses: taiki-e/install-action@c2927f0c5b5adc6a76bc4a7847bc6e0503754bed # pin v2.33.22 | |
with: | |
tool: [email protected] | |
- name: Generate SBOM | |
run: syft packages --config=.syft.yaml --output=spdx-json=dist/Parsec-SBOM-Wheel-${{ matrix.platform }}.spdx.json . | |
- uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # pin v4.3.3 | |
with: | |
name: ${{ runner.os }}-${{ runner.arch }}-wheel | |
path: | | |
dist/ | |
if-no-files-found: error | |
timeout-minutes: 5 |