react/scripts/rollup
Andrew Clark 112168f31b
Lint rule for unminified errors (#15757)
* Lint rule for unminified errors

Add a lint rule that fails if an invariant message is not part of the
error code map.

The goal is to be more disciplined about adding and modifiying
production error codes. Error codes should be consistent across releases
even if their wording changes, for continuity in logs.

Currently, error codes are added to the error code map via an automated
script that runs right before release. The problem with this approach is
that if someone modifies an error message in the source, but neglects to
modify the corresponding message in the error code map, then the message
will be assigned a new error code, instead of reusing the existing one.

Because the error extraction script only runs before a release, people
rarely modify the error code map in practice. By moving the extraction
step to the PR stage, it forces the author to consider whether the
message should be assigned a new error code. It also allows the reviewer
to review the changes.

The trade off is that it requires more effort and context to land new
error messages, or to modify existing ones, particular for new
contributors who are not familiar with our processes.

Since we already expect users to lint their code, I would argue the
additional burden is marginal. Even if they forget to run the lint
command locally, they will get quick feedback from the CI lint job,
which typically finishes within 2-3 minutes.

* Add unreleased error messages to map
2019-05-29 11:29:04 -07:00
..
plugins Drop the year from Facebook copyright headers and the LICENSE file. (#13593) 2018-09-07 15:11:23 -07:00
shims Lint rule for unminified errors (#15757) 2019-05-29 11:29:04 -07:00
validate [React Native] Inline calls to FabricUIManager in shared code (#15490) 2019-04-29 14:31:16 -07:00
build.js add --watch mode to "yarn build" (#15116) 2019-04-25 12:55:44 +01:00
bundles.js [react-native] Use path-based imports instead of Haste for the RN renderer (#15604) 2019-05-23 08:23:54 +01:00
forks.js Fork ReactSharedInternals for UMD builds (#15617) 2019-05-10 13:51:39 -07:00
modules.js [react-native] Use path-based imports instead of Haste for the RN renderer (#15604) 2019-05-23 08:23:54 +01:00
packaging.js Add UMD production+profiling entry points (#13642) 2018-09-13 17:44:08 -07:00
stats.js Don't run danger on bad build (#14143) 2018-11-09 10:21:39 -08:00
sync.js Fork React Native renderer into FB and OSS bundles (#12625) 2018-04-18 13:16:50 -07:00
utils.js Refactor the build scripts (#11787) 2017-12-06 20:11:32 +00:00
wrappers.js Add UMD production+profiling entry points (#13642) 2018-09-13 17:44:08 -07:00