web 3d图形渲染器
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

150 lines
5.1 KiB

  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = void 0;
  6. var _experimentalUtils = require("@typescript-eslint/experimental-utils");
  7. var _utils = require("./utils");
  8. const isExpectAssertionsOrHasAssertionsCall = expression => expression.type === _experimentalUtils.AST_NODE_TYPES.CallExpression && expression.callee.type === _experimentalUtils.AST_NODE_TYPES.MemberExpression && (0, _utils.isSupportedAccessor)(expression.callee.object, 'expect') && (0, _utils.isSupportedAccessor)(expression.callee.property) && ['assertions', 'hasAssertions'].includes((0, _utils.getAccessorValue)(expression.callee.property));
  9. const isFirstLineExprStmt = functionBody => functionBody[0] && functionBody[0].type === _experimentalUtils.AST_NODE_TYPES.ExpressionStatement;
  10. const suggestRemovingExtraArguments = (args, extraArgsStartAt) => ({
  11. messageId: 'suggestRemovingExtraArguments',
  12. fix: fixer => fixer.removeRange([args[extraArgsStartAt].range[0] - Math.sign(extraArgsStartAt), args[args.length - 1].range[1]])
  13. });
  14. const suggestions = [['suggestAddingHasAssertions', 'expect.hasAssertions();'], ['suggestAddingAssertions', 'expect.assertions();']];
  15. var _default = (0, _utils.createRule)({
  16. name: __filename,
  17. meta: {
  18. docs: {
  19. category: 'Best Practices',
  20. description: 'Suggest using `expect.assertions()` OR `expect.hasAssertions()`',
  21. recommended: false,
  22. suggestion: true
  23. },
  24. messages: {
  25. hasAssertionsTakesNoArguments: '`expect.hasAssertions` expects no arguments',
  26. assertionsRequiresOneArgument: '`expect.assertions` excepts a single argument of type number',
  27. assertionsRequiresNumberArgument: 'This argument should be a number',
  28. haveExpectAssertions: 'Every test should have either `expect.assertions(<number of assertions>)` or `expect.hasAssertions()` as its first expression',
  29. suggestAddingHasAssertions: 'Add `expect.hasAssertions()`',
  30. suggestAddingAssertions: 'Add `expect.assertions(<number of assertions>)`',
  31. suggestRemovingExtraArguments: 'Remove extra arguments'
  32. },
  33. type: 'suggestion',
  34. schema: [{
  35. type: 'object',
  36. properties: {
  37. onlyFunctionsWithAsyncKeyword: {
  38. type: 'boolean'
  39. }
  40. },
  41. additionalProperties: false
  42. }]
  43. },
  44. defaultOptions: [{
  45. onlyFunctionsWithAsyncKeyword: false
  46. }],
  47. create(context, [options]) {
  48. return {
  49. CallExpression(node) {
  50. if (!(0, _utils.isTestCaseCall)(node)) {
  51. return;
  52. }
  53. const args = (0, _utils.isEachCall)(node) ? node.parent.arguments : node.arguments;
  54. if (args.length < 2) {
  55. return;
  56. }
  57. const [, testFn] = args;
  58. if (!(0, _utils.isFunction)(testFn) || testFn.body.type !== _experimentalUtils.AST_NODE_TYPES.BlockStatement || options.onlyFunctionsWithAsyncKeyword && !testFn.async) {
  59. return;
  60. }
  61. const testFuncBody = testFn.body.body;
  62. if (!isFirstLineExprStmt(testFuncBody)) {
  63. context.report({
  64. messageId: 'haveExpectAssertions',
  65. node,
  66. suggest: suggestions.map(([messageId, text]) => ({
  67. messageId,
  68. fix: fixer => fixer.insertTextBeforeRange([testFn.body.range[0] + 1, testFn.body.range[1]], text)
  69. }))
  70. });
  71. return;
  72. }
  73. const testFuncFirstLine = testFuncBody[0].expression;
  74. if (!isExpectAssertionsOrHasAssertionsCall(testFuncFirstLine)) {
  75. context.report({
  76. messageId: 'haveExpectAssertions',
  77. node,
  78. suggest: suggestions.map(([messageId, text]) => ({
  79. messageId,
  80. fix: fixer => fixer.insertTextBefore(testFuncBody[0], text)
  81. }))
  82. });
  83. return;
  84. }
  85. if ((0, _utils.isSupportedAccessor)(testFuncFirstLine.callee.property, 'hasAssertions')) {
  86. if (testFuncFirstLine.arguments.length) {
  87. context.report({
  88. messageId: 'hasAssertionsTakesNoArguments',
  89. node: testFuncFirstLine.callee.property,
  90. suggest: [suggestRemovingExtraArguments(testFuncFirstLine.arguments, 0)]
  91. });
  92. }
  93. return;
  94. }
  95. if (!(0, _utils.hasOnlyOneArgument)(testFuncFirstLine)) {
  96. let {
  97. loc
  98. } = testFuncFirstLine.callee.property;
  99. const suggest = [];
  100. if (testFuncFirstLine.arguments.length) {
  101. loc = testFuncFirstLine.arguments[1].loc;
  102. suggest.push(suggestRemovingExtraArguments(testFuncFirstLine.arguments, 1));
  103. }
  104. context.report({
  105. messageId: 'assertionsRequiresOneArgument',
  106. suggest,
  107. loc
  108. });
  109. return;
  110. }
  111. const [arg] = testFuncFirstLine.arguments;
  112. if (arg.type === _experimentalUtils.AST_NODE_TYPES.Literal && typeof arg.value === 'number' && Number.isInteger(arg.value)) {
  113. return;
  114. }
  115. context.report({
  116. messageId: 'assertionsRequiresNumberArgument',
  117. node: arg
  118. });
  119. }
  120. };
  121. }
  122. });
  123. exports.default = _default;