This PR contains the following updates: | Package | Type | Update | Change | |---|---|---|---| | [astral-sh/setup-uv](https://github.com/astral-sh/setup-uv) | action | minor | `v8.0.0` → `v8.1.0` | --- ### Release Notes <details> <summary>astral-sh/setup-uv (astral-sh/setup-uv)</summary> ### [`v8.1.0`](https://github.com/astral-sh/setup-uv/releases/tag/v8.1.0): 🌈 New input `no-project` [Compare Source](https://github.com/astral-sh/setup-uv/compare/v8.0.0...v8.1.0) #### Changes This add the a new boolean input `no-project`. It only makes sense to use in combination with `activate-environment: true` and will append `--no project` to the `uv venv` call. This is for example useful [if you have a pyproject.toml file with parts unparseable by uv](https://github.com/astral-sh/setup-uv/issues/854) #### 🚀 Enhancements - Add input no-project in combination with activate-environment [@​eifinger](https://github.com/eifinger) ([#​856](https://github.com/astral-sh/setup-uv/issues/856)) #### 🧰 Maintenance - fix: grant contents:write to validate-release job [@​eifinger](https://github.com/eifinger) ([#​860](https://github.com/astral-sh/setup-uv/issues/860)) - Add a release-gate step to the release workflow [@​zanieb](https://github.com/zanieb) ([#​859](https://github.com/astral-sh/setup-uv/issues/859)) - Draft commitish releases [@​eifinger](https://github.com/eifinger) ([#​858](https://github.com/astral-sh/setup-uv/issues/858)) - Add action-types.yml to instructions [@​eifinger](https://github.com/eifinger) ([#​857](https://github.com/astral-sh/setup-uv/issues/857)) - chore: update known checksums for 0.11.7 @​[github-actions\[bot\]](https://github.com/apps/github-actions) ([#​853](https://github.com/astral-sh/setup-uv/issues/853)) - Refactor version resolving [@​eifinger](https://github.com/eifinger) ([#​852](https://github.com/astral-sh/setup-uv/issues/852)) - chore: update known checksums for 0.11.6 @​[github-actions\[bot\]](https://github.com/apps/github-actions) ([#​850](https://github.com/astral-sh/setup-uv/issues/850)) - chore: update known checksums for 0.11.5 @​[github-actions\[bot\]](https://github.com/apps/github-actions) ([#​845](https://github.com/astral-sh/setup-uv/issues/845)) - chore: update known checksums for 0.11.4 @​[github-actions\[bot\]](https://github.com/apps/github-actions) ([#​843](https://github.com/astral-sh/setup-uv/issues/843)) - Add a release workflow [@​zanieb](https://github.com/zanieb) ([#​839](https://github.com/astral-sh/setup-uv/issues/839)) - chore: update known checksums for 0.11.3 @​[github-actions\[bot\]](https://github.com/apps/github-actions) ([#​836](https://github.com/astral-sh/setup-uv/issues/836)) #### 📚 Documentation - Update ignore-nothing-to-cache documentation [@​eifinger](https://github.com/eifinger) ([#​833](https://github.com/astral-sh/setup-uv/issues/833)) - Pin setup-uv docs to v8 [@​eifinger](https://github.com/eifinger) ([#​829](https://github.com/astral-sh/setup-uv/issues/829)) #### ⬆️ Dependency updates - chore(deps): bump release-drafter/release-drafter from 7.1.1 to 7.2.0 @​[dependabot\[bot\]](https://github.com/apps/dependabot) ([#​855](https://github.com/astral-sh/setup-uv/issues/855)) </details> --- ### Configuration 📅 **Schedule**: (UTC) - Branch creation - At any time (no schedule defined) - Automerge - At any time (no schedule defined) 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My4xMjYuMCIsInVwZGF0ZWRJblZlciI6IjQzLjEyNi4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJ0eXBlL2RlcGVuZGVuY2llcyJdfQ==--> Reviewed-on: https://git.tainton.uk/repos/pypilot/pulls/436 Co-authored-by: renovate[bot] <renovate-bot@git.tainton.uk> Co-committed-by: renovate[bot] <renovate-bot@git.tainton.uk>
183 lines
5.8 KiB
YAML
183 lines
5.8 KiB
YAML
name: Release
|
|
on:
|
|
workflow_dispatch:
|
|
schedule:
|
|
- cron: "0 9 * * 0"
|
|
|
|
jobs:
|
|
# test:
|
|
# name: Test
|
|
# uses: https://git.tainton.uk/repos/pypilot/.gitea/workflows/ci.yml@main
|
|
|
|
tag:
|
|
name: Tag release
|
|
uses: https://git.tainton.uk/actions/gha-workflows/.gitea/workflows/release-with-tag.yaml@main
|
|
|
|
create_release:
|
|
name: Create Release
|
|
needs: tag
|
|
uses: https://git.tainton.uk/actions/gha-workflows/.gitea/workflows/create-release-preexisting-tag.yaml@main
|
|
with:
|
|
tag: ${{ needs.tag.outputs.tag_name }}
|
|
body: ${{ needs.tag.outputs.changelog }}
|
|
secrets:
|
|
ACTIONS_TOKEN: ${{ secrets.ACTIONS_TOKEN }}
|
|
|
|
get_release_id:
|
|
name: Get Release ID
|
|
runs-on: ubuntu-latest
|
|
needs: [tag, create_release]
|
|
outputs:
|
|
releaseid: ${{ steps.getid.outputs.releaseid }}
|
|
steps:
|
|
- name: Get Release ID
|
|
id: getid
|
|
run: |
|
|
rid=$(curl -s -X 'GET' \
|
|
-H 'accept: application/json' \
|
|
'${{ gitea.server_url }}/api/v1/repos/${{ gitea.repository }}/releases/latest' | jq -r '.id')
|
|
echo "releaseid=$rid" >> "$GITEA_OUTPUT"
|
|
echo "$rid"
|
|
|
|
build_whl:
|
|
name: Build Wheel File
|
|
needs: [tag, get_release_id]
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: actions/checkout@v6.0.2
|
|
with:
|
|
ref: ${{ needs.tag.outputs.tag_name }}
|
|
# - name: Setup Python
|
|
# uses: actions/setup-python@v5
|
|
# with:
|
|
# python-version: "3.13"
|
|
- name: Install uv
|
|
uses: astral-sh/setup-uv@v8.1.0
|
|
with:
|
|
enable-cache: true
|
|
cache-dependency-glob: "uv.lock"
|
|
- name: Set up Python
|
|
run: uv python install
|
|
- name: Update pyproject.toml
|
|
run: ./tools/update_pyproject.sh ${{ needs.tag.outputs.tag_name }}
|
|
- name: Install dependencies
|
|
run: uv sync
|
|
- name: Build wheel file
|
|
run: uv build
|
|
- name: Upload Release Asset
|
|
run: |
|
|
for file in dist/*.whl; do
|
|
curl -s -X POST \
|
|
-H "Authorization: token ${{ secrets.ACTIONS_TOKEN }}" \
|
|
-H "Content-Type: multipart/form-data" \
|
|
-F "attachment=@${{ gitea.workspace }}/$file" \
|
|
"${{ gitea.server_url }}/api/v1/repos/${{ gitea.repository }}/releases/${{ needs.get_release_id.outputs.releaseid }}/assets"
|
|
done
|
|
- name: Publish to PyPI
|
|
run: uv publish
|
|
env:
|
|
UV_PUBLISH_TOKEN: ${{ secrets.PYPI_API_TOKEN }}
|
|
# - name: Publish to PyPI
|
|
# uses: pypa/gh-action-pypi-publish@release/v1
|
|
# with:
|
|
# # user: ${{ vars.PYPI_USERNAME }}
|
|
# user: __token__
|
|
# password: ${{ secrets.PYPI_API_TOKEN }}
|
|
|
|
# publish_pypi:
|
|
# name: Publish to PyPI
|
|
# needs: build_whl
|
|
# runs-on: ubuntu-latest
|
|
# steps:
|
|
# - name: Create dist folder
|
|
# run: mkdir -p dist
|
|
# - uses: actions/download-artifact@v4
|
|
# with:
|
|
# name: whl
|
|
# path: dist
|
|
# - name: Publish to PyPI
|
|
# uses: pypa/gh-action-pypi-publish@release/v1
|
|
# with:
|
|
# # user: ${{ vars.PYPI_USERNAME }}
|
|
# user: __token__
|
|
# password: ${{ secrets.PYPI_API_TOKEN }}
|
|
|
|
create_docker:
|
|
name: Publish Docker Images
|
|
runs-on: ubuntu-latest
|
|
needs: tag
|
|
steps:
|
|
- name: Update Docker configuration
|
|
continue-on-error: true
|
|
run: |
|
|
mkdir -p /etc/default
|
|
mkdir -p /etc/docker
|
|
touch -a /etc/default/docker
|
|
touch -a /etc/docker/daemon.json
|
|
echo "DOCKER_OPTS=\"--insecure-registry ${{ vars.PACKAGES_REGISTRY_URL }}\"" >> /etc/default/docker
|
|
echo "{\"insecure-registries\": [\"${{ vars.PACKAGES_REGISTRY_URL }}\"]}" > /etc/docker/daemon.json
|
|
|
|
- name: Get repo name
|
|
id: split
|
|
run: echo "repo=${REPO##*/}" >> "$GITEA_OUTPUT"
|
|
env:
|
|
REPO: ${{ gitea.repository }}
|
|
|
|
- name: Check out repository
|
|
uses: actions/checkout@v6.0.2
|
|
with:
|
|
fetch-depth: 0
|
|
ref: ${{ needs.tag.outputs.tag_name }}
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v4
|
|
|
|
- name: Log in to Gitea Container Registry
|
|
uses: docker/login-action@v4
|
|
with:
|
|
registry: ${{ vars.PACKAGES_REGISTRY_URL }}
|
|
username: ${{ vars.ACTIONS_USERNAME }}
|
|
password: ${{ secrets.ACTIONS_TOKEN }}
|
|
|
|
- name: Log in to GitHub Container Registry
|
|
uses: docker/login-action@v4
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ vars.GHCR_USERNAME }}
|
|
password: ${{ secrets.GHCR_TOKEN }}
|
|
|
|
- name: Extract metadata (tags, labels) for Docker
|
|
id: meta
|
|
uses: docker/metadata-action@v6
|
|
with:
|
|
tags: type=semver,pattern=v{{version}},value=${{ needs.tag.outputs.tag_name }}
|
|
images: |
|
|
ghcr.io/${{ vars.GHCR_USERNAME }}/${{ steps.split.outputs.repo }}
|
|
${{ vars.PACKAGES_REGISTRY_URL }}/${{ gitea.repository }}
|
|
|
|
- name: Print metadata
|
|
run: |
|
|
printf "Annotations:\n${{ steps.meta.outputs.annotations }}"
|
|
echo ""
|
|
printf "Labels:\n${{ steps.meta.outputs.labels }}"
|
|
echo ""
|
|
printf "Tags:\n${{ steps.meta.outputs.tags }}"
|
|
|
|
- name: Build images
|
|
uses: docker/build-push-action@v7
|
|
with:
|
|
context: .
|
|
push: false
|
|
load: true
|
|
annotations: ${{ steps.meta.outputs.annotations }}
|
|
labels: ${{ steps.meta.outputs.labels }}
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
|
|
- name: Push images
|
|
run: |
|
|
strtags="${{ steps.meta.outputs.tags }}"
|
|
readarray -t lines <<<"$strtags"
|
|
for element in "${lines[@]}"; do docker push "$element"; done
|
|
unset strtags lines
|