fix: use ubuntu-24.04 in goreleaser-weekly #126
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: goreleaser-weekly | |
on: | |
push: | |
branches: | |
- 'weekly/f*' | |
jobs: | |
goreleaser-weekly: | |
runs-on: ubuntu-24.04 | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: Set GORELEASER_CURRENT_TAG | |
run: echo "GORELEASER_CURRENT_TAG=v0.0.0-$(./tools/image-tag)" >> $GITHUB_ENV | |
- name: Set WEEKLY_IMAGE_TAG | |
run: echo "WEEKLY_IMAGE_TAG=$(./tools/image-tag)" >> $GITHUB_ENV | |
- name: Set GORELEASER_STRIP_DEBUG_INFO=false, so binaries are not stripped of debug info | |
run: echo "GORELEASER_STRIP_DEBUG_INFO=false" >> $GITHUB_ENV | |
# Forces goreleaser to use the correct previous tag for the changelog | |
- name: Set GORELEASER_PREVIOUS_TAG | |
run: echo "GORELEASER_PREVIOUS_TAG=$(git tag -l --sort=-version:refname | grep -E '^weekly-.*' | head -n 2 | tail -1)" >> $GITHUB_ENV | |
- run: git fetch --force --tags | |
- name: Create tags for this weekly release | |
run: | | |
git tag "$GORELEASER_CURRENT_TAG" | |
git tag "$WEEKLY_IMAGE_TAG" | |
- uses: actions/setup-go@v3 | |
with: | |
go-version: "1.21.12" | |
cache: true | |
# setup docker buildx | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
# login to docker hub | |
- uses: docker/login-action@v2 | |
name: Login to Docker Hub | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_TOKEN }} | |
- uses: actions/setup-node@v3 | |
with: | |
node-version: lts/hydrogen | |
cache: yarn | |
- run: make frontend/build | |
- name: Get github app token (valid for an hour) | |
id: app-goreleaser | |
uses: tibdex/github-app-token@v1 | |
with: | |
app_id: ${{ secrets.APP_ID }} | |
private_key: ${{ secrets.APP_PRIVATE_KEY }} | |
- uses: goreleaser/goreleaser-action@v6 | |
with: | |
# ensure this aligns with the version specified in the /Makefile | |
version: v2.0.1 | |
args: release --clean --skip=publish --timeout 60m | |
env: | |
GITHUB_TOKEN: ${{ steps.app-releaser.outputs.token }} | |
- name: Push per architecture images and create multi-arch manifest | |
run: | | |
set +x | |
IMAGE_AMMENDS=() | |
# the grep needs to remove an extra v, which is in the git tag, but not in the image tag | |
for image in $(docker images --format '{{.Repository}}:{{.Tag}}' | grep "grafana/pyroscope:${GORELEASER_CURRENT_TAG:1}-"); do | |
new_image="${image/0.0.0-/}" | |
docker tag "${image}" "${new_image}" | |
docker push "${new_image}" | |
IMAGE_AMMENDS+=( "--amend" "${new_image}" ) | |
done | |
docker manifest create "grafana/pyroscope:${WEEKLY_IMAGE_TAG}" "${IMAGE_AMMENDS[@]}" | |
docker manifest push "grafana/pyroscope:${WEEKLY_IMAGE_TAG}" | |
- name: Get github app token (valid for an hour) | |
id: app-git-tag | |
uses: tibdex/github-app-token@v1 | |
with: | |
app_id: ${{ secrets.APP_ID }} | |
private_key: ${{ secrets.APP_PRIVATE_KEY }} | |
- name: Push git tag for weekly release | |
run: git push https://x-access-token:${{ steps.app-git-tag.output.token }}@github.com/grafana/pyroscope.git "${WEEKLY_IMAGE_TAG}" |