/** * @fileoverview Disallow the use of process.exit() * @author Nicholas C. Zakas * @deprecated in ESLint v7.0.0 */ "use strict"; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ /** @type {import('../types').Rule.RuleModule} */ module.exports = { meta: { deprecated: { message: "Node.js rules were moved out of ESLint core.", url: "https://eslint.org/docs/latest/use/migrating-to-7.0.0#deprecate-node-rules", deprecatedSince: "7.0.0", availableUntil: null, replacedBy: [ { message: "eslint-plugin-n now maintains deprecated Node.js-related rules.", plugin: { name: "eslint-plugin-n", url: "https://github.com/eslint-community/eslint-plugin-n", }, rule: { name: "no-process-exit", url: "https://github.com/eslint-community/eslint-plugin-n/tree/master/docs/rules/no-process-exit.md", }, }, ], }, type: "suggestion", docs: { description: "Disallow the use of `process.exit()`", recommended: false, url: "https://eslint.org/docs/latest/rules/no-process-exit", }, schema: [], messages: { noProcessExit: "Don't use process.exit(); throw an error instead.", }, }, create(context) { //-------------------------------------------------------------------------- // Public //-------------------------------------------------------------------------- return { "CallExpression > MemberExpression.callee[object.name = 'process'][property.name = 'exit']"( node, ) { context.report({ node: node.parent, messageId: "noProcessExit", }); }, }; }, };