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.
Files changed (275) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/LICENSE.md +55 -0
  3. package/README.md +699 -0
  4. package/dist/bootstrap.cjs +37 -0
  5. package/dist/bootstrap.cjs.map +1 -0
  6. package/dist/bootstrap.d.cts +17 -0
  7. package/dist/bootstrap.d.cts.map +1 -0
  8. package/dist/bootstrap.d.ts +17 -0
  9. package/dist/bootstrap.d.ts.map +1 -0
  10. package/dist/bootstrap.js +33 -0
  11. package/dist/bootstrap.js.map +1 -0
  12. package/dist/cli/commands/history.cjs +459 -0
  13. package/dist/cli/commands/history.cjs.map +1 -0
  14. package/dist/cli/commands/history.d.cts +34 -0
  15. package/dist/cli/commands/history.d.cts.map +1 -0
  16. package/dist/cli/commands/history.d.ts +34 -0
  17. package/dist/cli/commands/history.d.ts.map +1 -0
  18. package/dist/cli/commands/history.js +422 -0
  19. package/dist/cli/commands/history.js.map +1 -0
  20. package/dist/cli/commands/init.cjs +566 -0
  21. package/dist/cli/commands/init.cjs.map +1 -0
  22. package/dist/cli/commands/init.d.cts +26 -0
  23. package/dist/cli/commands/init.d.cts.map +1 -0
  24. package/dist/cli/commands/init.d.ts +26 -0
  25. package/dist/cli/commands/init.d.ts.map +1 -0
  26. package/dist/cli/commands/init.js +562 -0
  27. package/dist/cli/commands/init.js.map +1 -0
  28. package/dist/cli/commands/run.cjs +285 -0
  29. package/dist/cli/commands/run.cjs.map +1 -0
  30. package/dist/cli/commands/run.d.cts +37 -0
  31. package/dist/cli/commands/run.d.cts.map +1 -0
  32. package/dist/cli/commands/run.d.ts +37 -0
  33. package/dist/cli/commands/run.d.ts.map +1 -0
  34. package/dist/cli/commands/run.js +248 -0
  35. package/dist/cli/commands/run.js.map +1 -0
  36. package/dist/cli/index.cjs +523 -0
  37. package/dist/cli/index.cjs.map +1 -0
  38. package/dist/cli/index.d.cts +58 -0
  39. package/dist/cli/index.d.cts.map +1 -0
  40. package/dist/cli/index.d.ts +58 -0
  41. package/dist/cli/index.d.ts.map +1 -0
  42. package/dist/cli/index.js +515 -0
  43. package/dist/cli/index.js.map +1 -0
  44. package/dist/config/manager.cjs +370 -0
  45. package/dist/config/manager.cjs.map +1 -0
  46. package/dist/config/manager.d.cts +46 -0
  47. package/dist/config/manager.d.cts.map +1 -0
  48. package/dist/config/manager.d.ts +46 -0
  49. package/dist/config/manager.d.ts.map +1 -0
  50. package/dist/config/manager.js +333 -0
  51. package/dist/config/manager.js.map +1 -0
  52. package/dist/config/schema.cjs +182 -0
  53. package/dist/config/schema.cjs.map +1 -0
  54. package/dist/config/schema.d.cts +51 -0
  55. package/dist/config/schema.d.cts.map +1 -0
  56. package/dist/config/schema.d.ts +51 -0
  57. package/dist/config/schema.d.ts.map +1 -0
  58. package/dist/config/schema.js +145 -0
  59. package/dist/config/schema.js.map +1 -0
  60. package/dist/constants.cjs +22 -0
  61. package/dist/constants.cjs.map +1 -0
  62. package/dist/constants.d.cts +10 -0
  63. package/dist/constants.d.cts.map +1 -0
  64. package/dist/constants.d.ts +10 -0
  65. package/dist/constants.d.ts.map +1 -0
  66. package/dist/constants.js +19 -0
  67. package/dist/constants.js.map +1 -0
  68. package/dist/core/benchmark-schema.cjs +135 -0
  69. package/dist/core/benchmark-schema.cjs.map +1 -0
  70. package/dist/core/benchmark-schema.d.cts +139 -0
  71. package/dist/core/benchmark-schema.d.cts.map +1 -0
  72. package/dist/core/benchmark-schema.d.ts +139 -0
  73. package/dist/core/benchmark-schema.d.ts.map +1 -0
  74. package/dist/core/benchmark-schema.js +132 -0
  75. package/dist/core/benchmark-schema.js.map +1 -0
  76. package/dist/core/engine.cjs +669 -0
  77. package/dist/core/engine.cjs.map +1 -0
  78. package/dist/core/engine.d.cts +128 -0
  79. package/dist/core/engine.d.cts.map +1 -0
  80. package/dist/core/engine.d.ts +128 -0
  81. package/dist/core/engine.d.ts.map +1 -0
  82. package/dist/core/engine.js +632 -0
  83. package/dist/core/engine.js.map +1 -0
  84. package/dist/core/engines/accurate-engine.cjs +292 -0
  85. package/dist/core/engines/accurate-engine.cjs.map +1 -0
  86. package/dist/core/engines/accurate-engine.d.cts +63 -0
  87. package/dist/core/engines/accurate-engine.d.cts.map +1 -0
  88. package/dist/core/engines/accurate-engine.d.ts +63 -0
  89. package/dist/core/engines/accurate-engine.d.ts.map +1 -0
  90. package/dist/core/engines/accurate-engine.js +288 -0
  91. package/dist/core/engines/accurate-engine.js.map +1 -0
  92. package/dist/core/engines/index.cjs +21 -0
  93. package/dist/core/engines/index.cjs.map +1 -0
  94. package/dist/core/engines/index.d.cts +16 -0
  95. package/dist/core/engines/index.d.cts.map +1 -0
  96. package/dist/core/engines/index.d.ts +16 -0
  97. package/dist/core/engines/index.d.ts.map +1 -0
  98. package/dist/core/engines/index.js +16 -0
  99. package/dist/core/engines/index.js.map +1 -0
  100. package/dist/core/engines/tinybench-engine.cjs +286 -0
  101. package/dist/core/engines/tinybench-engine.cjs.map +1 -0
  102. package/dist/core/engines/tinybench-engine.d.cts +18 -0
  103. package/dist/core/engines/tinybench-engine.d.cts.map +1 -0
  104. package/dist/core/engines/tinybench-engine.d.ts +18 -0
  105. package/dist/core/engines/tinybench-engine.d.ts.map +1 -0
  106. package/dist/core/engines/tinybench-engine.js +282 -0
  107. package/dist/core/engines/tinybench-engine.js.map +1 -0
  108. package/dist/core/error-manager.cjs +303 -0
  109. package/dist/core/error-manager.cjs.map +1 -0
  110. package/dist/core/error-manager.d.cts +77 -0
  111. package/dist/core/error-manager.d.cts.map +1 -0
  112. package/dist/core/error-manager.d.ts +77 -0
  113. package/dist/core/error-manager.d.ts.map +1 -0
  114. package/dist/core/error-manager.js +299 -0
  115. package/dist/core/error-manager.js.map +1 -0
  116. package/dist/core/loader.cjs +287 -0
  117. package/dist/core/loader.cjs.map +1 -0
  118. package/dist/core/loader.d.cts +55 -0
  119. package/dist/core/loader.d.cts.map +1 -0
  120. package/dist/core/loader.d.ts +55 -0
  121. package/dist/core/loader.d.ts.map +1 -0
  122. package/dist/core/loader.js +250 -0
  123. package/dist/core/loader.js.map +1 -0
  124. package/dist/core/stats-utils.cjs +99 -0
  125. package/dist/core/stats-utils.cjs.map +1 -0
  126. package/dist/core/stats-utils.d.cts +50 -0
  127. package/dist/core/stats-utils.d.cts.map +1 -0
  128. package/dist/core/stats-utils.d.ts +50 -0
  129. package/dist/core/stats-utils.d.ts.map +1 -0
  130. package/dist/core/stats-utils.js +94 -0
  131. package/dist/core/stats-utils.js.map +1 -0
  132. package/dist/index.cjs +64 -0
  133. package/dist/index.cjs.map +1 -0
  134. package/dist/index.d.cts +22 -0
  135. package/dist/index.d.cts.map +1 -0
  136. package/dist/index.d.ts +22 -0
  137. package/dist/index.d.ts.map +1 -0
  138. package/dist/index.js +30 -0
  139. package/dist/index.js.map +1 -0
  140. package/dist/progress/manager.cjs +325 -0
  141. package/dist/progress/manager.cjs.map +1 -0
  142. package/dist/progress/manager.d.cts +125 -0
  143. package/dist/progress/manager.d.cts.map +1 -0
  144. package/dist/progress/manager.d.ts +125 -0
  145. package/dist/progress/manager.d.ts.map +1 -0
  146. package/dist/progress/manager.js +321 -0
  147. package/dist/progress/manager.js.map +1 -0
  148. package/dist/reporters/csv.cjs +250 -0
  149. package/dist/reporters/csv.cjs.map +1 -0
  150. package/dist/reporters/csv.d.cts +92 -0
  151. package/dist/reporters/csv.d.cts.map +1 -0
  152. package/dist/reporters/csv.d.ts +92 -0
  153. package/dist/reporters/csv.d.ts.map +1 -0
  154. package/dist/reporters/csv.js +246 -0
  155. package/dist/reporters/csv.js.map +1 -0
  156. package/dist/reporters/human.cjs +516 -0
  157. package/dist/reporters/human.cjs.map +1 -0
  158. package/dist/reporters/human.d.cts +86 -0
  159. package/dist/reporters/human.d.cts.map +1 -0
  160. package/dist/reporters/human.d.ts +86 -0
  161. package/dist/reporters/human.d.ts.map +1 -0
  162. package/dist/reporters/human.js +509 -0
  163. package/dist/reporters/human.js.map +1 -0
  164. package/dist/reporters/index.cjs +17 -0
  165. package/dist/reporters/index.cjs.map +1 -0
  166. package/dist/reporters/index.d.cts +10 -0
  167. package/dist/reporters/index.d.cts.map +1 -0
  168. package/dist/reporters/index.d.ts +10 -0
  169. package/dist/reporters/index.d.ts.map +1 -0
  170. package/dist/reporters/index.js +10 -0
  171. package/dist/reporters/index.js.map +1 -0
  172. package/dist/reporters/json.cjs +215 -0
  173. package/dist/reporters/json.cjs.map +1 -0
  174. package/dist/reporters/json.d.cts +79 -0
  175. package/dist/reporters/json.d.cts.map +1 -0
  176. package/dist/reporters/json.d.ts +79 -0
  177. package/dist/reporters/json.d.ts.map +1 -0
  178. package/dist/reporters/json.js +211 -0
  179. package/dist/reporters/json.js.map +1 -0
  180. package/dist/reporters/registry.cjs +255 -0
  181. package/dist/reporters/registry.cjs.map +1 -0
  182. package/dist/reporters/registry.d.cts +155 -0
  183. package/dist/reporters/registry.d.cts.map +1 -0
  184. package/dist/reporters/registry.d.ts +155 -0
  185. package/dist/reporters/registry.d.ts.map +1 -0
  186. package/dist/reporters/registry.js +249 -0
  187. package/dist/reporters/registry.js.map +1 -0
  188. package/dist/reporters/simple.cjs +328 -0
  189. package/dist/reporters/simple.cjs.map +1 -0
  190. package/dist/reporters/simple.d.cts +51 -0
  191. package/dist/reporters/simple.d.cts.map +1 -0
  192. package/dist/reporters/simple.d.ts +51 -0
  193. package/dist/reporters/simple.d.ts.map +1 -0
  194. package/dist/reporters/simple.js +321 -0
  195. package/dist/reporters/simple.js.map +1 -0
  196. package/dist/schema/modestbench-config.schema.json +162 -0
  197. package/dist/storage/history.cjs +456 -0
  198. package/dist/storage/history.cjs.map +1 -0
  199. package/dist/storage/history.d.cts +99 -0
  200. package/dist/storage/history.d.cts.map +1 -0
  201. package/dist/storage/history.d.ts +99 -0
  202. package/dist/storage/history.d.ts.map +1 -0
  203. package/dist/storage/history.js +452 -0
  204. package/dist/storage/history.js.map +1 -0
  205. package/dist/types/cli.cjs +21 -0
  206. package/dist/types/cli.cjs.map +1 -0
  207. package/dist/types/cli.d.cts +296 -0
  208. package/dist/types/cli.d.cts.map +1 -0
  209. package/dist/types/cli.d.ts +296 -0
  210. package/dist/types/cli.d.ts.map +1 -0
  211. package/dist/types/cli.js +18 -0
  212. package/dist/types/cli.js.map +1 -0
  213. package/dist/types/core.cjs +14 -0
  214. package/dist/types/core.cjs.map +1 -0
  215. package/dist/types/core.d.cts +380 -0
  216. package/dist/types/core.d.cts.map +1 -0
  217. package/dist/types/core.d.ts +380 -0
  218. package/dist/types/core.d.ts.map +1 -0
  219. package/dist/types/core.js +13 -0
  220. package/dist/types/core.js.map +1 -0
  221. package/dist/types/index.cjs +27 -0
  222. package/dist/types/index.cjs.map +1 -0
  223. package/dist/types/index.d.cts +11 -0
  224. package/dist/types/index.d.cts.map +1 -0
  225. package/dist/types/index.d.ts +11 -0
  226. package/dist/types/index.d.ts.map +1 -0
  227. package/dist/types/index.js +11 -0
  228. package/dist/types/index.js.map +1 -0
  229. package/dist/types/interfaces.cjs +10 -0
  230. package/dist/types/interfaces.cjs.map +1 -0
  231. package/dist/types/interfaces.d.cts +381 -0
  232. package/dist/types/interfaces.d.cts.map +1 -0
  233. package/dist/types/interfaces.d.ts +381 -0
  234. package/dist/types/interfaces.d.ts.map +1 -0
  235. package/dist/types/interfaces.js +9 -0
  236. package/dist/types/interfaces.js.map +1 -0
  237. package/dist/types/utility.cjs +92 -0
  238. package/dist/types/utility.cjs.map +1 -0
  239. package/dist/types/utility.d.cts +330 -0
  240. package/dist/types/utility.d.cts.map +1 -0
  241. package/dist/types/utility.d.ts +330 -0
  242. package/dist/types/utility.d.ts.map +1 -0
  243. package/dist/types/utility.js +78 -0
  244. package/dist/types/utility.js.map +1 -0
  245. package/package.json +211 -0
  246. package/src/bootstrap.ts +35 -0
  247. package/src/cli/commands/history.ts +569 -0
  248. package/src/cli/commands/init.ts +658 -0
  249. package/src/cli/commands/run.ts +346 -0
  250. package/src/cli/index.ts +642 -0
  251. package/src/config/manager.ts +387 -0
  252. package/src/config/schema.ts +188 -0
  253. package/src/constants.ts +21 -0
  254. package/src/core/benchmark-schema.ts +185 -0
  255. package/src/core/engine.ts +888 -0
  256. package/src/core/engines/accurate-engine.ts +408 -0
  257. package/src/core/engines/index.ts +16 -0
  258. package/src/core/engines/tinybench-engine.ts +335 -0
  259. package/src/core/error-manager.ts +372 -0
  260. package/src/core/loader.ts +324 -0
  261. package/src/core/stats-utils.ts +135 -0
  262. package/src/index.ts +46 -0
  263. package/src/progress/manager.ts +415 -0
  264. package/src/reporters/csv.ts +368 -0
  265. package/src/reporters/human.ts +707 -0
  266. package/src/reporters/index.ts +10 -0
  267. package/src/reporters/json.ts +302 -0
  268. package/src/reporters/registry.ts +349 -0
  269. package/src/reporters/simple.ts +459 -0
  270. package/src/storage/history.ts +600 -0
  271. package/src/types/cli.ts +312 -0
  272. package/src/types/core.ts +414 -0
  273. package/src/types/index.ts +18 -0
  274. package/src/types/interfaces.ts +451 -0
  275. package/src/types/utility.ts +446 -0
@@ -0,0 +1,515 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * ModestBench CLI Entry Point
4
+ *
5
+ * Command-line interface using yargs for command parsing and routing. Provides
6
+ * global options, help generation, and dependency injection setup.
7
+ */
8
+ import { realpathSync } from 'node:fs';
9
+ import { fileURLToPath } from 'node:url';
10
+ import yargs from 'yargs';
11
+ import { hideBin } from 'yargs/helpers';
12
+ import { bootstrap } from "../bootstrap.js";
13
+ import { AccurateEngine, TinybenchEngine } from "../core/engines/index.js";
14
+ import { CsvReporter, HumanReporter, JsonReporter, SimpleReporter, } from "../reporters/index.js";
15
+ // Import commands
16
+ import { handleHistoryCommand as historyCommand } from "./commands/history.js";
17
+ import { handleInitCommand as initCommand } from "./commands/init.js";
18
+ import { handleRunCommand as runCommand } from "./commands/run.js";
19
+ /**
20
+ * Exit codes for the CLI
21
+ */
22
+ export const ExitCodes = {
23
+ BENCHMARK_FAILURES: 1,
24
+ CONFIG_ERROR: 2,
25
+ DISCOVERY_ERROR: 3,
26
+ RUNTIME_ERROR: 5,
27
+ SUCCESS: 0,
28
+ UNKNOWN_ERROR: 99,
29
+ VALIDATION_ERROR: 4,
30
+ };
31
+ /**
32
+ * Initialize and run the CLI
33
+ */
34
+ export const cli = (argv) => {
35
+ const abortController = new AbortController();
36
+ setupSignalHandlers(abortController);
37
+ main(argv, abortController).catch((error) => {
38
+ console.error('CLI error:', error);
39
+ process.exit(ExitCodes.UNKNOWN_ERROR);
40
+ });
41
+ };
42
+ /**
43
+ * Main CLI entry point
44
+ */
45
+ export const main = async (argv, abortController) => {
46
+ try {
47
+ const args = argv || hideBin(process.argv);
48
+ const cli = yargs(args);
49
+ // Configure global options and commands
50
+ await cli
51
+ .option('config', {
52
+ alias: 'c',
53
+ description: 'Path to configuration file',
54
+ global: true,
55
+ type: 'string',
56
+ })
57
+ .option('verbose', {
58
+ alias: 'v',
59
+ default: false,
60
+ description: 'Enable verbose output',
61
+ global: true,
62
+ type: 'boolean',
63
+ })
64
+ .option('no-color', {
65
+ default: false,
66
+ description: 'Disable colored output',
67
+ global: true,
68
+ type: 'boolean',
69
+ })
70
+ .option('progress', {
71
+ default: true,
72
+ description: 'Show animated progress bar',
73
+ global: true,
74
+ type: 'boolean',
75
+ })
76
+ .option('json', {
77
+ default: false,
78
+ description: 'Output results in JSON format',
79
+ global: true,
80
+ type: 'boolean',
81
+ })
82
+ .option('cwd', {
83
+ default: process.cwd(),
84
+ description: 'Working directory',
85
+ global: true,
86
+ type: 'string',
87
+ })
88
+ .help()
89
+ .alias('help', 'h')
90
+ .version()
91
+ .alias('version', 'V')
92
+ .strict()
93
+ .demandCommand(1, 'You must specify a command')
94
+ .recommendCommands()
95
+ .completion()
96
+ .wrap(Math.min(120, cli.terminalWidth()))
97
+ .command('run [pattern..]', 'Run benchmark files', (yargs) => {
98
+ return yargs
99
+ .positional('pattern', {
100
+ array: true,
101
+ default: [],
102
+ describe: 'File paths, directory paths, or glob patterns for benchmark files',
103
+ type: 'string',
104
+ })
105
+ .option('config', {
106
+ alias: 'c',
107
+ description: 'Path to configuration file',
108
+ type: 'string',
109
+ })
110
+ .option('reporters', {
111
+ alias: 'r',
112
+ coerce: (value) => {
113
+ // Handle comma-separated values
114
+ if (Array.isArray(value)) {
115
+ return value.flatMap((v) => v.split(',').map((s) => s.trim()));
116
+ }
117
+ return value.split(',').map((s) => s.trim());
118
+ },
119
+ default: ['human'],
120
+ description: 'Output reporters to use (human,json,csv)',
121
+ type: 'array',
122
+ })
123
+ .option('output', {
124
+ alias: 'o',
125
+ description: 'Output directory for reports',
126
+ type: 'string',
127
+ })
128
+ .option('iterations', {
129
+ alias: 'i',
130
+ description: 'Number of iterations per benchmark',
131
+ type: 'number',
132
+ })
133
+ .option('time', {
134
+ alias: 't',
135
+ description: 'Time budget per benchmark in milliseconds',
136
+ type: 'number',
137
+ })
138
+ .option('warmup', {
139
+ alias: 'w',
140
+ description: 'Number of warmup iterations',
141
+ type: 'number',
142
+ })
143
+ .option('limit-by', {
144
+ choices: ['time', 'iterations', 'any', 'all'],
145
+ description: 'How to limit benchmarks: time (time budget), iterations (sample count), any (either threshold), all (both thresholds)',
146
+ type: 'string',
147
+ })
148
+ .option('bail', {
149
+ alias: 'b',
150
+ default: false,
151
+ description: 'Stop on first failure',
152
+ type: 'boolean',
153
+ })
154
+ .option('exclude', {
155
+ coerce: (value) => {
156
+ // Handle comma-separated values
157
+ if (Array.isArray(value)) {
158
+ return value.flatMap((v) => v.split(',').map((s) => s.trim()));
159
+ }
160
+ return value.split(',').map((s) => s.trim());
161
+ },
162
+ description: 'Exclude patterns (comma-separated)',
163
+ type: 'array',
164
+ })
165
+ .option('timeout', {
166
+ description: 'Timeout per benchmark in milliseconds',
167
+ type: 'number',
168
+ })
169
+ .option('quiet', {
170
+ alias: 'q',
171
+ default: false,
172
+ description: 'Minimal output',
173
+ type: 'boolean',
174
+ })
175
+ .option('tags', {
176
+ coerce: (value) => {
177
+ // Handle comma-separated values
178
+ if (Array.isArray(value)) {
179
+ return value.flatMap((v) => v.split(',').map((s) => s.trim()));
180
+ }
181
+ return value.split(',').map((s) => s.trim());
182
+ },
183
+ description: 'Include only benchmarks with any of these tags',
184
+ type: 'array',
185
+ })
186
+ .option('exclude-tags', {
187
+ coerce: (value) => {
188
+ // Handle comma-separated values
189
+ if (Array.isArray(value)) {
190
+ return value.flatMap((v) => v.split(',').map((s) => s.trim()));
191
+ }
192
+ return value.split(',').map((s) => s.trim());
193
+ },
194
+ description: 'Exclude benchmarks with any of these tags',
195
+ type: 'array',
196
+ })
197
+ .option('engine', {
198
+ alias: 'e',
199
+ choices: ['tinybench', 'accurate'],
200
+ default: 'tinybench',
201
+ description: 'Benchmark engine: tinybench (default) or accurate (requires --allow-natives-syntax)',
202
+ type: 'string',
203
+ })
204
+ .example([
205
+ ['$0 run', 'Run benchmarks in current directory and bench/'],
206
+ ['$0 run benchmarks/', 'Run all benchmarks in a directory'],
207
+ ['$0 run src/perf/', 'Run benchmarks in specific directory'],
208
+ ['$0 run "src/**/*.bench.js"', 'Run specific glob pattern'],
209
+ ['$0 run file1.bench.js file2.bench.js', 'Run specific files'],
210
+ ['$0 run benchmarks/ tests/perf/', 'Run multiple directories'],
211
+ ['$0 run --reporters json,csv', 'Use multiple reporters'],
212
+ ['$0 run --iterations 1000', 'Set iteration count'],
213
+ ['$0 run --engine accurate', 'Use high-accuracy engine'],
214
+ ['$0 run --bail', 'Stop on first failure'],
215
+ ]);
216
+ }, async (argv) => {
217
+ const context = await createCliContext(argv, abortController, argv.engine);
218
+ const exitCode = await runCommand(context, {
219
+ bail: argv.bail,
220
+ config: argv.config,
221
+ cwd: argv.cwd,
222
+ engine: argv.engine,
223
+ exclude: argv.exclude,
224
+ excludeTags: argv['exclude-tags'],
225
+ iterations: argv.iterations,
226
+ json: argv.json,
227
+ noColor: argv.noColor,
228
+ outputDir: argv.output,
229
+ pattern: argv.pattern,
230
+ progress: argv.progress,
231
+ quiet: argv.quiet,
232
+ reporters: argv.reporters,
233
+ tags: argv.tags,
234
+ time: argv.time,
235
+ timeout: argv.timeout,
236
+ verbose: argv.verbose,
237
+ warmup: argv.warmup,
238
+ });
239
+ process.exit(exitCode);
240
+ })
241
+ .command('history <subcommand> [args..]', 'View and manage benchmark history', (yargs) => {
242
+ return yargs
243
+ .positional('subcommand', {
244
+ choices: [
245
+ 'list',
246
+ 'show',
247
+ 'compare',
248
+ 'trends',
249
+ 'clean',
250
+ 'export',
251
+ ],
252
+ demandOption: true,
253
+ describe: 'History subcommand',
254
+ type: 'string',
255
+ })
256
+ .positional('args', {
257
+ array: true,
258
+ describe: 'Additional arguments for the subcommand',
259
+ type: 'string',
260
+ })
261
+ .option('since', {
262
+ description: 'Show runs since date (ISO 8601 or relative like "1 week ago")',
263
+ type: 'string',
264
+ })
265
+ .option('until', {
266
+ description: 'Show runs until date (ISO 8601 or relative like "1 day ago")',
267
+ type: 'string',
268
+ })
269
+ .option('pattern', {
270
+ description: 'Filter by benchmark name pattern',
271
+ type: 'string',
272
+ })
273
+ .option('tags', {
274
+ description: 'Filter by tags',
275
+ type: 'array',
276
+ })
277
+ .option('limit', {
278
+ default: 10,
279
+ description: 'Maximum number of results',
280
+ type: 'number',
281
+ })
282
+ .option('format', {
283
+ choices: ['human', 'json', 'csv'],
284
+ default: 'human',
285
+ description: 'Output format',
286
+ type: 'string',
287
+ })
288
+ .option('maxAge', {
289
+ description: 'Maximum age in days for cleanup',
290
+ type: 'number',
291
+ })
292
+ .option('maxRuns', {
293
+ description: 'Maximum number of runs to keep',
294
+ type: 'number',
295
+ })
296
+ .option('maxSize', {
297
+ description: 'Maximum storage size in bytes',
298
+ type: 'number',
299
+ })
300
+ .option('confirm', {
301
+ default: false,
302
+ description: 'Confirm cleanup operations',
303
+ type: 'boolean',
304
+ })
305
+ .option('output', {
306
+ description: 'Output file path',
307
+ type: 'string',
308
+ })
309
+ .example([
310
+ ['$0 history list', 'List recent benchmark runs'],
311
+ ['$0 history show <run-id>', 'Show detailed results for run'],
312
+ ['$0 history compare <run-id1> <run-id2>', 'Compare two runs'],
313
+ ['$0 history trends [pattern]', 'Show performance trends'],
314
+ ['$0 history clean --max-runs 50', 'Keep only latest 50 runs'],
315
+ ['$0 history export --format csv', 'Export to CSV'],
316
+ ]);
317
+ }, async (argv) => {
318
+ const context = await createCliContext(argv, abortController);
319
+ const exitCode = await historyCommand(context, {
320
+ args: argv.args,
321
+ confirm: argv.confirm,
322
+ cwd: argv.cwd,
323
+ format: argv.format,
324
+ limit: argv.limit,
325
+ maxAge: argv.maxAge,
326
+ maxRuns: argv.maxRuns,
327
+ maxSize: argv.maxSize,
328
+ outputDir: argv.output,
329
+ pattern: argv.pattern,
330
+ quiet: Boolean(argv.quiet),
331
+ since: argv.since,
332
+ subcommand: argv.subcommand,
333
+ tags: argv.tags,
334
+ until: argv.until,
335
+ verbose: argv.verbose,
336
+ });
337
+ process.exit(exitCode);
338
+ })
339
+ .command('init [type]', 'Initialize a new benchmark project', (yargs) => {
340
+ return yargs
341
+ .positional('type', {
342
+ choices: ['basic', 'advanced', 'library'],
343
+ default: 'basic',
344
+ describe: 'Type of project to initialize',
345
+ type: 'string',
346
+ })
347
+ .option('examples', {
348
+ default: true,
349
+ description: 'Include example benchmark files',
350
+ type: 'boolean',
351
+ })
352
+ .option('config-type', {
353
+ choices: ['json', 'yaml', 'js', 'ts'],
354
+ default: 'json',
355
+ description: 'Configuration file format',
356
+ type: 'string',
357
+ })
358
+ .option('force', {
359
+ default: false,
360
+ description: 'Overwrite existing files',
361
+ type: 'boolean',
362
+ })
363
+ .option('yes', {
364
+ alias: 'y',
365
+ default: false,
366
+ description: 'Accept all prompts automatically',
367
+ type: 'boolean',
368
+ })
369
+ .option('quiet', {
370
+ alias: 'q',
371
+ default: false,
372
+ description: 'Minimal output',
373
+ type: 'boolean',
374
+ })
375
+ .example([
376
+ ['$0 init', 'Initialize a basic project'],
377
+ [
378
+ '$0 init advanced --config-type ts',
379
+ 'Initialize advanced project with TypeScript config',
380
+ ],
381
+ [
382
+ '$0 init library --no-examples',
383
+ 'Initialize library project without examples',
384
+ ],
385
+ ]);
386
+ }, async (argv) => {
387
+ const context = await createCliContext(argv, abortController);
388
+ const exitCode = await initCommand(context, {
389
+ configType: argv['config-type'],
390
+ cwd: argv.cwd,
391
+ examples: argv.examples,
392
+ force: argv.force,
393
+ quiet: Boolean(argv.quiet),
394
+ type: argv.type,
395
+ verbose: argv.verbose,
396
+ yes: argv.yes,
397
+ });
398
+ process.exit(exitCode);
399
+ })
400
+ .fail((msg, err, yargsInstance) => {
401
+ if (err) {
402
+ console.error('Error:', err.message);
403
+ if (process.env.DEBUG) {
404
+ console.error(err.stack);
405
+ }
406
+ process.exit(ExitCodes.RUNTIME_ERROR);
407
+ }
408
+ else {
409
+ console.error(msg);
410
+ console.error();
411
+ yargsInstance.showHelp();
412
+ process.exit(ExitCodes.CONFIG_ERROR);
413
+ }
414
+ })
415
+ .parse();
416
+ }
417
+ catch (error) {
418
+ console.error('Unexpected error:', error instanceof Error ? error.message : String(error));
419
+ if (process.env.DEBUG) {
420
+ console.error(error);
421
+ }
422
+ process.exit(ExitCodes.UNKNOWN_ERROR);
423
+ }
424
+ };
425
+ /**
426
+ * Create CLI context with dependency injection
427
+ */
428
+ const createCliContext = async (options, abortController, engineType = 'tinybench') => {
429
+ try {
430
+ const dependencies = bootstrap();
431
+ // Select engine based on type
432
+ const engine = engineType === 'accurate'
433
+ ? new AccurateEngine(dependencies)
434
+ : new TinybenchEngine(dependencies);
435
+ // Register built-in reporters
436
+ engine.registerReporter('human', new HumanReporter({
437
+ color: !options.noColor,
438
+ verbose: options.verbose,
439
+ }));
440
+ engine.registerReporter('json', new JsonReporter({
441
+ prettyPrint: true,
442
+ }));
443
+ engine.registerReporter('csv', new CsvReporter({
444
+ includeHeaders: true,
445
+ includeMetadata: true,
446
+ }));
447
+ engine.registerReporter('simple', new SimpleReporter({
448
+ verbose: options.verbose,
449
+ }));
450
+ return {
451
+ abortController,
452
+ configManager: engine.configManager,
453
+ engine,
454
+ errorManager: engine.errorManager,
455
+ historyStorage: engine.historyStorage,
456
+ options,
457
+ progressManager: engine.progressManager,
458
+ reporterRegistry: engine.reporterRegistry,
459
+ };
460
+ }
461
+ catch (error) {
462
+ console.error('Failed to initialize ModestBench:', error instanceof Error ? error.message : String(error));
463
+ process.exit(ExitCodes.CONFIG_ERROR);
464
+ }
465
+ };
466
+ /**
467
+ * Handle process signals gracefully
468
+ */
469
+ const setupSignalHandlers = (abortController) => {
470
+ let abortRequested = false;
471
+ const handleSignal = (signal) => {
472
+ if (abortRequested) {
473
+ // Second signal, force exit
474
+ console.log(`\nReceived ${signal} again, forcing exit...`);
475
+ process.exit(128 + (signal === 'SIGINT' ? 2 : signal === 'SIGQUIT' ? 3 : 15));
476
+ }
477
+ console.log(`\nReceived ${signal}, aborting benchmarks...`);
478
+ abortRequested = true;
479
+ abortController.abort();
480
+ // Give a short grace period for cleanup, then exit
481
+ setTimeout(() => {
482
+ console.log('\nBenchmark aborted.');
483
+ process.exit(128 + (signal === 'SIGINT' ? 2 : signal === 'SIGQUIT' ? 3 : 15));
484
+ }, 100);
485
+ };
486
+ process.on('SIGINT', () => handleSignal('SIGINT'));
487
+ process.on('SIGQUIT', () => handleSignal('SIGQUIT'));
488
+ process.on('SIGTERM', () => handleSignal('SIGTERM'));
489
+ process.on('uncaughtException', (error) => {
490
+ console.error('Uncaught exception:', error);
491
+ process.exit(ExitCodes.RUNTIME_ERROR);
492
+ });
493
+ process.on('unhandledRejection', (reason, promise) => {
494
+ console.error('Unhandled rejection at:', promise, 'reason:', reason);
495
+ process.exit(ExitCodes.RUNTIME_ERROR);
496
+ });
497
+ };
498
+ // Run CLI if this file is executed directly
499
+ const scriptPath = fileURLToPath(import.meta.url);
500
+ const argPath = process.argv[1];
501
+ // Resolve both to real paths to handle symlinks (e.g. npm install ../package)
502
+ try {
503
+ const scriptRealPath = realpathSync(scriptPath);
504
+ const argRealPath = argPath ? realpathSync(argPath) : '';
505
+ if (scriptRealPath === argRealPath) {
506
+ cli();
507
+ }
508
+ }
509
+ catch {
510
+ // If realpath fails (file doesn't exist), fall back to string comparison
511
+ if (import.meta.url === `file://${argPath}`) {
512
+ cli();
513
+ }
514
+ }
515
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}