modestbench 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +45 -0
- package/LICENSE.md +55 -0
- package/README.md +699 -0
- package/dist/bootstrap.cjs +37 -0
- package/dist/bootstrap.cjs.map +1 -0
- package/dist/bootstrap.d.cts +17 -0
- package/dist/bootstrap.d.cts.map +1 -0
- package/dist/bootstrap.d.ts +17 -0
- package/dist/bootstrap.d.ts.map +1 -0
- package/dist/bootstrap.js +33 -0
- package/dist/bootstrap.js.map +1 -0
- package/dist/cli/commands/history.cjs +459 -0
- package/dist/cli/commands/history.cjs.map +1 -0
- package/dist/cli/commands/history.d.cts +34 -0
- package/dist/cli/commands/history.d.cts.map +1 -0
- package/dist/cli/commands/history.d.ts +34 -0
- package/dist/cli/commands/history.d.ts.map +1 -0
- package/dist/cli/commands/history.js +422 -0
- package/dist/cli/commands/history.js.map +1 -0
- package/dist/cli/commands/init.cjs +566 -0
- package/dist/cli/commands/init.cjs.map +1 -0
- package/dist/cli/commands/init.d.cts +26 -0
- package/dist/cli/commands/init.d.cts.map +1 -0
- package/dist/cli/commands/init.d.ts +26 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +562 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/run.cjs +285 -0
- package/dist/cli/commands/run.cjs.map +1 -0
- package/dist/cli/commands/run.d.cts +37 -0
- package/dist/cli/commands/run.d.cts.map +1 -0
- package/dist/cli/commands/run.d.ts +37 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +248 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/index.cjs +523 -0
- package/dist/cli/index.cjs.map +1 -0
- package/dist/cli/index.d.cts +58 -0
- package/dist/cli/index.d.cts.map +1 -0
- package/dist/cli/index.d.ts +58 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +515 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/config/manager.cjs +370 -0
- package/dist/config/manager.cjs.map +1 -0
- package/dist/config/manager.d.cts +46 -0
- package/dist/config/manager.d.cts.map +1 -0
- package/dist/config/manager.d.ts +46 -0
- package/dist/config/manager.d.ts.map +1 -0
- package/dist/config/manager.js +333 -0
- package/dist/config/manager.js.map +1 -0
- package/dist/config/schema.cjs +182 -0
- package/dist/config/schema.cjs.map +1 -0
- package/dist/config/schema.d.cts +51 -0
- package/dist/config/schema.d.cts.map +1 -0
- package/dist/config/schema.d.ts +51 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +145 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/constants.cjs +22 -0
- package/dist/constants.cjs.map +1 -0
- package/dist/constants.d.cts +10 -0
- package/dist/constants.d.cts.map +1 -0
- package/dist/constants.d.ts +10 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +19 -0
- package/dist/constants.js.map +1 -0
- package/dist/core/benchmark-schema.cjs +135 -0
- package/dist/core/benchmark-schema.cjs.map +1 -0
- package/dist/core/benchmark-schema.d.cts +139 -0
- package/dist/core/benchmark-schema.d.cts.map +1 -0
- package/dist/core/benchmark-schema.d.ts +139 -0
- package/dist/core/benchmark-schema.d.ts.map +1 -0
- package/dist/core/benchmark-schema.js +132 -0
- package/dist/core/benchmark-schema.js.map +1 -0
- package/dist/core/engine.cjs +669 -0
- package/dist/core/engine.cjs.map +1 -0
- package/dist/core/engine.d.cts +128 -0
- package/dist/core/engine.d.cts.map +1 -0
- package/dist/core/engine.d.ts +128 -0
- package/dist/core/engine.d.ts.map +1 -0
- package/dist/core/engine.js +632 -0
- package/dist/core/engine.js.map +1 -0
- package/dist/core/engines/accurate-engine.cjs +292 -0
- package/dist/core/engines/accurate-engine.cjs.map +1 -0
- package/dist/core/engines/accurate-engine.d.cts +63 -0
- package/dist/core/engines/accurate-engine.d.cts.map +1 -0
- package/dist/core/engines/accurate-engine.d.ts +63 -0
- package/dist/core/engines/accurate-engine.d.ts.map +1 -0
- package/dist/core/engines/accurate-engine.js +288 -0
- package/dist/core/engines/accurate-engine.js.map +1 -0
- package/dist/core/engines/index.cjs +21 -0
- package/dist/core/engines/index.cjs.map +1 -0
- package/dist/core/engines/index.d.cts +16 -0
- package/dist/core/engines/index.d.cts.map +1 -0
- package/dist/core/engines/index.d.ts +16 -0
- package/dist/core/engines/index.d.ts.map +1 -0
- package/dist/core/engines/index.js +16 -0
- package/dist/core/engines/index.js.map +1 -0
- package/dist/core/engines/tinybench-engine.cjs +286 -0
- package/dist/core/engines/tinybench-engine.cjs.map +1 -0
- package/dist/core/engines/tinybench-engine.d.cts +18 -0
- package/dist/core/engines/tinybench-engine.d.cts.map +1 -0
- package/dist/core/engines/tinybench-engine.d.ts +18 -0
- package/dist/core/engines/tinybench-engine.d.ts.map +1 -0
- package/dist/core/engines/tinybench-engine.js +282 -0
- package/dist/core/engines/tinybench-engine.js.map +1 -0
- package/dist/core/error-manager.cjs +303 -0
- package/dist/core/error-manager.cjs.map +1 -0
- package/dist/core/error-manager.d.cts +77 -0
- package/dist/core/error-manager.d.cts.map +1 -0
- package/dist/core/error-manager.d.ts +77 -0
- package/dist/core/error-manager.d.ts.map +1 -0
- package/dist/core/error-manager.js +299 -0
- package/dist/core/error-manager.js.map +1 -0
- package/dist/core/loader.cjs +287 -0
- package/dist/core/loader.cjs.map +1 -0
- package/dist/core/loader.d.cts +55 -0
- package/dist/core/loader.d.cts.map +1 -0
- package/dist/core/loader.d.ts +55 -0
- package/dist/core/loader.d.ts.map +1 -0
- package/dist/core/loader.js +250 -0
- package/dist/core/loader.js.map +1 -0
- package/dist/core/stats-utils.cjs +99 -0
- package/dist/core/stats-utils.cjs.map +1 -0
- package/dist/core/stats-utils.d.cts +50 -0
- package/dist/core/stats-utils.d.cts.map +1 -0
- package/dist/core/stats-utils.d.ts +50 -0
- package/dist/core/stats-utils.d.ts.map +1 -0
- package/dist/core/stats-utils.js +94 -0
- package/dist/core/stats-utils.js.map +1 -0
- package/dist/index.cjs +64 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +22 -0
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +30 -0
- package/dist/index.js.map +1 -0
- package/dist/progress/manager.cjs +325 -0
- package/dist/progress/manager.cjs.map +1 -0
- package/dist/progress/manager.d.cts +125 -0
- package/dist/progress/manager.d.cts.map +1 -0
- package/dist/progress/manager.d.ts +125 -0
- package/dist/progress/manager.d.ts.map +1 -0
- package/dist/progress/manager.js +321 -0
- package/dist/progress/manager.js.map +1 -0
- package/dist/reporters/csv.cjs +250 -0
- package/dist/reporters/csv.cjs.map +1 -0
- package/dist/reporters/csv.d.cts +92 -0
- package/dist/reporters/csv.d.cts.map +1 -0
- package/dist/reporters/csv.d.ts +92 -0
- package/dist/reporters/csv.d.ts.map +1 -0
- package/dist/reporters/csv.js +246 -0
- package/dist/reporters/csv.js.map +1 -0
- package/dist/reporters/human.cjs +516 -0
- package/dist/reporters/human.cjs.map +1 -0
- package/dist/reporters/human.d.cts +86 -0
- package/dist/reporters/human.d.cts.map +1 -0
- package/dist/reporters/human.d.ts +86 -0
- package/dist/reporters/human.d.ts.map +1 -0
- package/dist/reporters/human.js +509 -0
- package/dist/reporters/human.js.map +1 -0
- package/dist/reporters/index.cjs +17 -0
- package/dist/reporters/index.cjs.map +1 -0
- package/dist/reporters/index.d.cts +10 -0
- package/dist/reporters/index.d.cts.map +1 -0
- package/dist/reporters/index.d.ts +10 -0
- package/dist/reporters/index.d.ts.map +1 -0
- package/dist/reporters/index.js +10 -0
- package/dist/reporters/index.js.map +1 -0
- package/dist/reporters/json.cjs +215 -0
- package/dist/reporters/json.cjs.map +1 -0
- package/dist/reporters/json.d.cts +79 -0
- package/dist/reporters/json.d.cts.map +1 -0
- package/dist/reporters/json.d.ts +79 -0
- package/dist/reporters/json.d.ts.map +1 -0
- package/dist/reporters/json.js +211 -0
- package/dist/reporters/json.js.map +1 -0
- package/dist/reporters/registry.cjs +255 -0
- package/dist/reporters/registry.cjs.map +1 -0
- package/dist/reporters/registry.d.cts +155 -0
- package/dist/reporters/registry.d.cts.map +1 -0
- package/dist/reporters/registry.d.ts +155 -0
- package/dist/reporters/registry.d.ts.map +1 -0
- package/dist/reporters/registry.js +249 -0
- package/dist/reporters/registry.js.map +1 -0
- package/dist/reporters/simple.cjs +328 -0
- package/dist/reporters/simple.cjs.map +1 -0
- package/dist/reporters/simple.d.cts +51 -0
- package/dist/reporters/simple.d.cts.map +1 -0
- package/dist/reporters/simple.d.ts +51 -0
- package/dist/reporters/simple.d.ts.map +1 -0
- package/dist/reporters/simple.js +321 -0
- package/dist/reporters/simple.js.map +1 -0
- package/dist/schema/modestbench-config.schema.json +162 -0
- package/dist/storage/history.cjs +456 -0
- package/dist/storage/history.cjs.map +1 -0
- package/dist/storage/history.d.cts +99 -0
- package/dist/storage/history.d.cts.map +1 -0
- package/dist/storage/history.d.ts +99 -0
- package/dist/storage/history.d.ts.map +1 -0
- package/dist/storage/history.js +452 -0
- package/dist/storage/history.js.map +1 -0
- package/dist/types/cli.cjs +21 -0
- package/dist/types/cli.cjs.map +1 -0
- package/dist/types/cli.d.cts +296 -0
- package/dist/types/cli.d.cts.map +1 -0
- package/dist/types/cli.d.ts +296 -0
- package/dist/types/cli.d.ts.map +1 -0
- package/dist/types/cli.js +18 -0
- package/dist/types/cli.js.map +1 -0
- package/dist/types/core.cjs +14 -0
- package/dist/types/core.cjs.map +1 -0
- package/dist/types/core.d.cts +380 -0
- package/dist/types/core.d.cts.map +1 -0
- package/dist/types/core.d.ts +380 -0
- package/dist/types/core.d.ts.map +1 -0
- package/dist/types/core.js +13 -0
- package/dist/types/core.js.map +1 -0
- package/dist/types/index.cjs +27 -0
- package/dist/types/index.cjs.map +1 -0
- package/dist/types/index.d.cts +11 -0
- package/dist/types/index.d.cts.map +1 -0
- package/dist/types/index.d.ts +11 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +11 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/interfaces.cjs +10 -0
- package/dist/types/interfaces.cjs.map +1 -0
- package/dist/types/interfaces.d.cts +381 -0
- package/dist/types/interfaces.d.cts.map +1 -0
- package/dist/types/interfaces.d.ts +381 -0
- package/dist/types/interfaces.d.ts.map +1 -0
- package/dist/types/interfaces.js +9 -0
- package/dist/types/interfaces.js.map +1 -0
- package/dist/types/utility.cjs +92 -0
- package/dist/types/utility.cjs.map +1 -0
- package/dist/types/utility.d.cts +330 -0
- package/dist/types/utility.d.cts.map +1 -0
- package/dist/types/utility.d.ts +330 -0
- package/dist/types/utility.d.ts.map +1 -0
- package/dist/types/utility.js +78 -0
- package/dist/types/utility.js.map +1 -0
- package/package.json +211 -0
- package/src/bootstrap.ts +35 -0
- package/src/cli/commands/history.ts +569 -0
- package/src/cli/commands/init.ts +658 -0
- package/src/cli/commands/run.ts +346 -0
- package/src/cli/index.ts +642 -0
- package/src/config/manager.ts +387 -0
- package/src/config/schema.ts +188 -0
- package/src/constants.ts +21 -0
- package/src/core/benchmark-schema.ts +185 -0
- package/src/core/engine.ts +888 -0
- package/src/core/engines/accurate-engine.ts +408 -0
- package/src/core/engines/index.ts +16 -0
- package/src/core/engines/tinybench-engine.ts +335 -0
- package/src/core/error-manager.ts +372 -0
- package/src/core/loader.ts +324 -0
- package/src/core/stats-utils.ts +135 -0
- package/src/index.ts +46 -0
- package/src/progress/manager.ts +415 -0
- package/src/reporters/csv.ts +368 -0
- package/src/reporters/human.ts +707 -0
- package/src/reporters/index.ts +10 -0
- package/src/reporters/json.ts +302 -0
- package/src/reporters/registry.ts +349 -0
- package/src/reporters/simple.ts +459 -0
- package/src/storage/history.ts +600 -0
- package/src/types/cli.ts +312 -0
- package/src/types/core.ts +414 -0
- package/src/types/index.ts +18 -0
- package/src/types/interfaces.ts +451 -0
- package/src/types/utility.ts +446 -0
|
@@ -0,0 +1,516 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ModestBench Human-Readable Console Reporter
|
|
4
|
+
*
|
|
5
|
+
* Provides colorized, progressive output for terminal environments. Displays
|
|
6
|
+
* real-time progress, results, and formatted statistics.
|
|
7
|
+
*/
|
|
8
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
9
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.HumanReporter = void 0;
|
|
13
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
14
|
+
const registry_js_1 = require("./registry.cjs");
|
|
15
|
+
/**
|
|
16
|
+
* ANSI color codes for terminal output
|
|
17
|
+
*/
|
|
18
|
+
const colors = {
|
|
19
|
+
bold: '\x1b[1m',
|
|
20
|
+
brightBlue: '\x1b[94m',
|
|
21
|
+
brightCyan: '\x1b[96m',
|
|
22
|
+
brightMagenta: '\x1b[95m',
|
|
23
|
+
brightRed: '\x1b[91m',
|
|
24
|
+
brightWhite: '\x1b[97m',
|
|
25
|
+
cyan: '\x1b[36m',
|
|
26
|
+
dim: '\x1b[2m',
|
|
27
|
+
gray: '\x1b[90m',
|
|
28
|
+
green: '\x1b[32m',
|
|
29
|
+
magenta: '\x1b[35m',
|
|
30
|
+
red: '\x1b[31m',
|
|
31
|
+
reset: '\x1b[0m',
|
|
32
|
+
underline: '\x1b[4m',
|
|
33
|
+
white: '\x1b[37m',
|
|
34
|
+
};
|
|
35
|
+
/**
|
|
36
|
+
* CP437-inspired ANSI art characters
|
|
37
|
+
*/
|
|
38
|
+
const ansiChars = {
|
|
39
|
+
approx: '≈',
|
|
40
|
+
// Block elements for gradients
|
|
41
|
+
block: {
|
|
42
|
+
dark: '▓',
|
|
43
|
+
full: '█',
|
|
44
|
+
light: '░',
|
|
45
|
+
medium: '▒',
|
|
46
|
+
},
|
|
47
|
+
bullet: '•',
|
|
48
|
+
// Symbols
|
|
49
|
+
checkmark: '√',
|
|
50
|
+
cross: '×',
|
|
51
|
+
plusMinus: '±',
|
|
52
|
+
smallSquare: '▪',
|
|
53
|
+
};
|
|
54
|
+
/**
|
|
55
|
+
* Human-readable console reporter with colorized output
|
|
56
|
+
*/
|
|
57
|
+
class HumanReporter extends registry_js_1.BaseReporter {
|
|
58
|
+
currentFile = '';
|
|
59
|
+
currentSuite = '';
|
|
60
|
+
failures = [];
|
|
61
|
+
lastProgressLine = '';
|
|
62
|
+
progressWindowActive = false; // Track if progress window is rendered
|
|
63
|
+
quiet;
|
|
64
|
+
showProgress;
|
|
65
|
+
startTime = 0;
|
|
66
|
+
suiteResults = [];
|
|
67
|
+
useColor;
|
|
68
|
+
verbose;
|
|
69
|
+
constructor(options = {}) {
|
|
70
|
+
super('human', options);
|
|
71
|
+
// Auto-detect color support if not explicitly set
|
|
72
|
+
this.useColor =
|
|
73
|
+
options.color ??
|
|
74
|
+
(process.stdout.isTTY &&
|
|
75
|
+
process.env.FORCE_COLOR !== '0' &&
|
|
76
|
+
process.env.NO_COLOR == null);
|
|
77
|
+
this.verbose = options.verbose ?? false;
|
|
78
|
+
this.quiet = options.quiet ?? false;
|
|
79
|
+
this.showProgress = options.progress ?? true;
|
|
80
|
+
}
|
|
81
|
+
onEnd(run) {
|
|
82
|
+
if (this.quiet) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
this.clearProgress();
|
|
86
|
+
const duration = Date.now() - this.startTime;
|
|
87
|
+
const totalFiles = run.files.length;
|
|
88
|
+
// Calculate totals across all files
|
|
89
|
+
let totalSuites = 0;
|
|
90
|
+
let totalPassed = 0;
|
|
91
|
+
let totalFailed = 0;
|
|
92
|
+
for (const file of run.files) {
|
|
93
|
+
totalSuites += file.suites.length;
|
|
94
|
+
for (const suite of file.suites) {
|
|
95
|
+
totalPassed += suite.tasks.filter((t) => !t.error).length;
|
|
96
|
+
totalFailed += suite.tasks.filter((t) => t.error).length;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
// Results header
|
|
100
|
+
const resultsHeader = `${this.colorize('magenta', ansiChars.block.full.repeat(2))} ${this.colorize('brightWhite', this.colorize('bold', 'Results'))}`;
|
|
101
|
+
this.printLine(resultsHeader);
|
|
102
|
+
this.printLine();
|
|
103
|
+
this.printLine(`${this.colorize('brightBlue', ' Files:')} ${this.colorize('brightWhite', String(totalFiles))}`);
|
|
104
|
+
this.printLine(`${this.colorize('brightBlue', ' Suites:')} ${this.colorize('brightWhite', String(totalSuites))}`);
|
|
105
|
+
this.printLine(`${this.colorize('brightBlue', ' Tasks:')} ${this.colorize('brightWhite', String(totalPassed + totalFailed))}`);
|
|
106
|
+
if (totalFailed > 0) {
|
|
107
|
+
this.printLine(`${this.colorize('brightRed', ansiChars.cross + ' Failed:')} ${this.colorize('brightWhite', String(totalFailed))}`);
|
|
108
|
+
this.printLine(`${this.colorize('brightCyan', ansiChars.checkmark + ' Passed:')} ${this.colorize('brightWhite', String(totalPassed))}`);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
this.printLine(`${this.colorize('brightCyan', ansiChars.checkmark + ' All tests passed:')} ${this.colorize('brightWhite', String(totalPassed))}`);
|
|
112
|
+
}
|
|
113
|
+
this.printLine(`${this.colorize('cyan', ansiChars.approx + ' Duration:')} ${this.colorize('brightWhite', this.formatDuration(duration * 1000000))}`);
|
|
114
|
+
this.printLine();
|
|
115
|
+
if (totalFailed > 0) {
|
|
116
|
+
// Display failed tasks with details
|
|
117
|
+
if (this.failures.length > 0) {
|
|
118
|
+
this.printLine();
|
|
119
|
+
this.printLine(this.colorize('brightRed', this.colorize('bold', 'Failed Tasks:')));
|
|
120
|
+
this.printLine();
|
|
121
|
+
for (const failure of this.failures) {
|
|
122
|
+
const displayPath = this.formatPath(failure.file);
|
|
123
|
+
this.printLine(` ${this.colorize('dim', displayPath)} ${this.colorize('dim', '›')} ${this.colorize('white', failure.suite)} ${this.colorize('dim', '›')} ${this.colorize('brightWhite', failure.task)}`);
|
|
124
|
+
this.printLine(` ${this.colorize('brightRed', failure.error)}`);
|
|
125
|
+
this.printLine();
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
const successMessage = `${this.colorize('brightMagenta', 'Rad. ☮')}`;
|
|
131
|
+
this.printLine(successMessage);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
onError(error) {
|
|
135
|
+
if (this.quiet) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
this.clearProgress();
|
|
139
|
+
console.error(this.colorize('red', ansiChars.cross.repeat(3) + ' Error:'), error.message);
|
|
140
|
+
if (this.verbose && error.stack) {
|
|
141
|
+
console.error(this.colorize('dim', error.stack));
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
onFileEnd(result) {
|
|
145
|
+
if (this.quiet) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
const totalTasks = result.suites.reduce((sum, suite) => sum + suite.tasks.length, 0);
|
|
149
|
+
const totalPassed = result.suites.reduce((sum, suite) => sum + suite.tasks.filter((t) => !t.error).length, 0);
|
|
150
|
+
const totalFailed = totalTasks - totalPassed;
|
|
151
|
+
if (totalFailed > 0) {
|
|
152
|
+
this.printLine(this.colorize('red', ` ${ansiChars.cross} ${totalFailed} failed, ${totalPassed} passed`));
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
this.printLine(` ${this.colorize('magenta', ansiChars.checkmark)} ${totalPassed > 1 ? this.colorize('brightMagenta', 'All ') : ''}${this.colorize('bold', this.colorize('brightMagenta', `${totalPassed}`))} ${this.colorize('brightMagenta', `${this.pluralize('task', totalPassed)} passed`)}`);
|
|
156
|
+
}
|
|
157
|
+
this.printLine();
|
|
158
|
+
}
|
|
159
|
+
onFileStart(file) {
|
|
160
|
+
this.currentFile = file;
|
|
161
|
+
if (this.quiet) {
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
const displayPath = this.formatPath(file);
|
|
165
|
+
const fileMarker = `${colors.magenta}${ansiChars.block.dark}${ansiChars.block.dark}${colors.reset}`;
|
|
166
|
+
this.printLine(`${fileMarker} ${colors.underline}${this.colorize('brightMagenta', this.colorize('bold', displayPath))}${colors.reset}`);
|
|
167
|
+
}
|
|
168
|
+
onProgress(state) {
|
|
169
|
+
// Only show progress bar in non-verbose, non-quiet mode with progress enabled
|
|
170
|
+
if (this.quiet || this.verbose || !this.showProgress) {
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
// Only show in TTY mode (progress bar updates in place)
|
|
174
|
+
if (!process.stdout.isTTY) {
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
const { elapsed, percentage, tasksCompleted, totalTasks } = state;
|
|
178
|
+
// Pad task counts for alignment
|
|
179
|
+
const totalTasksWidth = String(totalTasks).length;
|
|
180
|
+
const paddedTasksCompleted = String(tasksCompleted).padStart(totalTasksWidth, ' ');
|
|
181
|
+
// Format elapsed time
|
|
182
|
+
const elapsedSeconds = Math.round(elapsed / 1000);
|
|
183
|
+
const elapsedStrRaw = this.formatTimeRemaining(elapsedSeconds);
|
|
184
|
+
// Calculate ETA if we have completed tasks and determine padding width
|
|
185
|
+
let etaStr = '';
|
|
186
|
+
let padWidth = elapsedStrRaw.length;
|
|
187
|
+
if (tasksCompleted > 0) {
|
|
188
|
+
const avgTimePerTask = elapsed / tasksCompleted;
|
|
189
|
+
const remainingTasks = totalTasks - tasksCompleted;
|
|
190
|
+
const etaMs = avgTimePerTask * remainingTasks;
|
|
191
|
+
const etaSeconds = Math.round(etaMs / 1000);
|
|
192
|
+
const etaTimeStr = this.formatTimeRemaining(etaSeconds);
|
|
193
|
+
padWidth = Math.max(padWidth, etaTimeStr.length);
|
|
194
|
+
etaStr = ` ${this.colorize('dim', '|')} ${this.colorize('dim', 'ETA:')} ${this.colorize('brightBlue', etaTimeStr)}`;
|
|
195
|
+
}
|
|
196
|
+
// Pad elapsed time to match the longest time string
|
|
197
|
+
const elapsedStr = elapsedStrRaw.padStart(padWidth, ' ');
|
|
198
|
+
const roundedPercentage = percentage.toFixed(2);
|
|
199
|
+
const line = `${this.colorize('brightCyan', ansiChars.approx)} ${this.colorize('white', paddedTasksCompleted)}${this.colorize('dim', '/')}${this.colorize('white', String(totalTasks))} ${this.colorize('dim', 'tasks')} ${this.colorize('dim', '(')}${this.colorize('brightBlue', roundedPercentage + '%')}${this.colorize('dim', ')')} ${this.colorize('dim', '|')} ${this.colorize('dim', 'Elapsed:')} ${this.colorize('cyan', elapsedStr)}${etaStr}`;
|
|
200
|
+
this.lastProgressLine = line;
|
|
201
|
+
this.renderProgressWindow();
|
|
202
|
+
}
|
|
203
|
+
onStart(run) {
|
|
204
|
+
this.startTime = Date.now();
|
|
205
|
+
this.failures = []; // Reset failures for new run
|
|
206
|
+
this.lastProgressLine = ''; // Reset for new run
|
|
207
|
+
if (this.quiet) {
|
|
208
|
+
return;
|
|
209
|
+
}
|
|
210
|
+
let header;
|
|
211
|
+
if (run.environment) {
|
|
212
|
+
header = `
|
|
213
|
+
\x1b[49m \x1b[38;5;0;49m▄▄\x1b[38;5;37;48;5;0m▄\x1b[38;5;14;48;5;0m▄\x1b[38;5;6;48;5;0m▄\x1b[38;5;0;49m▄▄\x1b[49m \x1b[m
|
|
214
|
+
\x1b[49m \x1b[38;5;0;49m▄\x1b[38;5;235;48;5;0m▄\x1b[38;5;45;48;5;0m▄\x1b[38;5;14;48;5;23m▄\x1b[48;5;14m \x1b[38;5;14;48;5;14m▄\x1b[38;5;14;48;5;236m▄\x1b[38;5;44;48;5;0m▄\x1b[38;5;233;48;5;0m▄\x1b[38;5;0;49m▄\x1b[49m \x1b[m
|
|
215
|
+
\x1b[38;5;0;49m▄▄\x1b[38;5;30;48;5;0m▄\x1b[38;5;14;48;5;233m▄\x1b[38;5;14;48;5;37m▄\x1b[48;5;14m \x1b[38;5;14;48;5;37m▄\x1b[38;5;14;48;5;0m▄\x1b[38;5;23;48;5;0m▄\x1b[38;5;0;49m▄▄\x1b[m
|
|
216
|
+
\x1b[48;5;0m \x1b[38;5;14;48;5;45m▄\x1b[48;5;14m \x1b[38;5;44;48;5;14m▄\x1b[38;5;24;48;5;14m▄\x1b[38;5;242;48;5;14m▄\x1b[38;5;5;48;5;14m▄\x1b[38;5;60;48;5;14m▄\x1b[38;5;24;48;5;14m▄\x1b[38;5;44;48;5;14m▄\x1b[48;5;14m \x1b[38;5;14;48;5;44m▄\x1b[48;5;0m \x1b[m
|
|
217
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;44;48;5;14m▄\x1b[38;5;53;48;5;45m▄\x1b[38;5;44;48;5;53m▄\x1b[38;5;14;48;5;162m▄\x1b[38;5;14;48;5;89m▄▄\x1b[38;5;14;48;5;162m▄\x1b[38;5;44;48;5;198m▄\x1b[38;5;235;48;5;198m▄\x1b[48;5;198m \x1b[38;5;30;48;5;237m▄\x1b[38;5;38;48;5;14m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m \x1b[97m\x1b[4;1mmodest\x1b[0m\x1b[4;97mbench\x1b[0m \x1b[4;97m \x1b[0m \x1b[4;97m \x1b[0m
|
|
218
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;237;48;5;45m▄\x1b[38;5;14;48;5;23m▄\x1b[48;5;14m \x1b[38;5;14;48;5;14m▄\x1b[38;5;53;48;5;38m▄\x1b[38;5;44;48;5;23m▄\x1b[38;5;198;48;5;238m▄\x1b[38;5;198;48;5;125m▄\x1b[38;5;23;48;5;14m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m
|
|
219
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;30;48;5;38m▄\x1b[38;5;14;48;5;14m▄\x1b[48;5;14m \x1b[38;5;45;48;5;14m▄\x1b[38;5;89;48;5;14m▄\x1b[38;5;89;48;5;89m▄\x1b[38;5;14;48;5;31m▄\x1b[48;5;14m \x1b[38;5;37;48;5;89m▄\x1b[48;5;198m \x1b[38;5;198;48;5;198m▄\x1b[38;5;31;48;5;14m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m \x1b[2mnode.js:\x1b[m \x1b[36m${run.environment.nodeVersion} \x1b[m
|
|
220
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;44;48;5;31m▄\x1b[48;5;14m \x1b[38;5;126;48;5;38m▄\x1b[38;5;198;48;5;237m▄\x1b[38;5;237;48;5;37m▄\x1b[48;5;14m \x1b[38;5;14;48;5;14m▄\x1b[38;5;162;48;5;198m▄▄\x1b[38;5;53;48;5;240m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m \x1b[2mplatform:\x1b[m \x1b[36m${run.environment.platform} ${run.environment.arch} \x1b[m
|
|
221
|
+
\x1b[48;5;0m \x1b[38;5;45;48;5;14m▄\x1b[48;5;14m \x1b[38;5;14;48;5;37m▄\x1b[38;5;14;48;5;5m▄\x1b[38;5;14;48;5;44m▄\x1b[48;5;14m \x1b[38;5;45;48;5;14m▄\x1b[48;5;0m \x1b[m \x1b[2mcpu:\x1b[m \x1b[36m${run.environment.cpu.model} \x1b[2m(\x1b[m\x1b[36m${run.environment.cpu.cores} cores) \x1b[m
|
|
222
|
+
\x1b[49;38;5;0m▀▀\x1b[38;5;0;48;5;6m▄\x1b[38;5;232;48;5;14m▄\x1b[38;5;38;48;5;14m▄\x1b[48;5;14m \x1b[38;5;30;48;5;14m▄\x1b[38;5;0;48;5;14m▄\x1b[38;5;0;48;5;23m▄\x1b[49;38;5;0m▀▀\x1b[m \x1b[2mmem:\x1b[m \x1b[36m${this.formatBytes(run.environment.memory.total)} \x1b[m
|
|
223
|
+
\x1b[49m \x1b[49;38;5;0m▀\x1b[38;5;0;48;5;236m▄\x1b[38;5;0;48;5;45m▄\x1b[38;5;23;48;5;14m▄\x1b[48;5;14m \x1b[38;5;236;48;5;14m▄\x1b[38;5;0;48;5;44m▄\x1b[38;5;0;48;5;232m▄\x1b[49;38;5;0m▀\x1b[49m \x1b[m
|
|
224
|
+
\x1b[49m \x1b[49;38;5;0m▀▀\x1b[38;5;0;48;5;37m▄\x1b[38;5;0;48;5;14m▄\x1b[38;5;0;48;5;30m▄\x1b[49;38;5;0m▀▀\x1b[49m \x1b[m
|
|
225
|
+
`;
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
header = `
|
|
229
|
+
\x1b[49m \x1b[38;5;0;49m▄▄\x1b[38;5;37;48;5;0m▄\x1b[38;5;14;48;5;0m▄\x1b[38;5;6;48;5;0m▄\x1b[38;5;0;49m▄▄\x1b[49m \x1b[m
|
|
230
|
+
\x1b[49m \x1b[38;5;0;49m▄\x1b[38;5;235;48;5;0m▄\x1b[38;5;45;48;5;0m▄\x1b[38;5;14;48;5;23m▄\x1b[48;5;14m \x1b[38;5;14;48;5;14m▄\x1b[38;5;14;48;5;236m▄\x1b[38;5;44;48;5;0m▄\x1b[38;5;233;48;5;0m▄\x1b[38;5;0;49m▄\x1b[49m \x1b[m
|
|
231
|
+
\x1b[38;5;0;49m▄▄\x1b[38;5;30;48;5;0m▄\x1b[38;5;14;48;5;233m▄\x1b[38;5;14;48;5;37m▄\x1b[48;5;14m \x1b[38;5;14;48;5;37m▄\x1b[38;5;14;48;5;0m▄\x1b[38;5;23;48;5;0m▄\x1b[38;5;0;49m▄▄\x1b[m
|
|
232
|
+
\x1b[48;5;0m \x1b[38;5;14;48;5;45m▄\x1b[48;5;14m \x1b[38;5;44;48;5;14m▄\x1b[38;5;24;48;5;14m▄\x1b[38;5;242;48;5;14m▄\x1b[38;5;5;48;5;14m▄\x1b[38;5;60;48;5;14m▄\x1b[38;5;24;48;5;14m▄\x1b[38;5;44;48;5;14m▄\x1b[48;5;14m \x1b[38;5;14;48;5;44m▄\x1b[48;5;0m \x1b[m
|
|
233
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;44;48;5;14m▄\x1b[38;5;53;48;5;45m▄\x1b[38;5;44;48;5;53m▄\x1b[38;5;14;48;5;162m▄\x1b[38;5;14;48;5;89m▄▄\x1b[38;5;14;48;5;162m▄\x1b[38;5;44;48;5;198m▄\x1b[38;5;235;48;5;198m▄\x1b[48;5;198m \x1b[38;5;30;48;5;237m▄\x1b[38;5;38;48;5;14m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m \x1b[97m\x1b[4;1mmodest\x1b[0m\x1b[4;97mbench\x1b[0m \x1b[4;97m \x1b[0m
|
|
234
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;237;48;5;45m▄\x1b[38;5;14;48;5;23m▄\x1b[48;5;14m \x1b[38;5;14;48;5;14m▄\x1b[38;5;53;48;5;38m▄\x1b[38;5;44;48;5;23m▄\x1b[38;5;198;48;5;238m▄\x1b[38;5;198;48;5;125m▄\x1b[38;5;23;48;5;14m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m
|
|
235
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;30;48;5;38m▄\x1b[38;5;14;48;5;14m▄\x1b[48;5;14m \x1b[38;5;45;48;5;14m▄\x1b[38;5;89;48;5;14m▄\x1b[38;5;89;48;5;89m▄\x1b[38;5;14;48;5;31m▄\x1b[48;5;14m \x1b[38;5;37;48;5;89m▄\x1b[48;5;198m \x1b[38;5;198;48;5;198m▄\x1b[38;5;31;48;5;14m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m
|
|
236
|
+
\x1b[48;5;0m \x1b[48;5;14m \x1b[38;5;44;48;5;31m▄\x1b[48;5;14m \x1b[38;5;126;48;5;38m▄\x1b[38;5;198;48;5;237m▄\x1b[38;5;237;48;5;37m▄\x1b[48;5;14m \x1b[38;5;14;48;5;14m▄\x1b[38;5;162;48;5;198m▄▄\x1b[38;5;53;48;5;240m▄\x1b[48;5;14m \x1b[48;5;0m \x1b[m
|
|
237
|
+
\x1b[48;5;0m \x1b[38;5;45;48;5;14m▄\x1b[48;5;14m \x1b[38;5;14;48;5;37m▄\x1b[38;5;14;48;5;5m▄\x1b[38;5;14;48;5;44m▄\x1b[48;5;14m \x1b[38;5;45;48;5;14m▄\x1b[48;5;0m \x1b[m
|
|
238
|
+
\x1b[49;38;5;0m▀▀\x1b[38;5;0;48;5;6m▄\x1b[38;5;232;48;5;14m▄\x1b[38;5;38;48;5;14m▄\x1b[48;5;14m \x1b[38;5;30;48;5;14m▄\x1b[38;5;0;48;5;14m▄\x1b[38;5;0;48;5;23m▄\x1b[49;38;5;0m▀▀\x1b[m
|
|
239
|
+
\x1b[49m \x1b[49;38;5;0m▀\x1b[38;5;0;48;5;236m▄\x1b[38;5;0;48;5;45m▄\x1b[38;5;23;48;5;14m▄\x1b[48;5;14m \x1b[38;5;236;48;5;14m▄\x1b[38;5;0;48;5;44m▄\x1b[38;5;0;48;5;232m▄\x1b[49;38;5;0m▀\x1b[49m \x1b[m
|
|
240
|
+
\x1b[49m \x1b[49;38;5;0m▀▀\x1b[38;5;0;48;5;37m▄\x1b[38;5;0;48;5;14m▄\x1b[38;5;0;48;5;30m▄\x1b[49;38;5;0m▀▀\x1b[49m \x1b[m
|
|
241
|
+
`;
|
|
242
|
+
}
|
|
243
|
+
this.printLine(header);
|
|
244
|
+
this.printLine();
|
|
245
|
+
if (run.git) {
|
|
246
|
+
this.printLine(` Git: ${this.colorize('cyan', run.git.commit)}`);
|
|
247
|
+
}
|
|
248
|
+
if (run.ci) {
|
|
249
|
+
this.printLine(` CI: ${this.colorize('cyan', run.ci.provider)}`);
|
|
250
|
+
this.printLine();
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
onSuiteEnd(result) {
|
|
254
|
+
if (this.quiet) {
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
// Print all buffered task results with aligned columns
|
|
258
|
+
this.printAlignedSuiteResults();
|
|
259
|
+
// Skip displaying summary for the implicit "default" suite
|
|
260
|
+
if (result.name === 'default') {
|
|
261
|
+
return;
|
|
262
|
+
}
|
|
263
|
+
const passed = result.tasks.filter((t) => !t.error).length;
|
|
264
|
+
const failed = result.tasks.filter((t) => t.error).length;
|
|
265
|
+
if (failed > 0) {
|
|
266
|
+
this.printLine(` ${this.colorize('red', `${ansiChars.cross} ${failed} failed`)}, ${this.colorize('green', `${passed} passed`)}`);
|
|
267
|
+
}
|
|
268
|
+
else {
|
|
269
|
+
this.printLine(` ${this.colorize('magenta', ansiChars.checkmark)} ${this.colorize('bold', this.colorize('brightWhite', `${passed}`))} ${this.colorize('brightWhite', `${this.pluralize('task', passed)} passed`)}`);
|
|
270
|
+
}
|
|
271
|
+
this.printLine();
|
|
272
|
+
}
|
|
273
|
+
onSuiteStart(suite) {
|
|
274
|
+
this.currentSuite = suite;
|
|
275
|
+
if (this.quiet) {
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
this.suiteResults = []; // Reset buffer for new suite
|
|
279
|
+
// Skip displaying the implicit "default" suite header
|
|
280
|
+
if (suite === 'default') {
|
|
281
|
+
return;
|
|
282
|
+
}
|
|
283
|
+
this.printLine();
|
|
284
|
+
const suiteMarker = `${colors.magenta}${ansiChars.block.light}${ansiChars.block.light}${colors.reset}`;
|
|
285
|
+
this.printLine(` ${suiteMarker} ${this.colorize('bold', this.colorize('brightWhite', suite))}`);
|
|
286
|
+
}
|
|
287
|
+
onTaskResult(result) {
|
|
288
|
+
if (this.quiet) {
|
|
289
|
+
return;
|
|
290
|
+
}
|
|
291
|
+
// Buffer the result for later printing with proper alignment
|
|
292
|
+
this.suiteResults.push(result);
|
|
293
|
+
}
|
|
294
|
+
onTaskStart(task) {
|
|
295
|
+
if (this.quiet) {
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
// Only show static markers in verbose mode
|
|
299
|
+
if (this.verbose) {
|
|
300
|
+
this.printLine(` ${this.colorize('gray', ansiChars.smallSquare)} ${task}`);
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
/**
|
|
304
|
+
* Clear current progress display
|
|
305
|
+
*/
|
|
306
|
+
clearProgress() {
|
|
307
|
+
this.clearProgressWindow();
|
|
308
|
+
this.lastProgressLine = '';
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* Clear the progress window at the bottom (Vitest-style)
|
|
312
|
+
*/
|
|
313
|
+
clearProgressWindow() {
|
|
314
|
+
if (!process.stdout.isTTY || !this.progressWindowActive) {
|
|
315
|
+
return;
|
|
316
|
+
}
|
|
317
|
+
// Move up and clear two lines (blank line + progress line)
|
|
318
|
+
// '\x1b[1A' moves cursor up one line, '\x1b[K' clears the current line
|
|
319
|
+
// This sequence moves up and clears two lines in total
|
|
320
|
+
process.stdout.write('\x1b[1A\x1b[K\x1b[1A\x1b[K');
|
|
321
|
+
this.progressWindowActive = false;
|
|
322
|
+
}
|
|
323
|
+
/**
|
|
324
|
+
* Apply color to text if colors are enabled
|
|
325
|
+
*/
|
|
326
|
+
colorize(color, text) {
|
|
327
|
+
if (!this.useColor) {
|
|
328
|
+
return text;
|
|
329
|
+
}
|
|
330
|
+
return `${colors[color]}${text}${colors.reset}`;
|
|
331
|
+
}
|
|
332
|
+
/**
|
|
333
|
+
* Format bytes in human-readable format
|
|
334
|
+
*/
|
|
335
|
+
formatBytes(bytes) {
|
|
336
|
+
const units = ['B', 'KB', 'MB', 'GB', 'TB'];
|
|
337
|
+
let size = bytes;
|
|
338
|
+
let unitIndex = 0;
|
|
339
|
+
while (size >= 1024 && unitIndex < units.length - 1) {
|
|
340
|
+
size /= 1024;
|
|
341
|
+
unitIndex++;
|
|
342
|
+
}
|
|
343
|
+
return `${size.toFixed(1)} ${units[unitIndex]}`;
|
|
344
|
+
}
|
|
345
|
+
/**
|
|
346
|
+
* Format file path - show relative path if within CWD, otherwise absolute
|
|
347
|
+
*/
|
|
348
|
+
formatPath(filePath) {
|
|
349
|
+
const cwd = process.cwd();
|
|
350
|
+
const absolutePath = node_path_1.default.resolve(filePath);
|
|
351
|
+
// Check if the file is within the current working directory
|
|
352
|
+
if (absolutePath.startsWith(cwd + node_path_1.default.sep) || absolutePath === cwd) {
|
|
353
|
+
return node_path_1.default.relative(cwd, absolutePath);
|
|
354
|
+
}
|
|
355
|
+
return absolutePath;
|
|
356
|
+
}
|
|
357
|
+
/**
|
|
358
|
+
* Format duration in human-readable format for progress display
|
|
359
|
+
*/
|
|
360
|
+
formatTimeRemaining(seconds) {
|
|
361
|
+
if (seconds < 60) {
|
|
362
|
+
return `${seconds}s`;
|
|
363
|
+
}
|
|
364
|
+
else if (seconds < 3600) {
|
|
365
|
+
const minutes = Math.floor(seconds / 60);
|
|
366
|
+
const remainingSeconds = seconds % 60;
|
|
367
|
+
return `${minutes}m${remainingSeconds}s`;
|
|
368
|
+
}
|
|
369
|
+
else {
|
|
370
|
+
const hours = Math.floor(seconds / 3600);
|
|
371
|
+
const minutes = Math.floor((seconds % 3600) / 60);
|
|
372
|
+
return `${hours}h${minutes}m`;
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Get visible length of string (excluding ANSI escape codes)
|
|
377
|
+
*/
|
|
378
|
+
getVisibleLength(str) {
|
|
379
|
+
// Remove ANSI escape codes to get actual visible length
|
|
380
|
+
// eslint-disable-next-line no-control-regex
|
|
381
|
+
return str.replace(/\x1b\[[0-9;]*m/g, '').length;
|
|
382
|
+
}
|
|
383
|
+
/**
|
|
384
|
+
* Simple pluralization helper
|
|
385
|
+
*/
|
|
386
|
+
pluralize(str, count) {
|
|
387
|
+
return count === 1 ? str : `${str}s`;
|
|
388
|
+
}
|
|
389
|
+
/**
|
|
390
|
+
* Print all task results in a suite with aligned columns
|
|
391
|
+
*/
|
|
392
|
+
printAlignedSuiteResults() {
|
|
393
|
+
if (this.suiteResults.length === 0) {
|
|
394
|
+
return;
|
|
395
|
+
}
|
|
396
|
+
const MAX_NAME_WIDTH = 60;
|
|
397
|
+
const BASE_INDENT = ' '; // 4 spaces
|
|
398
|
+
const bullet = this.colorize('dim', this.colorize('gray', ansiChars.bullet));
|
|
399
|
+
const formatted = this.suiteResults.map((result) => {
|
|
400
|
+
const status = result.error
|
|
401
|
+
? this.colorize('red', ansiChars.cross)
|
|
402
|
+
: this.colorize('brightCyan', ansiChars.checkmark);
|
|
403
|
+
const name = result.name.trim();
|
|
404
|
+
const nameLength = this.getVisibleLength(name);
|
|
405
|
+
if (result.error) {
|
|
406
|
+
return {
|
|
407
|
+
durationLen: 0,
|
|
408
|
+
durationStr: '',
|
|
409
|
+
error: true,
|
|
410
|
+
errorMessage: result.error?.message || String(result.error),
|
|
411
|
+
iterations: 0,
|
|
412
|
+
name,
|
|
413
|
+
nameLength,
|
|
414
|
+
opsPerSecLen: 0,
|
|
415
|
+
opsPerSecStr: '',
|
|
416
|
+
rmeLen: 0,
|
|
417
|
+
rmeStr: '',
|
|
418
|
+
status,
|
|
419
|
+
};
|
|
420
|
+
}
|
|
421
|
+
const duration = this.formatDuration(result.mean); // already in nanoseconds
|
|
422
|
+
const opsPerSec = this.formatOpsPerSecond(result.opsPerSecond);
|
|
423
|
+
const rme = this.formatPercentage(result.marginOfError * 100);
|
|
424
|
+
return {
|
|
425
|
+
durationLen: this.getVisibleLength(duration),
|
|
426
|
+
durationStr: duration,
|
|
427
|
+
error: false,
|
|
428
|
+
iterations: result.iterations,
|
|
429
|
+
name,
|
|
430
|
+
nameLength,
|
|
431
|
+
opsPerSecLen: this.getVisibleLength(opsPerSec),
|
|
432
|
+
opsPerSecStr: opsPerSec,
|
|
433
|
+
rmeLen: this.getVisibleLength(rme),
|
|
434
|
+
rmeStr: rme,
|
|
435
|
+
status,
|
|
436
|
+
};
|
|
437
|
+
});
|
|
438
|
+
// Find max widths
|
|
439
|
+
const nonWrappingTasks = formatted.filter((t) => t.nameLength <= MAX_NAME_WIDTH);
|
|
440
|
+
const maxNameLen = nonWrappingTasks.length > 0
|
|
441
|
+
? Math.max(...nonWrappingTasks.map((t) => t.nameLength))
|
|
442
|
+
: 40; // Default if all tasks wrap
|
|
443
|
+
const maxDurationLen = Math.max(...formatted.filter((t) => !t.error).map((t) => t.durationLen), 0);
|
|
444
|
+
const maxRmeLen = Math.max(...formatted.filter((t) => !t.error).map((t) => t.rmeLen), 0);
|
|
445
|
+
const maxOpsLen = Math.max(...formatted.filter((t) => !t.error).map((t) => t.opsPerSecLen), 0);
|
|
446
|
+
// Calculate the position where numbers start for unwrapped lines
|
|
447
|
+
// BASE_INDENT (4) + status (1 char) + space (1) + maxNameLen + ": " (2) = 8 + maxNameLen
|
|
448
|
+
const numbersStartPos = BASE_INDENT.length + 2 + maxNameLen + 2;
|
|
449
|
+
// Print each task with aligned columns
|
|
450
|
+
for (const task of formatted) {
|
|
451
|
+
if (task.error) {
|
|
452
|
+
// Track failure for end summary
|
|
453
|
+
this.failures.push({
|
|
454
|
+
error: task.errorMessage || 'Unknown error',
|
|
455
|
+
file: this.currentFile,
|
|
456
|
+
suite: this.currentSuite,
|
|
457
|
+
task: task.name,
|
|
458
|
+
});
|
|
459
|
+
this.printLine(`${BASE_INDENT}${task.status} ${this.colorize('white', task.name)} ${this.colorize('red', 'FAILED')}`);
|
|
460
|
+
}
|
|
461
|
+
else if (task.nameLength > MAX_NAME_WIDTH) {
|
|
462
|
+
// Long name - wrap to next line, but align numbers with unwrapped lines
|
|
463
|
+
this.printLine(`${BASE_INDENT}${task.status} ${this.colorize('white', task.name)}:`);
|
|
464
|
+
// Calculate padding to align with unwrapped lines
|
|
465
|
+
// We need to get to numbersStartPos from the beginning of the line
|
|
466
|
+
const leadingPad = ' '.repeat(numbersStartPos);
|
|
467
|
+
const durationPad = ' '.repeat(maxDurationLen - task.durationLen);
|
|
468
|
+
const rmePad = ' '.repeat(maxRmeLen - task.rmeLen);
|
|
469
|
+
const opsPad = ' '.repeat(maxOpsLen - task.opsPerSecLen);
|
|
470
|
+
this.printLine(`${leadingPad}${durationPad}${this.colorize('cyan', task.durationStr)} ${bullet} ${ansiChars.plusMinus}${rmePad}${this.colorize('brightBlue', task.rmeStr)} ${bullet} ${opsPad}${this.colorize('magenta', task.opsPerSecStr)}`);
|
|
471
|
+
if (this.verbose && task.iterations > 0) {
|
|
472
|
+
this.printLine(` ${this.colorize('dim', `${task.iterations} iterations`)}`);
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
else {
|
|
476
|
+
// Normal length - align on same line
|
|
477
|
+
const namePad = ' '.repeat(maxNameLen - task.nameLength);
|
|
478
|
+
const durationPad = ' '.repeat(maxDurationLen - task.durationLen);
|
|
479
|
+
const rmePad = ' '.repeat(maxRmeLen - task.rmeLen);
|
|
480
|
+
const opsPad = ' '.repeat(maxOpsLen - task.opsPerSecLen);
|
|
481
|
+
this.printLine(`${BASE_INDENT}${task.status} ${this.colorize('white', task.name)}${namePad}: ${durationPad}${this.colorize('cyan', task.durationStr)} ${bullet} ${ansiChars.plusMinus}${rmePad}${this.colorize('brightBlue', task.rmeStr)} ${bullet} ${opsPad}${this.colorize('magenta', task.opsPerSecStr)}`);
|
|
482
|
+
if (this.verbose && task.iterations > 0) {
|
|
483
|
+
this.printLine(` ${this.colorize('dim', `${task.iterations} iterations`)}`);
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
/**
|
|
489
|
+
* Print a line while maintaining the progress window at the bottom
|
|
490
|
+
* (Vitest-style)
|
|
491
|
+
*/
|
|
492
|
+
printLine(message = '') {
|
|
493
|
+
// Clear progress window, print content, re-render progress window
|
|
494
|
+
this.clearProgressWindow();
|
|
495
|
+
console.log(message);
|
|
496
|
+
this.renderProgressWindow();
|
|
497
|
+
}
|
|
498
|
+
/**
|
|
499
|
+
* Render the progress window at the bottom
|
|
500
|
+
*/
|
|
501
|
+
renderProgressWindow() {
|
|
502
|
+
if (!process.stdout.isTTY || !this.lastProgressLine) {
|
|
503
|
+
return;
|
|
504
|
+
}
|
|
505
|
+
// Clear existing window if present
|
|
506
|
+
if (this.progressWindowActive) {
|
|
507
|
+
this.clearProgressWindow();
|
|
508
|
+
}
|
|
509
|
+
// Write blank line for spacing, then progress line
|
|
510
|
+
console.log('');
|
|
511
|
+
console.log(this.lastProgressLine);
|
|
512
|
+
this.progressWindowActive = true;
|
|
513
|
+
}
|
|
514
|
+
}
|
|
515
|
+
exports.HumanReporter = HumanReporter;
|
|
516
|
+
//# sourceMappingURL=human.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"human.js","sourceRoot":"","sources":["../../src/reporters/human.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ModestBench Human-Readable Console Reporter
|
|
3
|
+
*
|
|
4
|
+
* Provides colorized, progressive output for terminal environments. Displays
|
|
5
|
+
* real-time progress, results, and formatted statistics.
|
|
6
|
+
*/
|
|
7
|
+
import type { BenchmarkRun, FileResult, ProgressState, SuiteResult, TaskResult } from "../types/index.cjs";
|
|
8
|
+
import { BaseReporter } from "./registry.cjs";
|
|
9
|
+
/**
|
|
10
|
+
* Human-readable console reporter with colorized output
|
|
11
|
+
*/
|
|
12
|
+
export declare class HumanReporter extends BaseReporter {
|
|
13
|
+
private currentFile;
|
|
14
|
+
private currentSuite;
|
|
15
|
+
private failures;
|
|
16
|
+
private lastProgressLine;
|
|
17
|
+
private progressWindowActive;
|
|
18
|
+
private readonly quiet;
|
|
19
|
+
private readonly showProgress;
|
|
20
|
+
private startTime;
|
|
21
|
+
private suiteResults;
|
|
22
|
+
private readonly useColor;
|
|
23
|
+
private readonly verbose;
|
|
24
|
+
constructor(options?: {
|
|
25
|
+
color?: boolean;
|
|
26
|
+
progress?: boolean;
|
|
27
|
+
quiet?: boolean;
|
|
28
|
+
verbose?: boolean;
|
|
29
|
+
});
|
|
30
|
+
onEnd(run: BenchmarkRun): void;
|
|
31
|
+
onError(error: Error): void;
|
|
32
|
+
onFileEnd(result: FileResult): void;
|
|
33
|
+
onFileStart(file: string): void;
|
|
34
|
+
onProgress(state: ProgressState): void;
|
|
35
|
+
onStart(run: BenchmarkRun): void;
|
|
36
|
+
onSuiteEnd(result: SuiteResult): void;
|
|
37
|
+
onSuiteStart(suite: string): void;
|
|
38
|
+
onTaskResult(result: TaskResult): void;
|
|
39
|
+
onTaskStart(task: string): void;
|
|
40
|
+
/**
|
|
41
|
+
* Clear current progress display
|
|
42
|
+
*/
|
|
43
|
+
private clearProgress;
|
|
44
|
+
/**
|
|
45
|
+
* Clear the progress window at the bottom (Vitest-style)
|
|
46
|
+
*/
|
|
47
|
+
private clearProgressWindow;
|
|
48
|
+
/**
|
|
49
|
+
* Apply color to text if colors are enabled
|
|
50
|
+
*/
|
|
51
|
+
private colorize;
|
|
52
|
+
/**
|
|
53
|
+
* Format bytes in human-readable format
|
|
54
|
+
*/
|
|
55
|
+
private formatBytes;
|
|
56
|
+
/**
|
|
57
|
+
* Format file path - show relative path if within CWD, otherwise absolute
|
|
58
|
+
*/
|
|
59
|
+
private formatPath;
|
|
60
|
+
/**
|
|
61
|
+
* Format duration in human-readable format for progress display
|
|
62
|
+
*/
|
|
63
|
+
private formatTimeRemaining;
|
|
64
|
+
/**
|
|
65
|
+
* Get visible length of string (excluding ANSI escape codes)
|
|
66
|
+
*/
|
|
67
|
+
private getVisibleLength;
|
|
68
|
+
/**
|
|
69
|
+
* Simple pluralization helper
|
|
70
|
+
*/
|
|
71
|
+
private pluralize;
|
|
72
|
+
/**
|
|
73
|
+
* Print all task results in a suite with aligned columns
|
|
74
|
+
*/
|
|
75
|
+
private printAlignedSuiteResults;
|
|
76
|
+
/**
|
|
77
|
+
* Print a line while maintaining the progress window at the bottom
|
|
78
|
+
* (Vitest-style)
|
|
79
|
+
*/
|
|
80
|
+
private printLine;
|
|
81
|
+
/**
|
|
82
|
+
* Render the progress window at the bottom
|
|
83
|
+
*/
|
|
84
|
+
private renderProgressWindow;
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=human.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"human.d.ts","sourceRoot":"","sources":["../../src/reporters/human.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EACV,YAAY,EACZ,UAAU,EACV,aAAa,EACb,WAAW,EACX,UAAU,EACX,2BAA0B;AAE3B,OAAO,EAAE,YAAY,EAAE,uBAAsB;AA2C7C;;GAEG;AACH,qBAAa,aAAc,SAAQ,YAAY;IAC7C,OAAO,CAAC,WAAW,CAAM;IAEzB,OAAO,CAAC,YAAY,CAAM;IAE1B,OAAO,CAAC,QAAQ,CAKR;IAER,OAAO,CAAC,gBAAgB,CAAM;IAE9B,OAAO,CAAC,oBAAoB,CAAS;IAErC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAU;IAEhC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAU;IAEvC,OAAO,CAAC,SAAS,CAAK;IAEtB,OAAO,CAAC,YAAY,CAAoB;IAExC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAU;IAEnC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAU;gBAGhC,OAAO,GAAE;QACP,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,OAAO,CAAC,EAAE,OAAO,CAAC;KACd;IAgBR,KAAK,CAAC,GAAG,EAAE,YAAY,GAAG,IAAI;IA8E9B,OAAO,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAgB3B,SAAS,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IA+BnC,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAc/B,UAAU,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IA+CtC,OAAO,CAAC,GAAG,EAAE,YAAY,GAAG,IAAI;IAsDhC,UAAU,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IA4BrC,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAqBjC,YAAY,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IAStC,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAa/B;;OAEG;IACH,OAAO,CAAC,aAAa;IAKrB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAW3B;;OAEG;IACH,OAAO,CAAC,QAAQ;IAOhB;;OAEG;IACH,OAAO,CAAC,WAAW;IAanB;;OAEG;IACH,OAAO,CAAC,UAAU;IAYlB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAc3B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAMxB;;OAEG;IACH,OAAO,CAAC,SAAS;IAIjB;;OAEG;IACH,OAAO,CAAC,wBAAwB;IA0JhC;;;OAGG;IACH,OAAO,CAAC,SAAS;IAOjB;;OAEG;IACH,OAAO,CAAC,oBAAoB;CAe7B"}
|