From f70612d8b414575725a5831ed9dfad1eaf1e6548 Mon Sep 17 00:00:00 2001 From: Gareth Jones Date: Sun, 17 May 2020 11:19:11 +1200 Subject: [PATCH] fix(no-test-callback): check argument is an identifier --- src/rules/__tests__/no-test-callback.test.ts | 10 ++++++++++ src/rules/no-test-callback.ts | 9 +++++++++ 2 files changed, 19 insertions(+) diff --git a/src/rules/__tests__/no-test-callback.test.ts b/src/rules/__tests__/no-test-callback.test.ts index 41b2a3827..1f3185621 100644 --- a/src/rules/__tests__/no-test-callback.test.ts +++ b/src/rules/__tests__/no-test-callback.test.ts @@ -18,6 +18,16 @@ ruleTester.run('no-test-callback', rule, { 'test("something", someArg)', ], invalid: [ + { + code: 'test("something", (...args) => {args[0]();})', + errors: [ + { + messageId: 'illegalTestCallback', + line: 1, + column: 20, + }, + ], + }, { code: 'test("something", done => {done();})', errors: [{ messageId: 'illegalTestCallback', line: 1, column: 19 }], diff --git a/src/rules/no-test-callback.ts b/src/rules/no-test-callback.ts index 5b32fdcb5..9607ad80b 100644 --- a/src/rules/no-test-callback.ts +++ b/src/rules/no-test-callback.ts @@ -34,6 +34,15 @@ export default createRule({ const [argument] = callback.params; + if (argument.type !== AST_NODE_TYPES.Identifier) { + context.report({ + node: argument, + messageId: 'illegalTestCallback', + }); + + return; + } + if (callback.async) { context.report({ node: argument,