eslint-plugin-jest 27.2.0 → 27.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/README.md +1 -1
  2. package/docs/rules/no-alias-methods.md +1 -1
  3. package/docs/rules/no-hooks.md +1 -1
  4. package/docs/rules/no-if.md +1 -1
  5. package/docs/rules/no-large-snapshots.md +4 -0
  6. package/docs/rules/require-hook.md +2 -6
  7. package/docs/rules/valid-expect.md +2 -2
  8. package/lib/index.js +5 -12
  9. package/lib/processors/__tests__/snapshot-processor.test.js +36 -0
  10. package/lib/rules/__tests__/consistent-test-it.test.js +921 -0
  11. package/lib/rules/__tests__/expect-expect.test.js +347 -0
  12. package/lib/rules/__tests__/fixtures/class.ts +13 -0
  13. package/lib/rules/__tests__/fixtures/file.ts +0 -0
  14. package/lib/rules/__tests__/fixtures/foo.ts +1 -0
  15. package/lib/rules/__tests__/fixtures/indent/indent-invalid-fixture-1.js +530 -0
  16. package/lib/rules/__tests__/fixtures/indent/indent-valid-fixture-1.js +530 -0
  17. package/lib/rules/__tests__/fixtures/react.tsx +0 -0
  18. package/lib/rules/__tests__/fixtures/tsconfig-withmeta.json +6 -0
  19. package/lib/rules/__tests__/fixtures/tsconfig.json +16 -0
  20. package/lib/rules/__tests__/fixtures/unstrict/file.ts +0 -0
  21. package/lib/rules/__tests__/fixtures/unstrict/react.tsx +0 -0
  22. package/lib/rules/__tests__/fixtures/unstrict/tsconfig.json +15 -0
  23. package/lib/rules/__tests__/max-expects.test.js +330 -0
  24. package/lib/rules/__tests__/max-nested-describe.test.js +247 -0
  25. package/lib/rules/__tests__/no-alias-methods.test.js +190 -0
  26. package/lib/rules/__tests__/no-commented-out-tests.test.js +213 -0
  27. package/lib/rules/__tests__/no-conditional-expect.test.js +696 -0
  28. package/lib/rules/__tests__/no-conditional-in-test.test.js +777 -0
  29. package/lib/rules/__tests__/no-deprecated-functions.test.js +119 -0
  30. package/lib/rules/__tests__/no-disabled-tests.test.js +241 -0
  31. package/lib/rules/__tests__/no-done-callback.test.js +424 -0
  32. package/lib/rules/__tests__/no-duplicate-hooks.test.js +469 -0
  33. package/lib/rules/__tests__/no-export.test.js +107 -0
  34. package/lib/rules/__tests__/no-focused-tests.test.js +373 -0
  35. package/lib/rules/__tests__/no-hooks.test.js +90 -0
  36. package/lib/rules/__tests__/no-identical-title.test.js +270 -0
  37. package/lib/rules/__tests__/no-if.test.js +787 -0
  38. package/lib/rules/__tests__/no-interpolation-in-snapshots.test.js +58 -0
  39. package/lib/rules/__tests__/no-jasmine-globals.test.js +206 -0
  40. package/lib/rules/__tests__/no-large-snapshots.test.js +237 -0
  41. package/lib/rules/__tests__/no-mocks-import.test.js +73 -0
  42. package/lib/rules/__tests__/no-restricted-jest-methods.test.js +103 -0
  43. package/lib/rules/__tests__/no-restricted-matchers.test.js +244 -0
  44. package/lib/rules/__tests__/no-standalone-expect.test.js +230 -0
  45. package/lib/rules/__tests__/no-test-prefixes.test.js +206 -0
  46. package/lib/rules/__tests__/no-test-return-statement.test.js +122 -0
  47. package/lib/rules/__tests__/no-untyped-mock-factory.test.js +149 -0
  48. package/lib/rules/__tests__/prefer-called-with.test.js +40 -0
  49. package/lib/rules/__tests__/prefer-comparison-matcher.test.js +200 -0
  50. package/lib/rules/__tests__/prefer-each.test.js +295 -0
  51. package/lib/rules/__tests__/prefer-equality-matcher.test.js +184 -0
  52. package/lib/rules/__tests__/prefer-expect-assertions.test.js +1437 -0
  53. package/lib/rules/__tests__/prefer-expect-resolves.test.js +96 -0
  54. package/lib/rules/__tests__/prefer-hooks-in-order.test.js +678 -0
  55. package/lib/rules/__tests__/prefer-hooks-on-top.test.js +218 -0
  56. package/lib/rules/__tests__/prefer-lowercase-title.test.js +619 -0
  57. package/lib/rules/__tests__/prefer-mock-promise-shorthand.test.js +360 -0
  58. package/lib/rules/__tests__/prefer-snapshot-hint.test.js +784 -0
  59. package/lib/rules/__tests__/prefer-spy-on.test.js +100 -0
  60. package/lib/rules/__tests__/prefer-strict-equal.test.js +46 -0
  61. package/lib/rules/__tests__/prefer-to-be.test.js +438 -0
  62. package/lib/rules/__tests__/prefer-to-contain.test.js +301 -0
  63. package/lib/rules/__tests__/prefer-to-have-length.test.js +99 -0
  64. package/lib/rules/__tests__/prefer-todo.test.js +78 -0
  65. package/lib/rules/__tests__/require-hook.test.js +403 -0
  66. package/lib/rules/__tests__/require-to-throw-message.test.js +108 -0
  67. package/lib/rules/__tests__/require-top-level-describe.test.js +236 -0
  68. package/lib/rules/__tests__/test-utils.js +11 -0
  69. package/lib/rules/__tests__/unbound-method.test.js +518 -0
  70. package/lib/rules/__tests__/valid-describe-callback.test.js +305 -0
  71. package/lib/rules/__tests__/valid-expect-in-promise.test.js +1583 -0
  72. package/lib/rules/__tests__/valid-expect.test.js +894 -0
  73. package/lib/rules/__tests__/valid-title.test.js +1147 -0
  74. package/lib/rules/utils/__tests__/detectJestVersion.test.js +221 -0
  75. package/lib/rules/utils/__tests__/parseJestFnCall.test.js +809 -0
  76. package/lib/rules/utils/accessors.js +4 -0
  77. package/lib/rules/utils/misc.js +36 -20
  78. package/lib/rules/valid-expect-in-promise.js +3 -3
  79. package/package.json +13 -9
@@ -5,6 +5,10 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.isSupportedAccessor = exports.isStringNode = exports.isIdentifier = exports.getStringValue = exports.getAccessorValue = void 0;
7
7
  var _utils = require("@typescript-eslint/utils");
8
+ /**
9
+ * A `Literal` with a `value` of type `string`.
10
+ */
11
+
8
12
  /**
9
13
  * Checks if the given `node` is a `StringLiteral`.
10
14
  *
@@ -21,6 +21,22 @@ const createRule = _utils.ESLintUtils.RuleCreator(name => {
21
21
  /**
22
22
  * Represents a `MemberExpression` with a "known" `property`.
23
23
  */
24
+
25
+ /**
26
+ * Represents a `CallExpression` with a "known" `property` accessor.
27
+ *
28
+ * i.e `KnownCallExpression<'includes'>` represents `.includes()`.
29
+ */
30
+
31
+ /**
32
+ * Represents a `MemberExpression` with a "known" `property`, that is called.
33
+ *
34
+ * This is `KnownCallExpression` from the perspective of the `MemberExpression` node.
35
+ */
36
+
37
+ /**
38
+ * Represents a `CallExpression` with a single argument.
39
+ */
24
40
  exports.createRule = createRule;
25
41
  /**
26
42
  * Guards that the given `call` has only one `argument`.
@@ -31,44 +47,44 @@ exports.createRule = createRule;
31
47
  */
32
48
  const hasOnlyOneArgument = call => call.arguments.length === 1;
33
49
  exports.hasOnlyOneArgument = hasOnlyOneArgument;
34
- let DescribeAlias;
35
- exports.DescribeAlias = DescribeAlias;
36
- (function (DescribeAlias) {
50
+ let DescribeAlias = /*#__PURE__*/function (DescribeAlias) {
37
51
  DescribeAlias["describe"] = "describe";
38
52
  DescribeAlias["fdescribe"] = "fdescribe";
39
53
  DescribeAlias["xdescribe"] = "xdescribe";
40
- })(DescribeAlias || (exports.DescribeAlias = DescribeAlias = {}));
41
- let TestCaseName;
42
- exports.TestCaseName = TestCaseName;
43
- (function (TestCaseName) {
54
+ return DescribeAlias;
55
+ }({});
56
+ exports.DescribeAlias = DescribeAlias;
57
+ let TestCaseName = /*#__PURE__*/function (TestCaseName) {
44
58
  TestCaseName["fit"] = "fit";
45
59
  TestCaseName["it"] = "it";
46
60
  TestCaseName["test"] = "test";
47
61
  TestCaseName["xit"] = "xit";
48
62
  TestCaseName["xtest"] = "xtest";
49
- })(TestCaseName || (exports.TestCaseName = TestCaseName = {}));
50
- let HookName;
51
- exports.HookName = HookName;
52
- (function (HookName) {
63
+ return TestCaseName;
64
+ }({});
65
+ exports.TestCaseName = TestCaseName;
66
+ let HookName = /*#__PURE__*/function (HookName) {
53
67
  HookName["beforeAll"] = "beforeAll";
54
68
  HookName["beforeEach"] = "beforeEach";
55
69
  HookName["afterAll"] = "afterAll";
56
70
  HookName["afterEach"] = "afterEach";
57
- })(HookName || (exports.HookName = HookName = {}));
58
- let ModifierName;
59
- exports.ModifierName = ModifierName;
60
- (function (ModifierName) {
71
+ return HookName;
72
+ }({});
73
+ exports.HookName = HookName;
74
+ let ModifierName = /*#__PURE__*/function (ModifierName) {
61
75
  ModifierName["not"] = "not";
62
76
  ModifierName["rejects"] = "rejects";
63
77
  ModifierName["resolves"] = "resolves";
64
- })(ModifierName || (exports.ModifierName = ModifierName = {}));
65
- let EqualityMatcher;
66
- exports.EqualityMatcher = EqualityMatcher;
67
- (function (EqualityMatcher) {
78
+ return ModifierName;
79
+ }({});
80
+ exports.ModifierName = ModifierName;
81
+ let EqualityMatcher = /*#__PURE__*/function (EqualityMatcher) {
68
82
  EqualityMatcher["toBe"] = "toBe";
69
83
  EqualityMatcher["toEqual"] = "toEqual";
70
84
  EqualityMatcher["toStrictEqual"] = "toStrictEqual";
71
- })(EqualityMatcher || (exports.EqualityMatcher = EqualityMatcher = {}));
85
+ return EqualityMatcher;
86
+ }({});
87
+ exports.EqualityMatcher = EqualityMatcher;
72
88
  const joinNames = (a, b) => a && b ? `${a}.${b}` : null;
73
89
  function getNodeName(node) {
74
90
  if ((0, _accessors.isSupportedAccessor)(node)) {
@@ -50,7 +50,7 @@ const isPromiseMethodThatUsesValue = (node, identifier) => {
50
50
  const nodeName = (0, _utils2.getNodeName)(node.argument);
51
51
  if (['Promise.all', 'Promise.allSettled'].includes(nodeName)) {
52
52
  const [firstArg] = node.argument.arguments;
53
- if (firstArg.type === _utils.AST_NODE_TYPES.ArrayExpression && firstArg.elements.some(nod => (0, _utils2.isIdentifier)(nod, name))) {
53
+ if (firstArg.type === _utils.AST_NODE_TYPES.ArrayExpression && firstArg.elements.some(nod => nod && (0, _utils2.isIdentifier)(nod, name))) {
54
54
  return true;
55
55
  }
56
56
  }
@@ -67,10 +67,10 @@ const isPromiseMethodThatUsesValue = (node, identifier) => {
67
67
  */
68
68
  const isValueAwaitedInElements = (name, elements) => {
69
69
  for (const element of elements) {
70
- if (element.type === _utils.AST_NODE_TYPES.AwaitExpression && (0, _utils2.isIdentifier)(element.argument, name)) {
70
+ if ((element === null || element === void 0 ? void 0 : element.type) === _utils.AST_NODE_TYPES.AwaitExpression && (0, _utils2.isIdentifier)(element.argument, name)) {
71
71
  return true;
72
72
  }
73
- if (element.type === _utils.AST_NODE_TYPES.ArrayExpression && isValueAwaitedInElements(name, element.elements)) {
73
+ if ((element === null || element === void 0 ? void 0 : element.type) === _utils.AST_NODE_TYPES.ArrayExpression && isValueAwaitedInElements(name, element.elements)) {
74
74
  return true;
75
75
  }
76
76
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "eslint-plugin-jest",
3
- "version": "27.2.0",
3
+ "version": "27.2.2",
4
4
  "description": "ESLint rules for Jest",
5
5
  "keywords": [
6
6
  "eslint",
@@ -105,7 +105,7 @@
105
105
  "@babel/preset-typescript": "^7.3.3",
106
106
  "@commitlint/cli": "^17.0.3",
107
107
  "@commitlint/config-conventional": "^17.0.3",
108
- "@schemastore/package": "^0.0.6",
108
+ "@schemastore/package": "^0.0.8",
109
109
  "@semantic-release/changelog": "^6.0.0",
110
110
  "@semantic-release/git": "^10.0.0",
111
111
  "@tsconfig/node14": "^1.0.3",
@@ -128,24 +128,25 @@
128
128
  "eslint-plugin-node": "^11.0.0",
129
129
  "eslint-plugin-prettier": "^4.2.1",
130
130
  "eslint-remote-tester": "^3.0.0",
131
- "eslint-remote-tester-repositories": "~0.0.5",
131
+ "eslint-remote-tester-repositories": "~1.0.0",
132
132
  "husky": "^8.0.1",
133
133
  "is-ci": "^3.0.0",
134
134
  "jest": "^29.0.0",
135
- "jest-runner-eslint": "^1.1.0",
135
+ "jest-runner-eslint": "^2.0.0",
136
136
  "lint-staged": "^13.0.3",
137
137
  "markdown-link-check": "^3.10.2",
138
138
  "pinst": "^3.0.0",
139
139
  "prettier": "^2.0.5",
140
- "rimraf": "^3.0.0",
141
- "semantic-release": "^19.0.0",
140
+ "rimraf": "^5.0.0",
141
+ "semantic-release": "^21.0.0",
142
142
  "semver": "^7.3.5",
143
143
  "ts-node": "^10.2.1",
144
- "typescript": "^4.4.0"
144
+ "typescript": "^5.0.4"
145
145
  },
146
146
  "peerDependencies": {
147
147
  "@typescript-eslint/eslint-plugin": "^5.0.0",
148
- "eslint": "^7.0.0 || ^8.0.0"
148
+ "eslint": "^7.0.0 || ^8.0.0",
149
+ "jest": "*"
149
150
  },
150
151
  "peerDependenciesMeta": {
151
152
  "@typescript-eslint/eslint-plugin": {
@@ -155,8 +156,11 @@
155
156
  "optional": true
156
157
  }
157
158
  },
158
- "packageManager": "yarn@3.3.1",
159
+ "packageManager": "yarn@3.6.0",
159
160
  "engines": {
160
161
  "node": "^14.15.0 || ^16.10.0 || >=18.0.0"
162
+ },
163
+ "publishConfig": {
164
+ "provenance": true
161
165
  }
162
166
  }