Skip to content

Merge branch 'main' into apl-430 #1059

Merge branch 'main' into apl-430

Merge branch 'main' into apl-430 #1059

Workflow file for this run

# Linode APL default Workflow
#
# Given facts:
# * We don't allow manual tagging, but let the workflow create them after tests have passed.
# * We don't let workflows be triggered by events coming from tags
# * We use `npm run release` (without automated tagging) which only bumps version and creates changelog and commit message with title 'chore(release): v${semverVersion}'
# * Pipeline detects the release title and after tests pass, creates artifacts (images) and makes full tag copies (and github release) to allow release patching.
name: Build test push release
on:
push:
branches:
- '**'
tags-ignore:
- '*'
env:
COMMIT_MSG: ${{ github.event.head_commit.message }}
CACHE_REGISTRY: ghcr.io
CACHE_REPO: linode/apl-tasks
REPO: linode/apl-tasks
DOCKER_PASSWORD: ${{ secrets.DOCKERHUB_LINODEBOT_TOKEN }}
DOCKER_USERNAME: ${{ vars.DOCKERHUB_LINODEBOT_USERNAME }}
BOT_EMAIL: ${{ vars.BOT_EMAIL }}
BOT_USERNAME: ${{ vars.BOT_USERNAME }}
BOT_TOKEN: ${{ secrets.BOT_TOKEN }}
jobs:
build-test-push-release:
if: "((contains(github.event.head_commit.message, 'chore(release)') && github.ref == 'refs/heads/main') || !contains(github.event.head_commit.message, 'chore(release)')) && !contains(github.event.head_commit.message, 'ci skip') && !startsWith(github.ref, 'refs/tags/')"
runs-on: ubuntu-22.04
steps:
- name: Set env
run: |
set -u
tag=$(echo $(basename $GITHUB_REF))
echo "Creating tag: $tag"
echo "TAG=$tag" >> $GITHUB_ENV
- name: Checkout
uses: actions/checkout@v4
- name: CI tests, image build and push tag to cache for main or branch
uses: whoan/docker-build-with-cache-action@v8
with:
username: ${{ env.BOT_USERNAME }}
password: '${{ env.BOT_TOKEN }}'
registry: ${{ env.CACHE_REGISTRY }}
image_name: ${{ env.CACHE_REPO }}
image_tag: ${{ env.TAG }}
build_extra_args: '--build-arg=NPM_TOKEN=${{ secrets.GITHUB_TOKEN }}'
- name: Retag from cache and push
if: ${{ github.actor != 'dependabot[bot]' }}
run: |
set -u
docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD
docker tag $CACHE_REGISTRY/$CACHE_REPO:$TAG $REPO:$TAG
docker push $REPO:$TAG
- if: "contains(github.event.head_commit.message, 'chore(release)')"
name: Create latest and push git tag
id: git_tag
run: |
set -u
docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD
docker tag $REPO:$TAG $REPO:latest
docker push $REPO:latest
release_tag=v$(jq -r '.version' < package.json)
echo tag=$release_tag >> $GITHUB_OUTPUT
echo "Releasing $REPO:$release_tag"
docker tag $REPO:$TAG $REPO:$release_tag
docker push $REPO:$release_tag
git config --global user.email $BOT_EMAIL
git config --global user.name $BOT_USERNAME
echo "machine github.com login $BOT_USERNAME password $BOT_TOKEN" > ~/.netrc
git tag -am "$COMMIT_MSG" $release_tag && git push --follow-tags origin main
changelog=$(cat CHANGELOG.md | awk -v n=2 '/### \[[0-9]*/&&!--n{exit}{print}')
# now do some escaping because github does not help us here:
changelog="${changelog//'%'/'%25'}"
changelog="${changelog//$'\n'/'%0A'}"
changelog="${changelog//$'\r'/'%0D'}"
echo changes=$changelog >> $GITHUB_OUTPUT
- if: "contains(github.event.head_commit.message, 'chore(release)')"
name: Create GitHub release
uses: ncipollo/[email protected]
env:
token: ${{ secrets.GITHUB_TOKEN }}
with:
tag: ${{ steps.git_tag.outputs.tag }}
name: Release ${{ steps.git_tag.outputs.tag }}
body: ${{ steps.git_tag.outputs.changes }}