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

no-undefined-types reports an undefined type that is defined #144

Closed
lll000111 opened this issue Jan 7, 2019 · 9 comments
Closed

no-undefined-types reports an undefined type that is defined #144

lll000111 opened this issue Jan 7, 2019 · 9 comments

Comments

@lll000111
Copy link

v3.15.1

Even within the same file for the exact same type I get both no error and an error about the type being undefined. All errors of this kind are for types defined with @typedef and @global in other files.

Screenshot

@ibbignerd
Copy link

Could you include your typedef and your relevant eslint config?

@lll000111
Copy link
Author

lll000111 commented Jan 8, 2019

That type is not the only one with that problem, there are a few others. Those are all @typedef {Object} SomeType (plus a list of the respective properties).

/**
 * @global
 * @typedef {string} SHA256Hash
 */

In the jsdoc3 HTML output all those types are clickable (types defined as @global get an extra page, types only visible within a module get no link), so jsdoc3 found the typedef.

JSDoc rules — by now I disabled all the rules that caused errors for no good reason though:

        'jsdoc/check-examples': 'off',
        'jsdoc/check-param-names': 'error',
        'jsdoc/check-tag-names': 'error',
        'jsdoc/check-types': 'error',
        'jsdoc/newline-after-description': 'off',
        'jsdoc/no-undefined-types': 'off',
        'jsdoc/require-description': 'off',
        'jsdoc/require-description-complete-sentence': 'off',
        'jsdoc/require-example': 'off',
        'jsdoc/require-hyphen-before-param-description': 'warn',
        'jsdoc/require-param': 'warn',
        'jsdoc/require-param-description': 'off',
        'jsdoc/require-param-name': 'error',
        'jsdoc/require-param-type': 'error',
        'jsdoc/require-returns': 'off',
        'jsdoc/require-returns-description': 'off',
        'jsdoc/require-returns-type': 'warn',
        'jsdoc/valid-types': 'off',

@ibbignerd
Copy link

One issue is that Promise isn't recognized as a type: message: 'The type \'Promise\' is undefined.',

Here's the test I used that passes:

    {
      code: `
        /**
         * @global
         * @typedef {string} SHA256Hash
         */

        /**
         * @private
         * @param {SHA256Hash} foo
         */
        function quux(foo) {

        }
      `,
      globals: {
        SHA256Hash: true
      }
    },

I think you issue is a little more higher level. ESLint doesn't look like it is interfacing with your IDE to pass the global typedefs.

I'm not too experienced in this field. Maybe @gajus knows more about this.

@lll000111
Copy link
Author

lll000111 commented Jan 9, 2019

I used the IDE for the nice screenshot, it's of course the same on the command line. Your test does not help, most uses of that type in all files, and it is one used everywhere, cause no problem. I even chose an example where it is and isn't a problem at the same time. I don't understand the "Promise" part, I didn't post anything about a problem with a base type so that seems to be a problem you are having, well...

And another thing about your comment about the IDE: The IDE merely displays what running eslint produces in messages. That's why that popup starts with the name of the tool tool that produced the displayed message. In any case it has noting to do with this issue.

@PLASMAchicken
Copy link

By doing "sourceType": "module" it fixed the problem for me.

@lll000111
Copy link
Author

@PLASMAchicken I already have exactly that set in my .eslintrc.js

@brettz9
Copy link
Collaborator

brettz9 commented May 14, 2019

If the @typedef's are defined in other files, eslint-plugin-jsdoc does not support reading these in: #99. The rule currently only looks within the current file. As a workaround, you could add /* globals SHA256Hash */ to each file with such a reference (or add globals to your .eslintrc.js).

I therefore think this can be closed as a dupe of 99. As far as "rules that caused errors for no good reason though", we'd need a more specific (and reduced) test case.

@brettz9
Copy link
Collaborator

brettz9 commented May 14, 2019

@ibbignerd : Re: Promise not being defined, you need env: {es6: true} in your config to get the ES6 globals like Promise added.

@PLASMAchicken : If you are using Node/commonjs, and not actually using ESM, PR #222 may solve an issue whereby no-undefined-types was not catching globals.

@lll000111
Copy link
Author

Closed as duplicate of #99

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

No branches or pull requests

4 participants