mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
chore: gradually reduce null-check errors (#3094)
## About the changes In order to move us towards enabling `strictNullChecks` we'd want to have a way of gradually enabling this without having to fix all errors at once, this will force us to start reducing the number of null check issues. This new workflow: 1. [Checks out the current branch and main into 2 different folders](https://github.com/Unleash/unleash/pull/3094/files#diff-068f2ace1d1d2e773fb5e4240c83ccab251556fd5524fe13847122878e40da3bR15-R23) 2. Uses the **same** script `gradual-strict-null-checks.sh` (from the current branch) [against each folder in parallel](https://github.com/Unleash/unleash/pull/3094/files#diff-068f2ace1d1d2e773fb5e4240c83ccab251556fd5524fe13847122878e40da3bR34-R38) to count the number of errors if `strictNullChecks` was enabled 3. If the number of potential errors in the current branch is higher than the number of potential errors in main [it fails](https://github.com/Unleash/unleash/pull/3094/files#diff-068f2ace1d1d2e773fb5e4240c83ccab251556fd5524fe13847122878e40da3bR41-R46) As an example, a [new issue was introduced in this PR](753f57223c
) (and then [reverted](e4deb62965
)), so we can test the build failure: https://github.com/Unleash/unleash/actions/runs/4163632636/jobs/7204268519#step:5:10 ## Discussion points This could be a non-mandatory check, just advising, or even adding a comment in the PR. It might be good to start with a non-strict check, but at the same time we can decide to make it non-strict if a problem appears In some situations, an additional null check error might require us to fix a bunch of them, increasing the time to deliver. In these cases we can suppress an individual line with `// @ts-ignore: Object is possibly 'null'.` although might defeat the purpose of this workflow
This commit is contained in:
parent
94b0471c4e
commit
7aed1e0d13
50
.github/workflows/gradual-strict-null-checks.yml
vendored
Normal file
50
.github/workflows/gradual-strict-null-checks.yml
vendored
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
name: Lower null checks
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
node-version: [16.x]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout current branch
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
path: current
|
||||||
|
- name: Checkout main branch
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
ref: main
|
||||||
|
path: main
|
||||||
|
- name: Use Node.js ${{ matrix.node-version }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: ${{ matrix.node-version }}
|
||||||
|
cache: 'yarn'
|
||||||
|
cache-dependency-path: |
|
||||||
|
current/yarn.lock
|
||||||
|
main/yarn.lock
|
||||||
|
# intentionally use the same script from current branch against both repositories
|
||||||
|
- run: |
|
||||||
|
./current/scripts/gradual-strict-null-checks.sh ./current > ./current-count &
|
||||||
|
pid1=$!
|
||||||
|
./current/scripts/gradual-strict-null-checks.sh ./main > ./main-count &
|
||||||
|
pid2=$!
|
||||||
|
wait $pid1 && wait $pid2
|
||||||
|
MAIN=$(cat ./main-count)
|
||||||
|
CURRENT=$(cat ./current-count)
|
||||||
|
if [ $CURRENT -gt $MAIN ]; then
|
||||||
|
echo "The PR is increasing the number of null check errors from ${MAIN} to ${CURRENT}. Check if your branch is up-to-date and consider fixing them before merging"
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
echo "The PR has $CURRENT null check errors against $MAIN in main. You're good to go!"
|
||||||
|
fi
|
13
scripts/gradual-strict-null-checks.sh
Executable file
13
scripts/gradual-strict-null-checks.sh
Executable file
@ -0,0 +1,13 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -e
|
||||||
|
FOLDER="${1:-.}"
|
||||||
|
|
||||||
|
cd "${FOLDER}"
|
||||||
|
|
||||||
|
# update strictNullChecks
|
||||||
|
sed -i 's/\/\/\s*"strictNullChecks":\s*true,/"strictNullChecks": true,/' "./tsconfig.json"
|
||||||
|
|
||||||
|
# count errors
|
||||||
|
ERRORS=$(yarn 2> /dev/null | grep "Found [0-9]* errors" | sed 's/Found \(.*\) errors in .* files./\1/')
|
||||||
|
|
||||||
|
echo ${ERRORS:-0}
|
Loading…
Reference in New Issue
Block a user