Skip to content

chore: refactor codebase #107

chore: refactor codebase

chore: refactor codebase #107

Workflow file for this run

name: CI
on:
push:
branches:
- main
pull_request:
permissions:
contents: write
packages: write
pull-requests: write
jobs:
lint:
name: Lint
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup bun
uses: oven-sh/setup-bun@v2
with:
bun-version: ${{ env.BUN_VERSION }}
- name: Install Dependencies
run: bun install --frozen-lockfile
- name: Lint
run: bun run lint
build:
name: Build
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup bun
uses: oven-sh/setup-bun@v2
with:
bun-version: ${{ env.BUN_VERSION }}
- name: Install Dependencies
run: bun install --frozen-lockfile
- name: Build
env:
ADMIN_EMAIL: ${{ secrets.ADMIN_EMAIL }}
ADMIN_PASSWORD: ${{ secrets.ADMIN_PASSWORD }}
POCKETBASE_URL: ${{ secrets.POCKETBASE_URL }}
run: bun run build
test:
name: Test
needs: build
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup bun
uses: oven-sh/setup-bun@v2
with:
bun-version: ${{ env.BUN_VERSION }}
- name: Install Dependencies
run: bun install --frozen-lockfile
- name: Test
env:
ADMIN_EMAIL: ${{ secrets.ADMIN_EMAIL }}
ADMIN_PASSWORD: ${{ secrets.ADMIN_PASSWORD }}
POCKETBASE_URL: ${{ secrets.POCKETBASE_URL }}
run: bun run test
changelog:
name: Changelog
needs:
- lint
- build
- test
if: github.event_name != 'pull_request'
runs-on: ubuntu-latest
outputs:
skipped: ${{ steps.changelog.outputs.skipped }}
tag: ${{ steps.changelog.outputs.tag }}
clean_changelog: ${{ steps.changelog.outputs.clean_changelog }}
version: ${{ steps.changelog.outputs.version }}
env:
PR_BRANCH: release/ci-${{ github.sha }}
steps:
- uses: actions/checkout@v4
- name: Create Branch
run: |
git checkout -b ${{ env.PR_BRANCH }}
- name: Create Changelog
uses: TriPSs/conventional-changelog-action@v5
id: changelog
with:
github-token: ${{ github.token }}
git-user-name: 'github-actions[bot]'
git-user-email: 'github-actions[bot]@users.noreply.github.com'
git-branch: ${{ env.PR_BRANCH }}
skip-git-pull: true
output-file: false
version-file: package.json
create-summary: true
- name: Create Changelog PR
if: steps.changelog.outputs.skipped == 'false'
env:
GH_TOKEN: ${{ github.token }}
run: |
gh pr create --base main --head ${{ env.PR_BRANCH }} --title 'chore(release): ${{ steps.changelog.outputs.tag }} [skip-ci]' --body '${{ steps.changelog.outputs.clean_changelog }}'
- name: Merge Changelog PR
if: steps.changelog.outputs.skipped == 'false'
env:
GH_TOKEN: ${{ github.token }}
run: |
gh pr merge --squash --delete-branch ${{ env.PR_BRANCH }}
release:
name: Release
needs: changelog
if: github.event_name != 'pull_request' && needs.changelog.outputs.skipped == 'false'
runs-on: ubuntu-latest
steps:
- name: Create Release
uses: softprops/action-gh-release@v1
with:
tag_name: ${{ needs.changelog.outputs.tag }}
prerelease: false
draft: false
generate_release_notes: true
name: ${{ needs.changelog.outputs.tag }}
body: |
<details>
<summary>Changelog</summary>
${{ needs.changelog.outputs.clean_changelog }}
</details>
build-deploy:
name: Build & Push
needs: [changelog, release]
runs-on: ubuntu-latest
steps:
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ github.token }}
- name: Checkout
uses: actions/checkout@v4
- name: Update env
run: |
echo "REGISTRY_DIR=${GITHUB_REPOSITORY_OWNER@L}" >> "${GITHUB_ENV}"
- name: Build
working-directory: ./resources/deployment
run: |
docker compose -f compose.production.yml build
docker tag ghcr.io/${{ env.REGISTRY_DIR }}/shapez-base ghcr.io/${{ env.REGISTRY_DIR }}/shapez-base:${{ needs.changelog.outputs.tag }}
docker tag ghcr.io/${{ env.REGISTRY_DIR }}/shapez-proxy ghcr.io/${{ env.REGISTRY_DIR }}/shapez-proxy:${{ needs.changelog.outputs.tag }}
- name: Push
run: |
docker image ls
docker push -a ghcr.io/${{ env.REGISTRY_DIR }}/shapez-base
docker push -a ghcr.io/${{ env.REGISTRY_DIR }}/shapez-proxy
deploy:
name: Deploy
needs: build-deploy
environment: production
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Create Context
uses: amirmarmul/docker-context-ssh-action@v2.1.3
with:
ssh-host: ${{ secrets.DEPLOYMENT_SSH_HOST }}
ssh-username: ${{ secrets.DEPLOYMENT_SSH_USER }}
ssh-private-key: ${{ secrets.DEPLOYMENT_SSH_KEY }}
context-use: true
- name: Deploy
working-directory: ./resources/deployment
# todo use docker stack deploy
run: |
docker compose -f compose.production.yml up -d --force-recreate --pull always