From ee2647eb24fe5668df7ed483b8eedc6eb1d1dffa Mon Sep 17 00:00:00 2001 From: garyking Date: Sun, 30 Sep 2018 16:04:12 -0400 Subject: [PATCH] fix(prefer-strict-equal): only run if `expect` is used (#163) --- rules/__tests__/prefer-strict-equal.test.js | 5 ++++- rules/prefer-strict-equal.js | 13 ++++++++++--- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/rules/__tests__/prefer-strict-equal.test.js b/rules/__tests__/prefer-strict-equal.test.js index 8104f43d8..978a2a841 100644 --- a/rules/__tests__/prefer-strict-equal.test.js +++ b/rules/__tests__/prefer-strict-equal.test.js @@ -6,7 +6,10 @@ const rule = require('../prefer-strict-equal'); const ruleTester = new RuleTester(); ruleTester.run('prefer-strict-equal', rule, { - valid: ['expect(something).toStrictEqual(somethingElse);'], + valid: [ + 'expect(something).toStrictEqual(somethingElse);', + "a().toEqual('b')", + ], invalid: [ { code: 'expect(something).toEqual(somethingElse);', diff --git a/rules/prefer-strict-equal.js b/rules/prefer-strict-equal.js index 838438913..45092b3df 100644 --- a/rules/prefer-strict-equal.js +++ b/rules/prefer-strict-equal.js @@ -1,6 +1,8 @@ 'use strict'; +const expectCase = require('./util').expectCase; const getDocsUrl = require('./util').getDocsUrl; +const method = require('./util').method; module.exports = { meta: { @@ -12,14 +14,19 @@ module.exports = { create(context) { return { CallExpression(node) { - const propertyName = node.callee.property && node.callee.property.name; + if (!expectCase(node)) { + return; + } + + const propertyName = method(node) && method(node).name; + if (propertyName === 'toEqual') { context.report({ fix(fixer) { - return [fixer.replaceText(node.callee.property, 'toStrictEqual')]; + return [fixer.replaceText(method(node), 'toStrictEqual')]; }, message: 'Use toStrictEqual() instead', - node: node.callee.property, + node: method(node), }); } },