ci: auto-sync docker hub description from docker/DOCKER_README.md #1537
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 | |
| permissions: | |
| contents: read | |
| on: | |
| push: | |
| branches: [main] | |
| pull_request: | |
| branches: [main] | |
| workflow_dispatch: | |
| jobs: | |
| lint: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: 22 | |
| cache: npm | |
| - run: npm ci | |
| - run: npm run lint | |
| backend-postgres: | |
| name: Backend (PostgreSQL) | |
| runs-on: ubuntu-latest | |
| services: | |
| postgres: | |
| image: postgres:16 | |
| env: | |
| POSTGRES_USER: myuser | |
| POSTGRES_PASSWORD: mypassword | |
| POSTGRES_DB: mydatabase | |
| ports: | |
| - 5432:5432 | |
| options: >- | |
| --health-cmd "pg_isready -U myuser -d mydatabase" | |
| --health-interval 10s | |
| --health-timeout 5s | |
| --health-retries 5 | |
| env: | |
| DATABASE_URL: postgresql://myuser:mypassword@localhost:5432/mydatabase | |
| BETTER_AUTH_SECRET: ci-test-secret-at-least-32-characters-long!! | |
| NODE_ENV: test | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: 22 | |
| cache: npm | |
| - run: npm ci | |
| - run: npm run build --workspace=packages/shared | |
| - run: npx tsc --noEmit | |
| working-directory: packages/backend | |
| - run: npm run build --workspace=packages/backend | |
| - name: Test migrations | |
| run: npm run migration:run --workspace=packages/backend | |
| - run: npm test --workspace=packages/backend -- --coverage --coverageReporters=lcov | |
| - run: npm run test:e2e --workspace=packages/backend -- --coverage --coverageReporters=lcov | |
| - name: Upload backend coverage to Codecov | |
| if: always() | |
| uses: codecov/codecov-action@v5 | |
| with: | |
| token: ${{ secrets.CODECOV_TOKEN }} | |
| flags: backend | |
| directory: packages/backend/coverage | |
| fail_ci_if_error: false | |
| frontend: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: 22 | |
| cache: npm | |
| - run: npm ci | |
| - run: npm run build --workspace=packages/shared | |
| - run: npx tsc --noEmit | |
| working-directory: packages/frontend | |
| - run: npm test --workspace=packages/frontend -- --coverage | |
| - run: npx vite build | |
| working-directory: packages/frontend | |
| env: | |
| CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} | |
| - name: Upload frontend coverage to Codecov | |
| if: always() | |
| uses: codecov/codecov-action@v5 | |
| with: | |
| token: ${{ secrets.CODECOV_TOKEN }} | |
| flags: frontend | |
| directory: packages/frontend/coverage | |
| fail_ci_if_error: false | |
| shared: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: 22 | |
| cache: npm | |
| - run: npm ci | |
| - run: npm run build --workspace=packages/shared | |
| - run: npm test --workspace=packages/shared -- --coverage --coverageReporters=lcov | |
| - name: Upload shared coverage to Codecov | |
| if: always() | |
| uses: codecov/codecov-action@v5 | |
| with: | |
| token: ${{ secrets.CODECOV_TOKEN }} | |
| flags: shared | |
| directory: packages/shared/coverage | |
| fail_ci_if_error: false | |
| changeset-check: | |
| name: Changeset status | |
| runs-on: ubuntu-latest | |
| if: github.event_name == 'pull_request' && github.head_ref != 'changeset-release/main' | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: 22 | |
| cache: npm | |
| - run: npm ci | |
| - name: Check changeset status | |
| run: npx changeset status --since=origin/main | |
| continue-on-error: true |