Build test push release #1091
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
# 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/release-action@v1.15.0 | |
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 }} | |