-
-
Notifications
You must be signed in to change notification settings - Fork 54
[RFC] Replace ember-cli-eslint with the standard eslint #121
Changes from all commits
1c50958
4f3a56c
36dce72
6ae2c50
e9eb29f
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
- Start Date: 2018-08-13 | ||
- RFC PR: (leave this empty) | ||
|
||
# Summary | ||
|
||
Remove https://github.com/ember-cli/ember-cli-eslint from projects generated by | ||
`ember-cli`. | ||
|
||
[ember-cli-eslint](https://github.com/ember-cli/ember-cli-eslint) is an addon | ||
designed to show lint errors during test runs. Tooling around `eslint` has | ||
improved enough where this feature may no longer be necessary. | ||
|
||
To be clear, the proposal is _not_ to remove linting in tests. It is to follow | ||
the rest of JavaScript community and follow the standard tooling process. | ||
|
||
There are multiple ways to run `eslint`: | ||
|
||
1. Integration with editors | ||
2. Utilize precommit hooks with `eslint` | ||
3. Support a standard way to run `eslint` (such as `yarn lint:js`) | ||
|
||
We can also discuss configuring `testem` to automatically run `eslint` as part | ||
of `yarn test` | ||
|
||
# Motivation | ||
|
||
1. Improve our build speed | ||
2. Simplicity. `eslint` is common among JS stack, and integrations with editors | ||
/ precommit-hooks are ubiquitous. Removing this layer of abstraction will | ||
simplify how `eslint` is used throughout `ember-cli`. Most editors have | ||
plugins available for `eslint`, and as long as the `.eslint.rc` is not | ||
removed, we should still see the benefits of `eslint` in our Ember projects. | ||
3. Hacks required to support features such as [PR #122 | ||
broccoli-lint-eslint](https://github.com/ember-cli/broccoli-lint-eslint/pull/122#discussion-diff-153937455R28) | ||
|
||
# Detailed design | ||
|
||
1. Change blueprint to pull in `eslint` as opposed to `ember-cli-eslint` under | ||
`devDependencies`. | ||
2. Provide documentation on `eslint` and editor integration as well as precommit hooks | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe:
To make it clear that linting is still running (and still part of the test process) it just doesn't run along side the other tests. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think this is a good idea. Thanks @jrjohnson! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @jrjohnson - You are totally correct! So much so, that its already what we do! https://github.com/ember-cli/ember-new-output/blob/v3.4.1/.travis.yml#L25-L27 |
||
Redefine `npm test` or `yarn test` (depending on whether the `--yarn` option was | ||
used to create project) to | ||
|
||
``` | ||
ember test && npm run lint:js && npm run lint:hbs | ||
``` | ||
|
||
and | ||
|
||
``` | ||
ember test && yarn lint:js && yarn lint:hbs | ||
``` | ||
|
||
|
||
# How We Teach This | ||
|
||
Providing documentation regarding how to run linting should suffice as well as | ||
documentation to editor integration. | ||
|
||
Deleting abstractions and going towards a explicit path, `eslint` within the | ||
`ember-cli` ecosystem becomes _easier_ to teach. | ||
|
||
# Drawbacks | ||
|
||
1. No console warnings during builds | ||
2. lint failures are no longer included in browser tests | ||
|
||
# Alternatives | ||
|
||
1. Leave `ember-cli-eslint` alone | ||
|
||
# Unresolved questions | ||
|
||
N/A |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are you proposing the removal of lint hooks completely from ember-cli, or just removing
ember-cli-eslint
as a default dependency of new projects?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As far as I understand, only reason why we need the lint hooks is to trigger logic within
ember-cli-eslint
. (I assumed they were tightly coupled since they were marked as private).If that's not the case, we should leave the link hooks as is.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are some hooks beyond the ones you mentioned here, like
lintTree
that are used by a number of addons in the ecosystem.But more broadly,
broccoli-lint-eslint
andember-cli-eslint
aren't dependencies ofember-cli
itself, only of projects that the CLI generates. Given the phrasing here, I'm still a little unclear about whether you're proposing that Ember CLI stop supporting linters as part of the build, or just changing the default for new projects while leaving the ability for folks to opt in 🙂There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can see how that's unclear. I'll make some changes 👍 Thanks for the feedback @dfreeman