## Motivations This is not because we've hit the `actions/cache/restore` cache that NX won't be re-building sub commands. Which means the grain to save or not the cache should be extracted from nx sub commands and not from the `actions/cache` outputs. We should investigate on the way to retrieve this granularity level From the moment we will be saving everything, which could result sometimes in duplicating cache instances. We should keep in mind that our cache occurrences have a 1 day retention date, is low cost and pretty fast to perform
259 lines
9.5 KiB
YAML
259 lines
9.5 KiB
YAML
name: CI Front
|
|
on:
|
|
push:
|
|
branches:
|
|
- main
|
|
|
|
pull_request:
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
env:
|
|
STORYBOOK_BUILD_CACHE_KEY: storybook-build-depot-ubuntu-24.04-8-runner
|
|
|
|
jobs:
|
|
front-sb-build:
|
|
timeout-minutes: 30
|
|
runs-on: depot-ubuntu-24.04-8
|
|
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: restore-storybook-build-cache
|
|
if: steps.changed-files.outputs.any_changed == 'true'
|
|
uses: ./.github/workflows/actions/restore-cache
|
|
with:
|
|
key: ${{ env.STORYBOOK_BUILD_CACHE_KEY }}
|
|
- 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.changed-files.outputs.any_changed == 'true'
|
|
uses: ./.github/workflows/actions/save-cache
|
|
with:
|
|
key: ${{ steps.restore-storybook-build-cache.outputs.cache-primary-key }}
|
|
front-sb-test:
|
|
timeout-minutes: 30
|
|
runs-on: depot-ubuntu-24.04-8
|
|
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
|
|
if: steps.changed-files.outputs.any_changed == 'true'
|
|
uses: ./.github/workflows/actions/restore-cache
|
|
with:
|
|
key: ${{ env.STORYBOOK_BUILD_CACHE_KEY }}
|
|
- 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
|
|
if: steps.changed-files.outputs.any_changed == 'true'
|
|
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: depot-ubuntu-24.04-8
|
|
needs: front-sb-test
|
|
env:
|
|
PATH_TO_COVERAGE: packages/twenty-front/coverage/storybook
|
|
strategy:
|
|
matrix:
|
|
storybook_scope: [modules, pages]
|
|
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: depot-ubuntu-24.04-8
|
|
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
|
|
if: steps.changed-files.outputs.any_changed == 'true'
|
|
uses: ./.github/workflows/actions/restore-cache
|
|
with:
|
|
key: ${{ env.STORYBOOK_BUILD_CACHE_KEY }}
|
|
- 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: depot-ubuntu-24.04-8
|
|
env:
|
|
NX_REJECT_UNKNOWN_LOCAL_CACHE: 0
|
|
TASK_CACHE_KEY: front-task-${{ matrix.task }}
|
|
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: Restore ${{ matrix.task }} cache
|
|
id: restore-task-cache
|
|
if: steps.changed-files.outputs.any_changed == 'true'
|
|
uses: ./.github/workflows/actions/restore-cache
|
|
with:
|
|
key: ${{ env.TASK_CACHE_KEY }}
|
|
- 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 }}
|
|
- name: Save ${{ matrix.task }} cache
|
|
if: steps.changed-files.outputs.any_changed == 'true'
|
|
uses: ./.github/workflows/actions/save-cache
|
|
with:
|
|
key: ${{ steps.restore-task-cache.outputs.cache-primary-key }}
|