2023-11-13 16:10:11 +03:00
|
|
|
name: CI Utils
|
|
|
|
on:
|
2023-11-23 17:39:34 +03:00
|
|
|
# it's usually not recommended to use pull_request_target
|
|
|
|
# but we consider it's safe here if we keep the same steps
|
2024-04-04 10:30:55 +03:00
|
|
|
# see: https://securitylab.github.com/research/github-actions-preventing-pwn-requests/
|
2023-11-23 17:39:34 +03:00
|
|
|
# and: https://github.com/facebook/react-native/pull/34370/files
|
|
|
|
pull_request_target:
|
2024-05-21 23:56:25 +03:00
|
|
|
types: [opened, synchronize, reopened, closed]
|
2023-11-23 17:39:34 +03:00
|
|
|
permissions:
|
|
|
|
actions: write
|
|
|
|
checks: write
|
|
|
|
contents: write
|
|
|
|
issues: write
|
|
|
|
pull-requests: write
|
|
|
|
statuses: write
|
2024-04-04 10:30:55 +03:00
|
|
|
concurrency:
|
|
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
|
|
cancel-in-progress: true
|
|
|
|
|
2023-11-13 16:10:11 +03:00
|
|
|
jobs:
|
|
|
|
danger-js:
|
|
|
|
runs-on: ubuntu-latest
|
2024-05-21 23:56:25 +03:00
|
|
|
if: github.event.action != 'closed'
|
2023-11-13 16:10:11 +03:00
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v4
|
chore: use Nx affected tasks in CI (#5110)
Closes #5097
- Uses "nx affected" to detect what projects need to be checked in the
current PR (for now, `ci-front` and `ci-server` workflows only).
- Caches results of certain tasks (`lint`, `typecheck`, `test`,
`storybook:build`) when a PR pipeline runs. The next runs of the same
PR's pipeline will then be able to reuse the PR's task cache to execute
tasks faster.
- Caches Yarn's cache folder to install dependencies faster in CI jobs.
- Rewrites the node modules cache/install steps as a custom, reusable
Github action.
- Distributes `ci-front` jobs with a "matrix" strategy.
- Sets common tasks config at the root `nx.json`. For instance, to
activate the `typecheck` task in a project, add `typecheck: {}` to its
`project.json` and it'll use the default config set in `nx.json` for the
`typecheck` task. Options can be overridden in each individual
`project.json` if needed.
- Adds "scope" tags to some projects: `scope:frontend`, `scope:backend`,
`scope:shared`. An eslint rule ensures that `scope:frontend` only
depends on `scope:frontent` or `scope:shared` projects, same for
`scope:backend`. These tags are used by `nx affected` to filter projects
by scope and generates different task cache keys according to the
requested scope.
- Enables checks for twenty-emails in the `ci-server` workflow.
2024-04-30 17:28:25 +03:00
|
|
|
- name: Install dependencies
|
|
|
|
uses: ./.github/workflows/actions/yarn-install
|
2023-11-13 16:10:11 +03:00
|
|
|
- name: Utils / Run Danger.js
|
2024-04-19 19:28:02 +03:00
|
|
|
run: cd packages/twenty-utils && npx nx danger:ci
|
2023-11-13 16:10:11 +03:00
|
|
|
env:
|
2024-01-05 18:08:19 +03:00
|
|
|
DANGER_GITHUB_API_TOKEN: ${{ github.token }}
|
2024-05-21 23:56:25 +03:00
|
|
|
|
|
|
|
congratulate:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
if: github.event.action == 'closed' && github.event.pull_request.merged == true
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Install dependencies
|
|
|
|
uses: ./.github/workflows/actions/yarn-install
|
|
|
|
- name: Run congratulate-dangerfile.js
|
|
|
|
run: cd packages/twenty-utils && npx nx danger:congratulate
|
|
|
|
env:
|
|
|
|
DANGER_GITHUB_API_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|