Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add linter #1750

Merged
merged 4 commits into from
Jul 3, 2015
Merged

Add linter #1750

merged 4 commits into from
Jul 3, 2015

Conversation

ndhoule
Copy link
Contributor

@ndhoule ndhoule commented Jun 16, 2015

@jbnicolai @boneskull

Addresses #1359

The Make task uses eslint's --reset flag to disable all default ESLint settings because ESLint is planning on making that the default in the future and I'd rather not have to go back through and change all the settings when that happens. I know there are a lot of settings here, but would be good to get some feedback on what's here. Most of the rules are pretty uncontroversial and we already follow them, but there are a few sections (labeled in .eslintrc) worth looking at.

We should also add more directories (e.g. bin and test), but I'm thinking we can do that in a separate PR to speed this one along to minimize merge conflicts. (Happy to handle that too.)

"space-unary-ops": [2, { "words": true, "nonwords": false }],
"use-isnan": 2,
"wrap-iife": 2
}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Kinda screwed up here and just deleted any rule I wanted to disable; in reality we should leave them in the config. --reset is not yet the default, so most editors' linting plugins will re-enable those rules. Will add these back in before merge.

@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 16, 2015

once we settle on a final rule list I'll remove those comments in .eslintrc

@@ -0,0 +1,113 @@
{
"env": {
"browser": true,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if we're building with browserify, we can just use the node env

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Mostly to pick up on document, window, etc. in the reporters, lib/utils.js, and a few other files. We should probably remove it eventually though

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

in those cases we could do a

/* eslint-env browser */
// ^ top of file

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

everything in {lib,test}/browser should have its env set to browser, maybe a few reporters. I think the references to browser stuff elsewhere is feature detection. was being lazy but I'll just fix those

@boneskull
Copy link
Contributor

@ndhoule thx for all the work on this

@ndhoule ndhoule force-pushed the chore/linting branch 2 times, most recently from a4e7c44 to 7981c25 Compare June 17, 2015 10:07
@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 17, 2015

@boneskull Think I addressed all your comments (added your config, converted .eslintrcs to YAML, addressed notes like removing browser: true, etc). Disabled some of the rules that were making linting output particularly noisy; I think it's important to minimize linting noise because people will end up ignoring the linter otherwise. Will take care of some of those later (or other folks are welcome to tackle them :P).

Just rebased, should be good to go—let me know if you want to see other changes

@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 18, 2015

Only point to updating npm was to fix 0.8 CI builds, so amended it PR to only update npm when necessary. Also added npm >= 1.3.7 (introduction of caret) to Mocha's engines field.

@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 23, 2015

just pinging here. I think I've addressed all issues, let me know if that's not the case

@boneskull
Copy link
Contributor

taking another look now. I'm probably going to merge this unless someone objects.

@boneskull
Copy link
Contributor

@ndhoule The only thing I see that would prevent me from merging as-is is the npm change. Let me check on package.json really quicklike

@boneskull
Copy link
Contributor

@ndhoule OK, so that's necessary because why? If we changed the caret in the eslint version to a tilde, would the 0.8 Travis run work?

@boneskull
Copy link
Contributor

If we can avoid that, it'd be great, otherwise this would have to be rebased into branch v3.0.0

@dasilvacontin
Copy link
Contributor

~ matches only new patch versions. If we plan on manually updating the dependencies, I'd say it's fine leaving the tilde. Otherwise we might miss some bugfixes due to some new feature release.

And yeah, using ~ makes updating npm unnecessary for travis.

@boneskull
Copy link
Contributor

well, I know that, I just wasn't sure if the caret was there for a reason

@dasilvacontin
Copy link
Contributor

yeah, sorry, too early in the morning here :x

@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 30, 2015

@boneskull

@ndhoule OK, so that's necessary because why? If we changed the caret in the eslint version to a tilde, would the 0.8 Travis run work?

We can change the caret to tildes, which should leave Mocha installable on npm > 1.3.7, so long as users aren't trying to install it with its dev dependencies.

ESLint has carets in its dev dependencies, so including it will make npm 1.3.7+ a hard dev dependency for Mocha going forward—so those lines in .travis.yml will still be necessary.

@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 30, 2015

@boneskull rebased from master and fixed the caret issue.

@boneskull
Copy link
Contributor

ty. That's fine with the dev deps.

@ndhoule
Copy link
Contributor Author

ndhoule commented Jun 30, 2015

@boneskull Cool. Removed npm from the engines field, since removing the caret made that not a req. (I had added it in when I added the linter.) This should be good to go, then.

@boneskull
Copy link
Contributor

gonna try to merge this.

@boneskull
Copy link
Contributor

just waiting on CI. oh boy oh boy oh boy

@boneskull boneskull merged commit 6158e09 into mochajs:master Jul 3, 2015
@boneskull
Copy link
Contributor

@ndhoule thanks a ton!

@jbnicolai jbnicolai mentioned this pull request Jul 5, 2015
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants