2020-08-26 01:57:08 +02:00
|
|
|
"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 setup and teardown hooks',
|
|
|
|
recommended: false
|
|
|
|
},
|
|
|
|
messages: {
|
|
|
|
unexpectedHook: "Unexpected '{{ hookName }}' hook"
|
|
|
|
},
|
|
|
|
schema: [{
|
|
|
|
type: 'object',
|
|
|
|
properties: {
|
|
|
|
allow: {
|
|
|
|
type: 'array',
|
|
|
|
contains: ['beforeAll', 'beforeEach', 'afterAll', 'afterEach']
|
|
|
|
}
|
|
|
|
},
|
|
|
|
additionalProperties: false
|
|
|
|
}],
|
|
|
|
type: 'suggestion'
|
|
|
|
},
|
|
|
|
defaultOptions: [{
|
|
|
|
allow: []
|
|
|
|
}],
|
|
|
|
create(context, [{
|
|
|
|
allow = []
|
|
|
|
}]) {
|
|
|
|
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) === 'hook' && !allow.includes(jestFnCall.name)) {
|
2020-08-26 01:57:08 +02:00
|
|
|
context.report({
|
|
|
|
node,
|
|
|
|
messageId: 'unexpectedHook',
|
|
|
|
data: {
|
2022-11-10 11:43:16 +01:00
|
|
|
hookName: jestFnCall.name
|
2020-08-26 01:57:08 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
exports.default = _default;
|