From 7ff2cb9298f5dd0b4dae82321605d04e50ca935b Mon Sep 17 00:00:00 2001 From: Brett Zamir Date: Sat, 26 Oct 2024 11:16:46 +0800 Subject: [PATCH] feat(`valid-params`): add `exclude` option (#515) Allows use of non-standard methods, e.g., Bluebird `catch`. --- __tests__/no-new-statics.js | 24 ++++++++++++------------ __tests__/valid-params.js | 36 ++++++++++++++++++++++++++---------- docs/rules/always-return.md | 4 ++-- docs/rules/no-native.md | 6 +++--- docs/rules/valid-params.md | 6 ++++++ rules/valid-params.js | 20 +++++++++++++++++++- 6 files changed, 68 insertions(+), 28 deletions(-) diff --git a/__tests__/no-new-statics.js b/__tests__/no-new-statics.js index 4ced5e87..33ad0c13 100644 --- a/__tests__/no-new-statics.js +++ b/__tests__/no-new-statics.js @@ -53,18 +53,18 @@ ruleTester.run('no-new-statics', rule, { errors: [{ message: "Avoid calling 'new' on 'Promise.withResolvers()'" }], }, { - code: [ - 'function foo() {', - ' var a = getA()', - ' return new Promise.resolve(a)', - '}', - ].join('\n'), - output: [ - 'function foo() {', - ' var a = getA()', - ' return Promise.resolve(a)', - '}', - ].join('\n'), + code: ` + function foo() { + var a = getA() + return new Promise.resolve(a) + } + `, + output: ` + function foo() { + var a = getA() + return Promise.resolve(a) + } + `, errors: [{ message: "Avoid calling 'new' on 'Promise.resolve()'" }], }, ], diff --git a/__tests__/valid-params.js b/__tests__/valid-params.js index 968135c3..0993e35d 100644 --- a/__tests__/valid-params.js +++ b/__tests__/valid-params.js @@ -61,17 +61,33 @@ ruleTester.run('valid-params', rule, { 'promiseReference.finally(callback)', 'promiseReference.finally(() => {})', + { + code: ` + somePromise.then(function() { + return sth(); + }).catch(TypeError, function(e) { + // + }).catch(function(e) { + }); + `, + options: [ + { + exclude: ['catch'], + }, + ], + }, + // integration test - [ - 'Promise.all([', - ' Promise.resolve(1),', - ' Promise.resolve(2),', - ' Promise.reject(Error()),', - '])', - ' .then(console.log)', - ' .catch(console.error)', - ' .finally(console.log)', - ].join('\n'), + ` + Promise.all([ + Promise.resolve(1), + Promise.resolve(2), + Promise.reject(Error()), + ]) + .then(console.log) + .catch(console.error) + .finally(console.log) + `, ], invalid: [ // invalid Promise.resolve() diff --git a/docs/rules/always-return.md b/docs/rules/always-return.md index 81899d96..a3be47d4 100644 --- a/docs/rules/always-return.md +++ b/docs/rules/always-return.md @@ -78,11 +78,11 @@ promise }) // NG -var v = promise.then((x) => { +const v = promise.then((x) => { console.log(x) }) // NG -var v = await promise.then((x) => { +const v = await promise.then((x) => { console.log(x) }) function foo() { diff --git a/docs/rules/no-native.md b/docs/rules/no-native.md index fff32d9b..2a7d516e 100644 --- a/docs/rules/no-native.md +++ b/docs/rules/no-native.md @@ -12,12 +12,12 @@ existence of a native promise implementation. Helpful if you want to use #### Valid ```js -var Promise = require('bluebird') -var x = Promise.resolve('good') +const Promise = require('bluebird') +const x = Promise.resolve('good') ``` #### Invalid ```js -var x = Promise.resolve('bad') +const x = Promise.resolve('bad') ``` diff --git a/docs/rules/valid-params.md b/docs/rules/valid-params.md index f2387718..1a54eb77 100644 --- a/docs/rules/valid-params.md +++ b/docs/rules/valid-params.md @@ -62,6 +62,12 @@ somePromise().finally(() => { somePromise().finally(console.log) ``` +## Options + +### `exclude` + +Array of method names to exclude from checks. Defaults to an empty array. + ## When Not To Use It If you do not want to be notified when passing an invalid number of arguments to diff --git a/rules/valid-params.js b/rules/valid-params.js index f06c40ea..c4fc3125 100644 --- a/rules/valid-params.js +++ b/rules/valid-params.js @@ -11,7 +11,20 @@ module.exports = { 'Enforces the proper number of arguments are passed to Promise functions.', url: getDocsUrl('valid-params'), }, - schema: [], + schema: [ + { + type: 'object', + properties: { + exclude: { + type: 'array', + items: { + type: 'string', + }, + }, + }, + additionalProperties: false, + }, + ], messages: { requireOneOptionalArgument: 'Promise.{{ name }}() requires 0 or 1 arguments, but received {{ numArgs }}', @@ -22,6 +35,7 @@ module.exports = { }, }, create(context) { + const { exclude = [] } = context.options[0] || {} return { CallExpression(node) { if (!isPromise(node)) { @@ -31,6 +45,10 @@ module.exports = { const name = node.callee.property.name const numArgs = node.arguments.length + if (exclude.includes(name)) { + return + } + // istanbul ignore next -- `isPromise` filters out others switch (name) { case 'resolve':