fix first level spell ordering #154
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: CI compile & test & build | |
on: | |
push: | |
branches: [ "main" ] | |
pull_request: | |
branches: [ "main" ] | |
jobs: | |
ci-fe: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Setup Node.js 18.x | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 18.x | |
- name: Cache NPM packages | |
uses: actions/cache@v4 | |
with: | |
key: npm-${{ hashFiles('./frontend/yarn.lock') }} | |
path: | | |
./frontend/node_modules | |
restore-keys: | | |
npm-${{ hashFiles('./frontend/yarn.lock') }} | |
npm- | |
- name: Yarn Install | |
run: | | |
cd ./frontend | |
yarn install --frozen-lockfiles | |
- name: Yarn Test | |
run: | | |
cd ./frontend | |
./compile-less.sh | |
yarn run test | |
docker-fe-build: | |
runs-on: ubuntu-latest | |
outputs: | |
image_tag: ${{ steps.get_image_tag.outputs.image_tag }} | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: docker/setup-buildx-action@v3 | |
- name: Install doctl | |
uses: digitalocean/action-doctl@v2 | |
with: | |
token: ${{ secrets.DO_ACCESS_TOKEN }} | |
- name: Log in to DigitalOcean Container Registry with short-lived credentials | |
run: doctl registry login --expiry-seconds 1200 | |
- name: Log in to GitHub Container Registry | |
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin | |
- id: get_image_tag | |
run: | | |
echo "GITHUB_SHA_SHORT=$(echo ${GITHUB_SHA::8})" >> $GITHUB_ENV | |
echo "registry.digitalocean.com/kemkas/kemkas-fe:${GITHUB_SHA::8}" | |
echo "ghcr.io/${{ github.repository_owner }}/kemkas-frontend:${GITHUB_SHA::8}" | |
echo "image_tag=registry.digitalocean.com/kemkas/kemkas-fe:${GITHUB_SHA::8}" >> $GITHUB_OUTPUT | |
- uses: docker/build-push-action@v5 | |
with: | |
context: ./frontend/ | |
file: ./frontend/Dockerfile | |
cache-from: type=gha | |
cache-to: type=gha,mode=max | |
push: false | |
load: true | |
tags: | | |
registry.digitalocean.com/kemkas/kemkas-fe:${{ env.GITHUB_SHA_SHORT }} | |
ghcr.io/${{ github.repository_owner }}/kemkas-frontend:${{ env.GITHUB_SHA_SHORT }} | |
- name: Push image to Container Registry | |
run: | | |
docker push registry.digitalocean.com/kemkas/kemkas-fe:${GITHUB_SHA::8} | |
docker push ghcr.io/${{ github.repository_owner }}/kemkas-frontend:${GITHUB_SHA::8} | |
deploy-to-beta: | |
runs-on: ubuntu-latest | |
needs: | |
- docker-fe-build | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
repository: ${{ github.repository_owner }}/kemkas-deployment | |
ref: refs/heads/main | |
ssh-key: ${{ secrets.DEPLOYMENT_REPO_DEPLOY_KEY }} | |
- uses: mikefarah/yq@v4 | |
with: | |
cmd: yq -i '.spec.template.spec.containers[0].image = "${{ needs.docker-fe-build.outputs.image_tag }}"' ./kemkas-beta/kemkas-fe-deployment.yaml | |
- run: | | |
git config --add user.email "[email protected]" | |
git config --add user.name "Deployment Bot Beta FE" | |
git commit -a -m "deploy ${{ needs.docker-fe-build.outputs.image_tag }}" | |
git push |