name: CI on: push: branches: [main, develop] pull_request: branches: [main, develop] jobs: test: name: Test & Build runs-on: ubuntu-latest strategy: matrix: node-version: [18.x, 20.x] steps: - name: Checkout code uses: actions/checkout@v4 - name: Setup Node.js ${{ matrix.node-version }} uses: actions/setup-node@v4 with: node-version: ${{ matrix.node-version }} cache: 'npm' - name: Install dependencies run: npm ci - name: Run linter run: npm run lint - name: Run type check run: npm run type-check - name: Run tests run: npm run test:run - name: Run tests with coverage run: npm run test:coverage - name: Upload coverage to Codecov uses: codecov/codecov-action@v4 with: token: ${{ secrets.CODECOV_TOKEN }} files: ./coverage/coverage-final.json flags: unittests name: codecov-umbrella fail_ci_if_error: false - name: Build application run: npm run build env: VITE_BACKEND_API_URL: ${{ secrets.VITE_BACKEND_API_URL }} - name: Upload build artifacts uses: actions/upload-artifact@v4 with: name: dist-${{ matrix.node-version }} path: dist/ retention-days: 7 security: name: Security Audit runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 - name: Setup Node.js uses: actions/setup-node@v4 with: node-version: '20.x' - name: Run npm audit run: npm audit --audit-level=moderate continue-on-error: true - name: Run Snyk security scan uses: snyk/actions/node@master continue-on-error: true env: SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }}