From 288f0ae5d45183321493131ecf8c377fd6a5a5f3 Mon Sep 17 00:00:00 2001 From: Brett Zamir Date: Wed, 14 Aug 2024 22:34:21 +0800 Subject: [PATCH] fix(`check-param-names`): check against whitelist of acceptable function nodes so that non-function global contexts do not err; fixes #1303 Also adds warning in docs for use of global settings contexts. --- .README/settings.md | 8 ++++++-- docs/rules/check-param-names.md | 10 ++++++++++ docs/rules/require-param.md | 9 +++++++++ docs/settings.md | 8 ++++++-- src/rules/checkParamNames.js | 22 +++++++++++++++++----- test/rules/assertions/checkParamNames.js | 23 +++++++++++++++++++++++ test/rules/assertions/requireParam.js | 22 ++++++++++++++++++++++ 7 files changed, 93 insertions(+), 9 deletions(-) diff --git a/.README/settings.md b/.README/settings.md index 73dacdd76..858e6c39c 100644 --- a/.README/settings.md +++ b/.README/settings.md @@ -329,5 +329,9 @@ values are objects with the following optional properties: ### `contexts` `settings.jsdoc.contexts` can be used as the default for any rules -with a `contexts` property option. See the "AST and Selectors" section -for more on this format. +with a `contexts` property option. **Please note**: This will replace any +default contexts, including for function rules, so if, for example, you exclude +`FunctionDeclaration` here, rules like `require-param` will not check +function declarations. + +See the "AST and Selectors" section for more on this format. diff --git a/docs/rules/check-param-names.md b/docs/rules/check-param-names.md index 10db07997..73d6f94c8 100644 --- a/docs/rules/check-param-names.md +++ b/docs/rules/check-param-names.md @@ -1119,5 +1119,15 @@ function quux (foo, bar) { export function fn(...[type, arg]: FnArgs): void { // ... } + +/** + * @param c c + * @param d d + */ +const inner = (c: number, d: string): void => { + console.log(c); + console.log(d); +}; +// Settings: {"jsdoc":{"contexts":["VariableDeclaration"]}} ```` diff --git a/docs/rules/require-param.md b/docs/rules/require-param.md index eb5eb271c..fa6006553 100644 --- a/docs/rules/require-param.md +++ b/docs/rules/require-param.md @@ -1804,5 +1804,14 @@ function a (b) {} function sumDestructure(this: unknown, { a, b }: { a: number, b: number }) { return a + b; } + +/** + * + */ +const inner = (c: number, d: string): void => { + console.log(c); + console.log(d); +}; +// Settings: {"jsdoc":{"contexts":["VariableDeclaration"]}} ```` diff --git a/docs/settings.md b/docs/settings.md index ab436ae8a..97648c26e 100644 --- a/docs/settings.md +++ b/docs/settings.md @@ -358,5 +358,9 @@ values are objects with the following optional properties: ### contexts `settings.jsdoc.contexts` can be used as the default for any rules -with a `contexts` property option. See the "AST and Selectors" section -for more on this format. +with a `contexts` property option. **Please note**: This will replace any +default contexts, including for function rules, so if, for example, you exclude +`FunctionDeclaration` here, rules like `require-param` will not check +function declarations. + +See the "AST and Selectors" section for more on this format. diff --git a/src/rules/checkParamNames.js b/src/rules/checkParamNames.js index 54ac72b9c..9002ff6d7 100644 --- a/src/rules/checkParamNames.js +++ b/src/rules/checkParamNames.js @@ -354,11 +354,18 @@ const validateParameterNamesDeep = ( }); }; +const allowedNodes = [ + 'ArrowFunctionExpression', 'FunctionDeclaration', 'FunctionExpression', 'TSDeclareFunction', + // Add this to above defaults + 'TSMethodSignature' +]; + export default iterateJsdoc(({ context, jsdoc, report, utils, + node, }) => { const { allowExtraTrailingParamDocs, @@ -371,6 +378,15 @@ export default iterateJsdoc(({ disableMissingParamChecks = false, } = context.options[0] || {}; + // Although we might just remove global settings contexts from applying to + // this rule (as they can cause problems with `getFunctionParameterNames` + // checks if they are not functions but say variables), the user may + // instead wish to narrow contexts in those settings, so this check + // is still useful + if (!allowedNodes.includes(/** @type {import('estree').Node} */ (node).type)) { + return; + } + const checkTypesRegex = utils.getRegexFromString(checkTypesPattern); const jsdocParameterNamesDeep = utils.getJsdocTagsDeep('param'); @@ -406,11 +422,7 @@ export default iterateJsdoc(({ targetTagName, allowExtraTrailingParamDocs, jsdocParameterNamesDeep, jsdoc, report, ); }, { - contextDefaults: [ - 'ArrowFunctionExpression', 'FunctionDeclaration', 'FunctionExpression', 'TSDeclareFunction', - // Add this to above defaults - 'TSMethodSignature' - ], + contextDefaults: allowedNodes, meta: { docs: { description: 'Ensures that parameter names in JSDoc match those in the function declaration.', diff --git a/test/rules/assertions/checkParamNames.js b/test/rules/assertions/checkParamNames.js index 7804b499b..861373a01 100644 --- a/test/rules/assertions/checkParamNames.js +++ b/test/rules/assertions/checkParamNames.js @@ -2015,5 +2015,28 @@ export default { sourceType: 'module', }, }, + { + code: ` + /** + * @param c c + * @param d d + */ + const inner = (c: number, d: string): void => { + console.log(c); + console.log(d); + }; + `, + languageOptions: { + parser: typescriptEslintParser, + sourceType: 'module', + }, + settings: { + jsdoc: { + contexts: [ + 'VariableDeclaration', + ] + } + }, + }, ], }; diff --git a/test/rules/assertions/requireParam.js b/test/rules/assertions/requireParam.js index 675e1039e..666cb4ab0 100644 --- a/test/rules/assertions/requireParam.js +++ b/test/rules/assertions/requireParam.js @@ -3582,5 +3582,27 @@ export default { parser: typescriptEslintParser, }, }, + { + code: ` + /** + * + */ + const inner = (c: number, d: string): void => { + console.log(c); + console.log(d); + }; + `, + languageOptions: { + parser: typescriptEslintParser, + sourceType: 'module', + }, + settings: { + jsdoc: { + contexts: [ + 'VariableDeclaration', + ] + } + }, + }, ], };