name: CI Front on: push: branches: - main pull_request: concurrency: group: ${{ github.workflow }}-${{ github.ref }} cancel-in-progress: true jobs: front-sb-build: timeout-minutes: 30 runs-on: ci-8-cores env: REACT_APP_SERVER_BASE_URL: http://localhost:3000 NX_REJECT_UNKNOWN_LOCAL_CACHE: 0 steps: - name: Cancel Previous Runs uses: styfle/cancel-workflow-action@0.11.0 with: access_token: ${{ github.token }} - name: Fetch local actions uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check for changed files id: changed-files uses: tj-actions/changed-files@v11 with: files: | package.json packages/twenty-front/** packages/twenty-ui/** packages/twenty-shared/** - name: Skip if no relevant changes if: steps.changed-files.outputs.any_changed == 'false' run: echo "No relevant changes. Skipping CI." - name: Install dependencies if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/yarn-install - name: Diagnostic disk space issue if: steps.changed-files.outputs.any_changed == 'true' run: df -h - name: Restore storybook build cache id: storybook-build-cache-restore uses: actions/cache/restore@v4 with: path: | .cache .nx/cache node_modules/.cache packages/*/node_modules/.cache key: storybook-build-ci-8-cores-runner-${{ github.ref_name }}-${{ github.sha }} restore-keys: | storybook-build-ci-8-cores-runner-${{ github.ref_name }}- - name: Front / Write .env if: steps.changed-files.outputs.any_changed == 'true' run: npx nx reset:env twenty-front - name: Front / Build storybook if: steps.changed-files.outputs.any_changed == 'true' run: npx nx storybook:build twenty-front - name: Save storybook build cache if: steps.storybook-build-cache-restore.outputs.cache-hit != 'true' uses: actions/cache/save@v4 with: key: ${{ steps.storybook-build-cache-restore.outputs.cache-primary-key }} path: | .cache .nx/cache node_modules/.cache packages/*/node_modules/.cache front-sb-test: timeout-minutes: 30 runs-on: ci-8-cores needs: front-sb-build strategy: fail-fast: false matrix: shard: [1, 2, 3, 4] storybook_scope: [modules, pages, performance] env: SHARD_COUNTER: 4 REACT_APP_SERVER_BASE_URL: http://localhost:3000 NX_REJECT_UNKNOWN_LOCAL_CACHE: 0 steps: - name: Fetch local actions uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check for changed files id: changed-files uses: tj-actions/changed-files@v11 with: files: | packages/twenty-front/** - name: Skip if no relevant changes if: steps.changed-files.outputs.any_changed == 'false' run: echo "No relevant changes. Skipping CI." - name: Install dependencies if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/yarn-install - name: Install Playwright if: steps.changed-files.outputs.any_changed == 'true' run: cd packages/twenty-front && npx playwright install - name: Restore Storybook build cache uses: actions/cache/restore@v4 with: path: | .cache .nx/cache node_modules/.cache packages/*/node_modules/.cache key: storybook-build-ci-8-cores-runner-${{ github.ref_name }}-${{ github.sha }} restore-keys: | storybook-build-ci-8-cores-runner-${{ github.ref_name }}- - name: Front / Write .env if: steps.changed-files.outputs.any_changed == 'true' run: npx nx reset:env twenty-front - name: Run storybook tests if: steps.changed-files.outputs.any_changed == 'true' run: npx nx storybook:serve-and-test:static twenty-front --configuration=${{ matrix.storybook_scope }} --shard=${{ matrix.shard }}/${{ env.SHARD_COUNTER }} --checkCoverage=false - name: Rename coverage file if: steps.changed-files.outputs.any_changed == 'true' run: mv packages/twenty-front/coverage/storybook/coverage-storybook.json packages/twenty-front/coverage/storybook/coverage-shard-${{matrix.shard}}.json - name: Upload coverage artifact uses: actions/upload-artifact@v4 with: retention-days: 1 name: coverage-artifacts-${{ matrix.storybook_scope }}-${{ github.run_id }}-${{ matrix.shard }} path: packages/twenty-front/coverage/storybook/coverage-shard-${{matrix.shard}}.json merge-reports-and-check-coverage: timeout-minutes: 30 runs-on: ci-8-cores needs: front-sb-test env: PATH_TO_COVERAGE: packages/twenty-front/coverage/storybook strategy: matrix: storybook_scope: [modules, pages, performance] steps: - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check for changed files id: changed-files uses: tj-actions/changed-files@v11 with: files: | packages/twenty-front/** - name: Skip if no relevant changes if: steps.changed-files.outputs.any_changed == 'false' run: echo "No relevant changes. Skipping CI." - name: Install dependencies if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/yarn-install - uses: actions/download-artifact@v4 if: steps.changed-files.outputs.any_changed == 'true' with: pattern: coverage-artifacts-${{ matrix.storybook_scope }}-${{ github.run_id }}-* merge-multiple: true path: coverage-artifacts - name: Merge coverage reports if: steps.changed-files.outputs.any_changed == 'true' run: | mkdir -p ${{ env.PATH_TO_COVERAGE }} npx nyc merge coverage-artifacts ${{ env.PATH_TO_COVERAGE }}/coverage-storybook.json - name: Checking coverage if: steps.changed-files.outputs.any_changed == 'true' run: npx nx storybook:coverage twenty-front --checkCoverage=true front-chromatic-deployment: timeout-minutes: 30 if: contains(github.event.pull_request.labels.*.name, 'run-chromatic') || github.event_name == 'push' needs: front-sb-build runs-on: ci-8-cores env: REACT_APP_SERVER_BASE_URL: http://127.0.0.1:3000 CHROMATIC_PROJECT_TOKEN: ${{ secrets.CHROMATIC_PROJECT_TOKEN }} NX_REJECT_UNKNOWN_LOCAL_CACHE: 0 steps: - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check for changed files id: changed-files uses: tj-actions/changed-files@v11 with: files: | packages/twenty-front/** - name: Skip if no relevant changes if: steps.changed-files.outputs.any_changed == 'false' run: echo "No relevant changes. Skipping CI." - name: Install dependencies if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/yarn-install - name: Restore storybook build cache id: storybook-build-cache-restore uses: actions/cache/restore@v4 with: path: | .cache .nx/cache node_modules/.cache packages/*/node_modules/.cache key: storybook-build-ci-8-cores-runner-${{ github.ref_name }}-${{ github.sha }} restore-keys: | storybook-build-ci-8-cores-runner-${{ github.ref_name }}- - name: Front / Write .env if: steps.changed-files.outputs.any_changed == 'true' run: | cd packages/twenty-front touch .env echo "REACT_APP_SERVER_BASE_URL: $REACT_APP_SERVER_BASE_URL" >> .env - name: Publish to Chromatic if: steps.changed-files.outputs.any_changed == 'true' run: npx nx run twenty-front:chromatic:ci front-task: timeout-minutes: 30 runs-on: ci-8-cores env: NX_REJECT_UNKNOWN_LOCAL_CACHE: 0 strategy: matrix: task: [lint, typecheck, test] steps: - name: Cancel Previous Runs uses: styfle/cancel-workflow-action@0.11.0 with: access_token: ${{ github.token }} - name: Fetch custom Github Actions and base branch history uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check for changed files id: changed-files uses: tj-actions/changed-files@v11 with: files: | packages/twenty-front/** - name: Skip if no relevant changes if: steps.changed-files.outputs.any_changed == 'false' run: echo "No relevant changes. Skipping CI." - name: Install dependencies if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/yarn-install - name: Front / Restore ${{ matrix.task }} task cache if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/task-cache with: tag: scope:frontend tasks: ${{ matrix.task }} - name: Reset .env if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/nx-affected with: tag: scope:frontend tasks: reset:env - name: Run ${{ matrix.task }} task if: steps.changed-files.outputs.any_changed == 'true' uses: ./.github/workflows/actions/nx-affected with: tag: scope:frontend tasks: ${{ matrix.task }}