123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- "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: 'Disallow disabled tests',
- recommended: 'warn'
- },
- messages: {
- missingFunction: 'Test is missing function argument',
- skippedTestSuite: 'Skipped test suite',
- skippedTest: 'Skipped test',
- pending: 'Call to pending()',
- pendingSuite: 'Call to pending() within test suite',
- pendingTest: 'Call to pending() within test',
- disabledSuite: 'Disabled test suite',
- disabledTest: 'Disabled test'
- },
- schema: [],
- type: 'suggestion'
- },
- defaultOptions: [],
- create(context) {
- let suiteDepth = 0;
- let testDepth = 0;
- return {
- 'CallExpression[callee.name="describe"]'() {
- suiteDepth++;
- },
- 'CallExpression[callee.name=/^(it|test)$/]'() {
- testDepth++;
- },
- 'CallExpression[callee.name=/^(it|test)$/][arguments.length<2]'(node) {
- context.report({
- messageId: 'missingFunction',
- node
- });
- },
- CallExpression(node) {
- const functionName = (0, _utils.getNodeName)(node.callee); // prevent duplicate warnings for it.each()()
- if (node.callee.type === 'CallExpression') {
- return;
- }
- switch (functionName) {
- case 'describe.skip.each':
- case 'xdescribe.each':
- case 'describe.skip':
- context.report({
- messageId: 'skippedTestSuite',
- node
- });
- break;
- case 'it.skip':
- case 'it.concurrent.skip':
- case 'test.skip':
- case 'test.concurrent.skip':
- case 'it.skip.each':
- case 'test.skip.each':
- case 'xit.each':
- case 'xtest.each':
- context.report({
- messageId: 'skippedTest',
- node
- });
- break;
- }
- },
- 'CallExpression[callee.name="pending"]'(node) {
- if ((0, _utils.scopeHasLocalReference)(context.getScope(), 'pending')) {
- return;
- }
- if (testDepth > 0) {
- context.report({
- messageId: 'pendingTest',
- node
- });
- } else if (suiteDepth > 0) {
- context.report({
- messageId: 'pendingSuite',
- node
- });
- } else {
- context.report({
- messageId: 'pending',
- node
- });
- }
- },
- 'CallExpression[callee.name="xdescribe"]'(node) {
- context.report({
- messageId: 'disabledSuite',
- node
- });
- },
- 'CallExpression[callee.name=/^(xit|xtest)$/]'(node) {
- context.report({
- messageId: 'disabledTest',
- node
- });
- },
- 'CallExpression[callee.name="describe"]:exit'() {
- suiteDepth--;
- },
- 'CallExpression[callee.name=/^(it|test)$/]:exit'() {
- testDepth--;
- }
- };
- }
- });
- exports.default = _default;
|