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 no-named-default rule #596

Merged
merged 11 commits into from
Nov 2, 2016
Merged

Add no-named-default rule #596

merged 11 commits into from
Nov 2, 2016

Conversation

ntdb
Copy link
Contributor

@ntdb ntdb commented Oct 1, 2016

👋

This is an attempt at building the rule requested in #481. I'm not new to ES2015 or ESLint but I may have misstepped on some terminology and certainly on some logic. Please take a look and let me know what I can improve!

@coveralls
Copy link

coveralls commented Oct 1, 2016

Coverage Status

Coverage increased (+0.02%) to 97.67% when pulling b3bfe56 on ntdb:master into 2dec0a7 on benmosher:master.

@coveralls
Copy link

coveralls commented Oct 1, 2016

Coverage Status

Coverage increased (+0.02%) to 97.667% when pulling 016672b on ntdb:master into 2dec0a7 on benmosher:master.

Copy link
Collaborator

@jfmengels jfmengels left a comment

Choose a reason for hiding this comment

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

Thanks a lot for taking care of this @ntdb!
I have a few comments, but this is good :)

},

create: function (context) {
function checkSpecifiers(type, node) {
Copy link
Collaborator

Choose a reason for hiding this comment

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

There's no reason to specify the type IMO, as I don't think this code will be extended to account for other types. You should remove the type parameter and the call to bind below. To make things a little bit clearer, you could simply assign this function to ImportDeclaration directly (like { ImportDeclaration: function (node) { ... } }

node.specifiers.forEach(function (im) {
if (im.type !== type) return

if (im.imported.name === 'default') {
Copy link
Collaborator

@jfmengels jfmengels Oct 1, 2016

Choose a reason for hiding this comment

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

if (im.type === 'ImportSpecifier' && im.imported.name === 'default') {
}

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I also went ahead and removed the preceding checks as I don't believe they were helping us anymore.

if (im.imported.name === 'default') {
context.report(im.local,
'Using name \'' + im.local.name +
'\' as identifier for default export.')
Copy link
Collaborator

Choose a reason for hiding this comment

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

context.report({
  node: im.local,
  message: 'Using name...'
})

Both syntaxes are valid but I think the first one was deprecated. Anyhow, this would be more consistent with the other rules in this repo AFAIK.

code: 'import { foo, default as bar } from "./bar";',
errors: [ {
message: 'Using name \'bar\' as identifier for default export.'
, type: 'Identifier' } ] }),
Copy link
Collaborator

@jfmengels jfmengels Oct 1, 2016

Choose a reason for hiding this comment

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

Could you add the following invalid test case? From what I can see, that looks like a syntax error using the default parser, but still valid with babel-eslint.

import {default} from './bar';


// es7
test({ code: 'import bar from "./bar";', parser: 'babel-eslint' }),
test({ code: 'import bar, { foo } from "./bar";', parser: 'babel-eslint' }),
Copy link
Collaborator

Choose a reason for hiding this comment

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

What are the differences with the previous non-es7 test cases? Are you just testing the parsers?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yup these are here because I was unsure about whether the parser required testing for each rule. Are they safe to remove?

Copy link
Collaborator

Choose a reason for hiding this comment

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

I'd say it's safe yes. At this point and AFAIK, the only difference is that one parser might consider some syntax invalid while another accepts it (and it goes both ways now with the latest version of Espree).

...these would be valid:
```js
import foo from './foo.js';
import foo { bar } from './foo.js';
Copy link
Collaborator

Choose a reason for hiding this comment

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

foo, { bar }


if (im.imported.name === 'default') {
context.report(im.local,
'Using name \'' + im.local.name +
Copy link
Collaborator

Choose a reason for hiding this comment

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

The error is currently: "Using name bar as identifier for default export".
Technically, if you do import bar from './foo', bar is also the name of the default export, but that's valid.

I'd change the error message to "Use default import syntax to import bar".

@coveralls
Copy link

coveralls commented Oct 1, 2016

Coverage Status

Coverage increased (+0.01%) to 97.66% when pulling 0ec1789 on ntdb:master into 2dec0a7 on benmosher:master.

Copy link
Collaborator

@jfmengels jfmengels left a comment

Choose a reason for hiding this comment

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

One more small thing from my side and then I think we're good. Thanks for making all the previous changes! :)

create: function (context) {
return {
'ImportDeclaration': function (node) {
if (node.source == null) return
Copy link
Collaborator

@jfmengels jfmengels Oct 1, 2016

Choose a reason for hiding this comment

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

I'm curious, is there ever a case where the source is not defined? ❓
We can leave it in case you're not sure, but I don't when this would happen.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

TBH, this is here because other rules included it (named, no-deprecated). It now seems likely that it's not needed here, will remove.

if (im.type === 'ImportSpecifier' && im.imported.name === 'default') {
context.report({
node: im.local,
message: 'Use default import syntax to ' +
Copy link
Collaborator

@jfmengels jfmengels Oct 1, 2016

Choose a reason for hiding this comment

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

You could use template literal syntax here by the way, makes it a bit simpler (and I think you're allowed to put this all on one line, but let me know if you aren't)

`Use default import syntax to import '${im.local.name}'`

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Good thought! I'm used to an 80-char line length, this is definitely under the project's max of 99. :)

@ntdb
Copy link
Contributor Author

ntdb commented Oct 1, 2016

@jfmengels I've just pushed changes based on your most recent review. Cheers!

@coveralls
Copy link

coveralls commented Oct 1, 2016

Coverage Status

Coverage increased (+0.01%) to 97.658% when pulling 3ec2248 on ntdb:master into 2dec0a7 on benmosher:master.

@coveralls
Copy link

coveralls commented Oct 1, 2016

Coverage Status

Coverage increased (+0.01%) to 97.658% when pulling 27836ba on ntdb:master into 2dec0a7 on benmosher:master.

@jfmengels
Copy link
Collaborator

Awesome, thanks @ntdb! :)

@benmosher
Copy link
Member

👌🏻 Thanks for this, @ntdb! Cool to see you contributing!

And thanks for all the back and forth working together from both you and @jfmengels!

Copy link
Member

@benmosher benmosher left a comment

Choose a reason for hiding this comment

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

Just need to get to a computer to resolve conflicts. Feel free to rebase if you want, I can do it otherwise.

@coveralls
Copy link

coveralls commented Nov 2, 2016

Coverage Status

Coverage increased (+0.02%) to 94.928% when pulling db1343f on ntdb:master into edbb570 on benmosher:master.

@ntdb
Copy link
Contributor Author

ntdb commented Nov 2, 2016

@benmosher Sure thing, thanks for maintaining a great plugin! I've just rebased, should be good to go.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

4 participants