webhook/node_modules/eslint-plugin-jest/lib/rules/prefer-strict-equal.js

49 lines
1.3 KiB
JavaScript
Raw Normal View History

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _utils = require("./utils");
var _default = (0, _utils.createRule)({
name: __filename,
meta: {
docs: {
category: 'Best Practices',
description: 'Suggest using `toStrictEqual()`',
2022-11-10 11:43:16 +01:00
recommended: false
},
messages: {
useToStrictEqual: 'Use `toStrictEqual()` instead',
suggestReplaceWithStrictEqual: 'Replace with `toStrictEqual()`'
},
type: 'suggestion',
2022-11-10 11:43:16 +01:00
schema: [],
hasSuggestions: true
},
defaultOptions: [],
create(context) {
return {
CallExpression(node) {
2022-11-10 11:43:16 +01:00
const jestFnCall = (0, _utils.parseJestFnCall)(node, context);
if ((jestFnCall === null || jestFnCall === void 0 ? void 0 : jestFnCall.type) !== 'expect') {
return;
}
const {
matcher
2022-11-10 11:43:16 +01:00
} = jestFnCall;
if ((0, _utils.isSupportedAccessor)(matcher, 'toEqual')) {
context.report({
messageId: 'useToStrictEqual',
2022-11-10 11:43:16 +01:00
node: matcher,
suggest: [{
messageId: 'suggestReplaceWithStrictEqual',
2022-11-10 11:43:16 +01:00
fix: fixer => [(0, _utils.replaceAccessorFixer)(fixer, matcher, _utils.EqualityMatcher.toStrictEqual)]
}]
});
}
}
};
}
});
exports.default = _default;