1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00
unleash.unleash/.github/workflows
Gastón Fournier 7aed1e0d13
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
2023-02-14 15:52:21 +01:00
..
add-to-project.yml meta: add external PRs to project board 2022-05-20 15:21:54 +02:00
build_coverage.yaml Merge frontend with backend (#1962) 2022-08-26 07:25:31 +00:00
build_doc_prs.yaml docs: test broken links in website (#1912) 2022-09-07 13:31:38 +00:00
build_frontend_prs.yml Add multiple tags (#3032) 2023-02-03 12:28:06 +02:00
build_prs_jest_report.yaml fix: support coverage reports on external PRs (#2087) 2022-09-27 15:51:04 +02:00
build_prs.yaml Merge frontend with backend (#1962) 2022-08-26 07:25:31 +00:00
build.yaml feat: remove CI build trigger (#3070) 2023-02-09 09:13:43 +01:00
check_links.yaml chore(deps): update lycheeverse/lychee-action action to v1.5.4 (#2367) 2022-11-09 23:59:14 +01:00
codeql-analysis.yml Create codeql-analysis.yml 2022-05-23 12:22:31 +02:00
continuous-publish-new-version.yaml refactor: move repo sync signal after npm publish (#3071) 2023-02-09 10:05:57 +01:00
docker_publish_main.yaml chore(deps): update docker/build-push-action action to v3 (#1766) 2022-07-11 14:01:45 +02:00
docker_publish_tags.yaml chore(deps): update docker/login-action action to v2 (#2962) 2023-02-13 09:50:49 +01:00
e2e.frontend.yaml Cypress test for importing (#3058) 2023-02-08 11:16:38 +02:00
flag-no-response.yaml feat: add no response action config 2022-04-20 08:30:13 +02:00
generate-docs.yaml docs: generate docs daily (#3067) 2023-02-08 10:30:00 +00:00
gradual-strict-null-checks.yml chore: gradually reduce null-check errors (#3094) 2023-02-14 15:52:21 +01:00
publish-new-version.yaml fix: allow publish-new-version action to run from branch (#2698) 2022-12-15 09:25:44 +01:00
release_changelog.yml chore(deps): update metcalfc/changelog-generator action to v4 (#2294) 2022-11-09 23:01:01 +01:00
release.yaml refactor: move repo sync signal after npm publish (#3071) 2023-02-09 10:05:57 +01:00
update_contributors.yaml fix: trim out test trigger for svg gen 2022-04-22 10:40:23 +02:00