chore: refactor codebase #109
Workflow file for this run
This file contains hidden or 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 | |
| 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 |