The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/.github/workflows/ci-code-check.yml

120 lines
3.7 KiB

name: Code Checks
on:
workflow_call:
inputs:
node-version:
required: true
type: string
deno-version:
required: true
type: string
env:
TOOL_NODE_FLAGS: ${{ vars.TOOL_NODE_FLAGS }}
jobs:
code-check:
runs-on: ubuntu-24.04-arm
name: ${{ matrix.check == 'ts' && 'TypeScript' || 'Code Lint' }}
strategy:
fail-fast: false
matrix:
check: ['ts', 'lint']
steps:
- name: Set Swap Space
uses: pierotofy/set-swap-space@master
with:
swap-size-gb: 4
- uses: actions/checkout@v6
- name: Setup NodeJS
uses: ./.github/actions/setup-node
with:
node-version: ${{ inputs.node-version }}
deno-version: ${{ inputs.deno-version }}
cache-modules: true
install: true
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
- uses: rharkor/caching-for-turbo@v1.8
- uses: ./.github/actions/restore-packages
- name: Restore TypeScript incremental cache
id: restore-typecheck
if: matrix.check == 'ts'
uses: actions/cache/restore@v5
with:
path: ./apps/meteor/tsconfig.typecheck.tsbuildinfo
key: typecheck-cache-${{ runner.os }}-${{ hashFiles('yarn.lock') }}
restore-keys: |
typecheck-cache-${{ runner.os }}-
- name: Cache observability (typecheck)
if: matrix.check == 'ts'
run: |
echo "### TypeScript incremental cache" >> $GITHUB_STEP_SUMMARY
echo "- **exact hit**: \`${{ steps.restore-typecheck.outputs.cache-hit }}\`" >> $GITHUB_STEP_SUMMARY
- name: Install Meteor
shell: bash
run: |
# Restore bin from cache
set +e
METEOR_SYMLINK_TARGET=$(readlink ~/.meteor/meteor)
METEOR_TOOL_DIRECTORY=$(dirname "$METEOR_SYMLINK_TARGET")
set -e
LAUNCHER=$HOME/.meteor/$METEOR_TOOL_DIRECTORY/scripts/admin/launch-meteor
if [ -e $LAUNCHER ]
then
echo "Cached Meteor bin found, restoring it"
sudo cp "$LAUNCHER" "/usr/local/bin/meteor"
else
echo "No cached Meteor bin found."
fi
# only install meteor if bin isn't found
command -v meteor >/dev/null 2>&1 || curl https://install.meteor.com | sed s/--progress-bar/-sL/g | /bin/sh
- name: TS TypeCheck
if: matrix.check == 'ts'
run: yarn turbo run typecheck --concurrency=5
- name: Save TypeScript incremental cache
if: matrix.check == 'ts' && github.ref == 'refs/heads/develop' && github.event_name == 'push'
uses: actions/cache/save@v5
with:
path: ./apps/meteor/tsconfig.typecheck.tsbuildinfo
key: typecheck-cache-${{ runner.os }}-${{ hashFiles('yarn.lock') }}
- name: Restore ESLint cache
id: restore-eslint
if: matrix.check == 'lint'
uses: actions/cache/restore@v5
with:
path: ./apps/meteor/.eslintcache
key: eslintcache-${{ runner.os }}-${{ hashFiles('yarn.lock') }}
restore-keys: |
eslintcache-${{ runner.os }}-
- name: Cache observability (eslint)
if: matrix.check == 'lint'
run: |
echo "### ESLint cache" >> $GITHUB_STEP_SUMMARY
echo "- **exact hit**: \`${{ steps.restore-eslint.outputs.cache-hit }}\`" >> $GITHUB_STEP_SUMMARY
- name: Lint
if: matrix.check == 'lint'
run: yarn lint
- name: Save ESLint cache
if: matrix.check == 'lint' && github.ref == 'refs/heads/develop' && github.event_name == 'push'
uses: actions/cache/save@v5
with:
path: ./apps/meteor/.eslintcache
key: eslintcache-${{ runner.os }}-${{ hashFiles('yarn.lock') }}