Stats Data
While an analysis of the overall rule performance for an ESLint run can be carried out by setting the TIMING environment variable, it can sometimes be useful to acquire more granular timing data (lint time per file per rule) or collect other measures of interest. In particular, when developing new custom plugins and evaluating/benchmarking new languages or rule sets. For these use cases, you can optionally collect runtime statistics from ESLint.
Enable stats collection
To enable collection of statistics, you can either:
- Use the --statsCLI option. This will pass the stats data into the formatter used to output results from ESLint. (Note: not all formatters output stats data.)
- Set stats: trueas an option on theESLintconstructor.
Enabling stats data adds a new stats key to each LintResult object containing data such as parse times, fix times, lint times per rule.
As such, it is not available via stdout but made easily ingestible via a formatter using the CLI or via the Node.js API to cater to your specific needs.
◆ Stats type
The Stats value is the timing information of each lint run. The stats property of the LintResult type contains it. It has the following properties:
- fixPasses(- number)
 The number of times ESLint has applied at least one fix after linting.
- times(- { passes: TimePass[] })
 The times spent on (parsing, fixing, linting) a file, where the linting refers to the timing information for each rule.- TimePass(- { parse: ParseTime, rules?: Record<string, RuleTime>, fix: FixTime, total: number })
 An object containing the times spent on (parsing, fixing, linting)- ParseTime(- { total: number })
 The total time that is spent when parsing a file.
- RuleTime(- { total: number })
 The total time that is spent on a rule.
- FixTime(- { total: number })
 The total time that is spent on applying fixes to the code.
 
 
CLI usage
Let’s consider the following example:
/*eslint no-regex-spaces: "error", wrap-regex: "error"*/
function a() {
	return / foo/.test("bar");
}
Run ESLint with --stats and output to JSON via the built-in json formatter:
npm
npx eslint file-to-fix.js --fix --stats -f json 
yarn
yarn dlx eslint file-to-fix.js --fix --stats -f json 
pnpm
pnpm dlx eslint file-to-fix.js --fix --stats -f json 
bun
bunx eslint file-to-fix.js --fix --stats -f json 
This yields the following stats entry as part of the formatted lint results object:
{
	"times": {
		"passes": [
			{
				"parse": {
					"total": 3.975959
				},
				"rules": {
					"no-regex-spaces": {
						"total": 0.160792
					},
					"wrap-regex": {
						"total": 0.422626
					}
				},
				"fix": {
					"total": 0.080208
				},
				"total": 12.765959
			},
			{
				"parse": {
					"total": 0.623542
				},
				"rules": {
					"no-regex-spaces": {
						"total": 0.043084
					},
					"wrap-regex": {
						"total": 0.007959
					}
				},
				"fix": {
					"total": 0
				},
				"total": 1.148875
			}
		]
	},
	"fixPasses": 1
}
Note, that for the simple example above, the sum of all rule times should be directly comparable to the first column of the TIMING output. Running the same command with TIMING=all, you can verify this:
$ TIMING=all npx eslint file-to-fix.js --fix --stats -f json
...
Rule            | Time (ms) | Relative
:---------------|----------:|--------:
wrap-regex      |     0.431 |    67.9%
no-regex-spaces |     0.204 |    32.1%
API Usage
You can achieve the same thing using the Node.js API by passing stats: true as an option to the ESLint constructor. For example:
const { ESLint } = require("eslint");
(async function main() {
	// 1. Create an instance.
	const eslint = new ESLint({ stats: true, fix: true });
	// 2. Lint files.
	const results = await eslint.lintFiles(["file-to-fix.js"]);
	// 3. Format the results.
	const formatter = await eslint.loadFormatter("json");
	const resultText = formatter.format(results);
	// 4. Output it.
	console.log(resultText);
})().catch(error => {
	process.exitCode = 1;
	console.error(error);
});