@visorcraft/idlehands 0.9.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 (197) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +30 -0
  3. package/dist/agent.js +2604 -0
  4. package/dist/agent.js.map +1 -0
  5. package/dist/anton/controller.js +341 -0
  6. package/dist/anton/controller.js.map +1 -0
  7. package/dist/anton/lock.js +110 -0
  8. package/dist/anton/lock.js.map +1 -0
  9. package/dist/anton/parser.js +303 -0
  10. package/dist/anton/parser.js.map +1 -0
  11. package/dist/anton/prompt.js +203 -0
  12. package/dist/anton/prompt.js.map +1 -0
  13. package/dist/anton/reporter.js +119 -0
  14. package/dist/anton/reporter.js.map +1 -0
  15. package/dist/anton/session.js +51 -0
  16. package/dist/anton/session.js.map +1 -0
  17. package/dist/anton/types.js +7 -0
  18. package/dist/anton/types.js.map +1 -0
  19. package/dist/anton/verifier.js +263 -0
  20. package/dist/anton/verifier.js.map +1 -0
  21. package/dist/bench/compare.js +239 -0
  22. package/dist/bench/compare.js.map +1 -0
  23. package/dist/bench/debug_hooks.js +17 -0
  24. package/dist/bench/debug_hooks.js.map +1 -0
  25. package/dist/bench/json_extract.js +22 -0
  26. package/dist/bench/json_extract.js.map +1 -0
  27. package/dist/bench/openclaw.js +86 -0
  28. package/dist/bench/openclaw.js.map +1 -0
  29. package/dist/bench/report.js +116 -0
  30. package/dist/bench/report.js.map +1 -0
  31. package/dist/bench/runner.js +312 -0
  32. package/dist/bench/runner.js.map +1 -0
  33. package/dist/bench/types.js +2 -0
  34. package/dist/bench/types.js.map +1 -0
  35. package/dist/bot/commands.js +444 -0
  36. package/dist/bot/commands.js.map +1 -0
  37. package/dist/bot/confirm-discord.js +133 -0
  38. package/dist/bot/confirm-discord.js.map +1 -0
  39. package/dist/bot/confirm-telegram.js +290 -0
  40. package/dist/bot/confirm-telegram.js.map +1 -0
  41. package/dist/bot/discord.js +826 -0
  42. package/dist/bot/discord.js.map +1 -0
  43. package/dist/bot/format.js +210 -0
  44. package/dist/bot/format.js.map +1 -0
  45. package/dist/bot/session-manager.js +270 -0
  46. package/dist/bot/session-manager.js.map +1 -0
  47. package/dist/bot/telegram.js +678 -0
  48. package/dist/bot/telegram.js.map +1 -0
  49. package/dist/cli/agent-turn.js +45 -0
  50. package/dist/cli/agent-turn.js.map +1 -0
  51. package/dist/cli/args.js +236 -0
  52. package/dist/cli/args.js.map +1 -0
  53. package/dist/cli/bot.js +252 -0
  54. package/dist/cli/bot.js.map +1 -0
  55. package/dist/cli/build-repl-context.js +365 -0
  56. package/dist/cli/build-repl-context.js.map +1 -0
  57. package/dist/cli/command-registry.js +20 -0
  58. package/dist/cli/command-registry.js.map +1 -0
  59. package/dist/cli/commands/anton.js +271 -0
  60. package/dist/cli/commands/anton.js.map +1 -0
  61. package/dist/cli/commands/editing.js +328 -0
  62. package/dist/cli/commands/editing.js.map +1 -0
  63. package/dist/cli/commands/model.js +274 -0
  64. package/dist/cli/commands/model.js.map +1 -0
  65. package/dist/cli/commands/project.js +255 -0
  66. package/dist/cli/commands/project.js.map +1 -0
  67. package/dist/cli/commands/runtime.js +63 -0
  68. package/dist/cli/commands/runtime.js.map +1 -0
  69. package/dist/cli/commands/session.js +281 -0
  70. package/dist/cli/commands/session.js.map +1 -0
  71. package/dist/cli/commands/tools.js +126 -0
  72. package/dist/cli/commands/tools.js.map +1 -0
  73. package/dist/cli/commands/trifecta.js +221 -0
  74. package/dist/cli/commands/trifecta.js.map +1 -0
  75. package/dist/cli/commands/tui.js +17 -0
  76. package/dist/cli/commands/tui.js.map +1 -0
  77. package/dist/cli/init.js +222 -0
  78. package/dist/cli/init.js.map +1 -0
  79. package/dist/cli/input.js +360 -0
  80. package/dist/cli/input.js.map +1 -0
  81. package/dist/cli/oneshot.js +254 -0
  82. package/dist/cli/oneshot.js.map +1 -0
  83. package/dist/cli/repl-context.js +2 -0
  84. package/dist/cli/repl-context.js.map +1 -0
  85. package/dist/cli/runtime-cmds.js +811 -0
  86. package/dist/cli/runtime-cmds.js.map +1 -0
  87. package/dist/cli/service.js +145 -0
  88. package/dist/cli/service.js.map +1 -0
  89. package/dist/cli/session-state.js +130 -0
  90. package/dist/cli/session-state.js.map +1 -0
  91. package/dist/cli/setup.js +815 -0
  92. package/dist/cli/setup.js.map +1 -0
  93. package/dist/cli/shell.js +79 -0
  94. package/dist/cli/shell.js.map +1 -0
  95. package/dist/cli/status.js +392 -0
  96. package/dist/cli/status.js.map +1 -0
  97. package/dist/cli/watch.js +33 -0
  98. package/dist/cli/watch.js.map +1 -0
  99. package/dist/client.js +676 -0
  100. package/dist/client.js.map +1 -0
  101. package/dist/commands.js +194 -0
  102. package/dist/commands.js.map +1 -0
  103. package/dist/config.js +507 -0
  104. package/dist/config.js.map +1 -0
  105. package/dist/confirm/auto.js +13 -0
  106. package/dist/confirm/auto.js.map +1 -0
  107. package/dist/confirm/headless.js +41 -0
  108. package/dist/confirm/headless.js.map +1 -0
  109. package/dist/confirm/terminal.js +90 -0
  110. package/dist/confirm/terminal.js.map +1 -0
  111. package/dist/context.js +49 -0
  112. package/dist/context.js.map +1 -0
  113. package/dist/git.js +136 -0
  114. package/dist/git.js.map +1 -0
  115. package/dist/harnesses.js +171 -0
  116. package/dist/harnesses.js.map +1 -0
  117. package/dist/history.js +139 -0
  118. package/dist/history.js.map +1 -0
  119. package/dist/index.js +700 -0
  120. package/dist/index.js.map +1 -0
  121. package/dist/indexer.js +374 -0
  122. package/dist/indexer.js.map +1 -0
  123. package/dist/jsonrpc.js +76 -0
  124. package/dist/jsonrpc.js.map +1 -0
  125. package/dist/lens.js +525 -0
  126. package/dist/lens.js.map +1 -0
  127. package/dist/lsp.js +605 -0
  128. package/dist/lsp.js.map +1 -0
  129. package/dist/markdown.js +275 -0
  130. package/dist/markdown.js.map +1 -0
  131. package/dist/mcp.js +554 -0
  132. package/dist/mcp.js.map +1 -0
  133. package/dist/recovery.js +178 -0
  134. package/dist/recovery.js.map +1 -0
  135. package/dist/replay.js +132 -0
  136. package/dist/replay.js.map +1 -0
  137. package/dist/replay_cli.js +24 -0
  138. package/dist/replay_cli.js.map +1 -0
  139. package/dist/runtime/executor.js +418 -0
  140. package/dist/runtime/executor.js.map +1 -0
  141. package/dist/runtime/planner.js +197 -0
  142. package/dist/runtime/planner.js.map +1 -0
  143. package/dist/runtime/store.js +289 -0
  144. package/dist/runtime/store.js.map +1 -0
  145. package/dist/runtime/types.js +2 -0
  146. package/dist/runtime/types.js.map +1 -0
  147. package/dist/safety.js +446 -0
  148. package/dist/safety.js.map +1 -0
  149. package/dist/spinner.js +224 -0
  150. package/dist/spinner.js.map +1 -0
  151. package/dist/sys/context.js +124 -0
  152. package/dist/sys/context.js.map +1 -0
  153. package/dist/sys/snapshot.sh +97 -0
  154. package/dist/term.js +61 -0
  155. package/dist/term.js.map +1 -0
  156. package/dist/themes.js +135 -0
  157. package/dist/themes.js.map +1 -0
  158. package/dist/tools.js +1114 -0
  159. package/dist/tools.js.map +1 -0
  160. package/dist/tui/branch-picker.js +65 -0
  161. package/dist/tui/branch-picker.js.map +1 -0
  162. package/dist/tui/command-handler.js +108 -0
  163. package/dist/tui/command-handler.js.map +1 -0
  164. package/dist/tui/confirm.js +90 -0
  165. package/dist/tui/confirm.js.map +1 -0
  166. package/dist/tui/controller.js +463 -0
  167. package/dist/tui/controller.js.map +1 -0
  168. package/dist/tui/event-bridge.js +44 -0
  169. package/dist/tui/event-bridge.js.map +1 -0
  170. package/dist/tui/events.js +2 -0
  171. package/dist/tui/events.js.map +1 -0
  172. package/dist/tui/keymap.js +144 -0
  173. package/dist/tui/keymap.js.map +1 -0
  174. package/dist/tui/layout.js +11 -0
  175. package/dist/tui/layout.js.map +1 -0
  176. package/dist/tui/render.js +186 -0
  177. package/dist/tui/render.js.map +1 -0
  178. package/dist/tui/screen.js +48 -0
  179. package/dist/tui/screen.js.map +1 -0
  180. package/dist/tui/state.js +167 -0
  181. package/dist/tui/state.js.map +1 -0
  182. package/dist/tui/theme.js +70 -0
  183. package/dist/tui/theme.js.map +1 -0
  184. package/dist/tui/types.js +2 -0
  185. package/dist/tui/types.js.map +1 -0
  186. package/dist/types.js +2 -0
  187. package/dist/types.js.map +1 -0
  188. package/dist/upgrade.js +412 -0
  189. package/dist/upgrade.js.map +1 -0
  190. package/dist/utils.js +87 -0
  191. package/dist/utils.js.map +1 -0
  192. package/dist/vault.js +520 -0
  193. package/dist/vault.js.map +1 -0
  194. package/dist/vim.js +160 -0
  195. package/dist/vim.js.map +1 -0
  196. package/package.json +67 -0
  197. package/src/sys/snapshot.sh +97 -0
@@ -0,0 +1,239 @@
1
+ #!/usr/bin/env node
2
+ // NOTE: These utilities are intentionally duplicated from src/ to keep the
3
+ // benchmark harness self-contained and free of production import dependencies.
4
+ import fs from 'node:fs/promises';
5
+ import path from 'node:path';
6
+ import os from 'node:os';
7
+ import crypto from 'node:crypto';
8
+ import { spawn } from 'node:child_process';
9
+ import { loadConfig } from '../config.js';
10
+ import { createSession } from '../agent.js';
11
+ import { runOpenclaw } from './openclaw.js';
12
+ function nowMs() {
13
+ return performance.now();
14
+ }
15
+ async function mkTempDir(prefix = 'idlehands-bench-') {
16
+ return await fs.mkdtemp(path.join(os.tmpdir(), prefix));
17
+ }
18
+ async function runShell(command, cwd, timeoutSec) {
19
+ return await new Promise((resolve, reject) => {
20
+ const shell = process.env.IDLEHANDS_SHELL || 'bash';
21
+ const child = spawn(shell, ['-lc', command], { cwd, stdio: ['ignore', 'pipe', 'pipe'] });
22
+ const out = [];
23
+ const err = [];
24
+ const t = setTimeout(() => child.kill('SIGKILL'), Math.max(1, timeoutSec) * 1000);
25
+ child.stdout.on('data', (d) => out.push(d));
26
+ child.stderr.on('data', (d) => err.push(d));
27
+ child.on('error', reject);
28
+ child.on('close', (code) => {
29
+ clearTimeout(t);
30
+ resolve({ rc: code ?? 0, out: Buffer.concat(out).toString('utf8'), err: Buffer.concat(err).toString('utf8') });
31
+ });
32
+ });
33
+ }
34
+ function randSessionId() {
35
+ return crypto.randomBytes(8).toString('hex');
36
+ }
37
+ async function setupWorkspace(c) {
38
+ if (c.workspace.kind === 'fixed')
39
+ return c.workspace.dir;
40
+ return await mkTempDir(c.workspace.prefix ?? `idlehands-${c.name}-`);
41
+ }
42
+ async function applySetup(c, workDir) {
43
+ if (!c.setup?.length)
44
+ return;
45
+ for (const cmd of c.setup) {
46
+ const r = await runShell(cmd, workDir, 30);
47
+ if (r.rc !== 0)
48
+ throw new Error(`setup failed rc=${r.rc}: ${cmd}\n${r.err}`);
49
+ }
50
+ }
51
+ async function checkSuccess(c, workDir, agentOutput) {
52
+ if (!c.success)
53
+ return { ok: true, reason: 'ok' };
54
+ if (c.success.type === 'equals') {
55
+ const out = agentOutput.trim();
56
+ const ok = out === c.success.value;
57
+ return { ok, reason: ok ? 'ok' : `expected ${JSON.stringify(c.success.value)}, got ${JSON.stringify(out)}` };
58
+ }
59
+ if (c.success.type === 'exec') {
60
+ const ex = await runShell(c.success.command, workDir, 60);
61
+ const wantRc = c.success.exitCode ?? 0;
62
+ let ok = ex.rc === wantRc;
63
+ let reason = ok ? 'ok' : `success check rc=${ex.rc} want=${wantRc}`;
64
+ if (ok && c.success.stdoutEquals !== undefined) {
65
+ ok = ex.out.trimEnd() === c.success.stdoutEquals;
66
+ if (!ok)
67
+ reason = `success stdout mismatch`;
68
+ }
69
+ if (ok && c.success.stdoutIncludes) {
70
+ ok = ex.out.includes(c.success.stdoutIncludes);
71
+ if (!ok)
72
+ reason = `success stdout missing substring`;
73
+ }
74
+ return { ok, reason };
75
+ }
76
+ return { ok: false, reason: 'unknown success type' };
77
+ }
78
+ async function runIdlehandsOnce(opts) {
79
+ const config = opts.cachedConfig
80
+ ? { ...opts.cachedConfig, dir: opts.workDir }
81
+ : (await loadConfig({
82
+ configPath: path.join(os.tmpdir(), 'idlehands-bench-config-does-not-exist.json'),
83
+ cli: {
84
+ endpoint: opts.endpoint,
85
+ dir: opts.workDir,
86
+ model: opts.model ?? '',
87
+ max_tokens: opts.maxTokens,
88
+ no_confirm: true,
89
+ dry_run: false,
90
+ verbose: false
91
+ }
92
+ })).config;
93
+ const initStart = nowMs();
94
+ const session = await createSession({ config });
95
+ const initMs = nowMs() - initStart;
96
+ const askStart = nowMs();
97
+ let ttfr = null;
98
+ let ttft = null;
99
+ const res = await session.ask(opts.instruction, {
100
+ onFirstDelta: () => {
101
+ if (ttfr == null)
102
+ ttfr = nowMs() - askStart;
103
+ },
104
+ onToken: () => {
105
+ if (ttft == null)
106
+ ttft = nowMs() - askStart;
107
+ }
108
+ });
109
+ const ttc = nowMs() - askStart;
110
+ return { initMs, ttfrMs: ttfr, ttftMs: ttft, ttcMs: ttc, exitCode: 0, out: res.text ?? '', turns: res.turns, toolCalls: res.toolCalls };
111
+ }
112
+ async function runEngineOnce(engine, c, workDir, endpoint, maxTokens, cachedConfig) {
113
+ if (engine === 'idlehands') {
114
+ return await runIdlehandsOnce({
115
+ workDir,
116
+ instruction: c.instruction,
117
+ endpoint,
118
+ maxTokens,
119
+ model: c.model,
120
+ cachedConfig
121
+ });
122
+ }
123
+ // openclaw (embedded local mode to keep it apples-to-apples)
124
+ const t0 = nowMs();
125
+ const r = await runOpenclaw({
126
+ workDir,
127
+ instruction: c.instruction,
128
+ timeoutSec: 180,
129
+ sessionId: `bench_${c.name}_${randSessionId()}`,
130
+ // Use embedded mode to avoid gateway pairing requirements.
131
+ // We still pin the model/provider via OPENCLAW_CONFIG_PATH.
132
+ local: true,
133
+ profile: 'idlehands-bench'
134
+ });
135
+ const initMs = 0;
136
+ const ttc = nowMs() - t0;
137
+ // openclaw emits JSON; extract first "text" field.
138
+ let out = '';
139
+ try {
140
+ const { extractFirstText } = await import('./json_extract.js');
141
+ const parsed = JSON.parse(r.stdout || r.stderr || '{}');
142
+ out = (extractFirstText(parsed) ?? '').trim();
143
+ }
144
+ catch {
145
+ out = (r.stdout || r.stderr || '').trim();
146
+ }
147
+ return { initMs, ttfrMs: r.ttfrMs, ttftMs: null, ttcMs: ttc, exitCode: r.exitCode, out, turns: 0, toolCalls: 0 };
148
+ }
149
+ async function main() {
150
+ const casePath = process.argv[2];
151
+ if (!casePath) {
152
+ console.error('Usage: compare <case.json>');
153
+ process.exit(2);
154
+ }
155
+ const raw = await fs.readFile(casePath, 'utf8');
156
+ const c = JSON.parse(raw);
157
+ const endpoint = process.env.IDLEHANDS_ENDPOINT || 'http://192.168.68.118:8080/v1';
158
+ const reps = c.repetitions ?? 5;
159
+ const maxTokens = c.max_tokens ?? 512;
160
+ const engines = c.engine === 'openclaw' ? ['openclaw'] : c.engine === 'both' ? ['idlehands', 'openclaw'] : ['idlehands'];
161
+ const results = [];
162
+ // Pre-load config once for idlehands runs (avoids redundant loadConfig + /v1/models per iteration)
163
+ let idlehandsCachedConfig = null;
164
+ if (engines.includes('idlehands')) {
165
+ const { config } = await loadConfig({
166
+ configPath: path.join(os.tmpdir(), 'idlehands-bench-config-does-not-exist.json'),
167
+ cli: {
168
+ endpoint,
169
+ dir: process.cwd(),
170
+ model: c.model ?? '',
171
+ max_tokens: maxTokens,
172
+ no_confirm: true,
173
+ dry_run: false,
174
+ verbose: false
175
+ }
176
+ });
177
+ idlehandsCachedConfig = config;
178
+ }
179
+ for (const engine of engines) {
180
+ for (let i = 0; i < reps; i++) {
181
+ const workDir = await setupWorkspace(c);
182
+ try {
183
+ console.error(`[bench] case=${c.name} engine=${engine} iter=${i + 1}/${reps} workdir=${workDir}`);
184
+ await applySetup(c, workDir);
185
+ const r = await runEngineOnce(engine, c, workDir, endpoint, maxTokens, engine === 'idlehands' ? idlehandsCachedConfig : undefined);
186
+ const check = await checkSuccess(c, workDir, r.out);
187
+ const ok = check.ok && r.exitCode === 0;
188
+ const reason = check.ok ? (r.exitCode === 0 ? 'ok' : `exitCode=${r.exitCode}`) : check.reason;
189
+ const ttcS = r.ttcMs != null ? (r.ttcMs / 1000).toFixed(2) : '?';
190
+ const ttfrS = r.ttfrMs != null ? (r.ttfrMs / 1000).toFixed(2) : '?';
191
+ console.error(`[bench] result case=${c.name} engine=${engine} iter=${i + 1}/${reps} ok=${ok} ttc_s=${ttcS} ttfr_s=${ttfrS} reason=${ok ? 'ok' : reason}`);
192
+ results.push({
193
+ case: c.name,
194
+ engine,
195
+ iter: i + 1,
196
+ ok,
197
+ reason,
198
+ init_ms: r.initMs,
199
+ ttfr_ms: r.ttfrMs,
200
+ ttft_ms: r.ttftMs,
201
+ ttc_ms: r.ttcMs,
202
+ exitCode: r.exitCode,
203
+ turns: r.turns,
204
+ toolCalls: r.toolCalls
205
+ });
206
+ }
207
+ catch (e) {
208
+ const reason = e?.message ?? String(e);
209
+ console.error(`[bench] result case=${c.name} engine=${engine} iter=${i + 1}/${reps} ok=false ttc_s=0 ttfr_s=? reason=${reason}`);
210
+ results.push({
211
+ case: c.name,
212
+ engine,
213
+ iter: i + 1,
214
+ ok: false,
215
+ reason,
216
+ init_ms: 0,
217
+ ttfr_ms: null,
218
+ ttft_ms: null,
219
+ ttc_ms: 0,
220
+ exitCode: null
221
+ });
222
+ }
223
+ finally {
224
+ if (c.workspace.kind === 'temp') {
225
+ await fs.rm(workDir, { recursive: true, force: true }).catch(() => { });
226
+ }
227
+ }
228
+ }
229
+ }
230
+ const outPath = path.join(process.cwd(), 'bench', 'results', `${c.name}.compare.${Date.now()}.jsonl`);
231
+ await fs.mkdir(path.dirname(outPath), { recursive: true });
232
+ await fs.writeFile(outPath, results.map((r) => JSON.stringify(r)).join('\n') + '\n', 'utf8');
233
+ console.log(`Wrote: ${outPath}`);
234
+ }
235
+ main().catch((e) => {
236
+ console.error(e);
237
+ process.exit(1);
238
+ });
239
+ //# sourceMappingURL=compare.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compare.js","sourceRoot":"","sources":["../../src/bench/compare.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ export function installBenchDebugHooks() {
2
+ const onUncaught = (e) => {
3
+ try {
4
+ console.error('[bench-debug] uncaughtException:', e);
5
+ }
6
+ catch { }
7
+ };
8
+ const onUnhandled = (e) => {
9
+ try {
10
+ console.error('[bench-debug] unhandledRejection:', e);
11
+ }
12
+ catch { }
13
+ };
14
+ process.on('uncaughtException', onUncaught);
15
+ process.on('unhandledRejection', onUnhandled);
16
+ }
17
+ //# sourceMappingURL=debug_hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug_hooks.js","sourceRoot":"","sources":["../../src/bench/debug_hooks.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,sBAAsB;IACpC,MAAM,UAAU,GAAG,CAAC,CAAM,EAAE,EAAE;QAC5B,IAAI,CAAC;YACH,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,CAAC,CAAC,CAAC;QACvD,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACZ,CAAC,CAAC;IACF,MAAM,WAAW,GAAG,CAAC,CAAM,EAAE,EAAE;QAC7B,IAAI,CAAC;YACH,OAAO,CAAC,KAAK,CAAC,mCAAmC,EAAE,CAAC,CAAC,CAAC;QACxD,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACZ,CAAC,CAAC;IAEF,OAAO,CAAC,EAAE,CAAC,mBAAmB,EAAE,UAAU,CAAC,CAAC;IAC5C,OAAO,CAAC,EAAE,CAAC,oBAAoB,EAAE,WAAW,CAAC,CAAC;AAChD,CAAC"}
@@ -0,0 +1,22 @@
1
+ export function extractFirstText(obj) {
2
+ const texts = [];
3
+ const walk = (x) => {
4
+ if (!x)
5
+ return;
6
+ if (typeof x === 'object') {
7
+ if (Array.isArray(x)) {
8
+ for (const v of x)
9
+ walk(v);
10
+ return;
11
+ }
12
+ for (const [k, v] of Object.entries(x)) {
13
+ if (k === 'text' && typeof v === 'string')
14
+ texts.push(v);
15
+ walk(v);
16
+ }
17
+ }
18
+ };
19
+ walk(obj);
20
+ return texts.length ? texts[0] : null;
21
+ }
22
+ //# sourceMappingURL=json_extract.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"json_extract.js","sourceRoot":"","sources":["../../src/bench/json_extract.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,gBAAgB,CAAC,GAAQ;IACvC,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,MAAM,IAAI,GAAG,CAAC,CAAM,EAAE,EAAE;QACtB,IAAI,CAAC,CAAC;YAAE,OAAO;QACf,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;YAC1B,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;gBACrB,KAAK,MAAM,CAAC,IAAI,CAAC;oBAAE,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC3B,OAAO;YACT,CAAC;YACD,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;gBACvC,IAAI,CAAC,KAAK,MAAM,IAAI,OAAO,CAAC,KAAK,QAAQ;oBAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACzD,IAAI,CAAC,CAAC,CAAC,CAAC;YACV,CAAC;QACH,CAAC;IACH,CAAC,CAAC;IACF,IAAI,CAAC,GAAG,CAAC,CAAC;IACV,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AACxC,CAAC"}
@@ -0,0 +1,86 @@
1
+ #!/usr/bin/env node
2
+ // NOTE: These utilities are intentionally duplicated from src/ to keep the
3
+ // benchmark harness self-contained and free of production import dependencies.
4
+ import { spawn } from 'node:child_process';
5
+ function nowMs() {
6
+ return performance.now();
7
+ }
8
+ export async function runOpenclaw(opts) {
9
+ const t0 = nowMs();
10
+ let ttfr = null;
11
+ const prefix = `Work in directory: ${opts.workDir}.\n` +
12
+ `Use absolute paths OR set cwd explicitly when using exec.\n` +
13
+ `Do not modify files outside that directory.\n\n`;
14
+ const args = [
15
+ 'agent',
16
+ ...(opts.local ? ['--local'] : []),
17
+ '--agent',
18
+ 'main',
19
+ '--channel',
20
+ 'last',
21
+ '--thinking',
22
+ 'off',
23
+ '--timeout',
24
+ String(opts.timeoutSec),
25
+ '--session-id',
26
+ opts.sessionId,
27
+ '--verbose',
28
+ 'off',
29
+ '--json',
30
+ '--message',
31
+ prefix +
32
+ `IMPORTANT: for ANY command execution, you MUST run it as:\n` +
33
+ ` bash -lc 'cd ${opts.workDir} && <command>'\n` +
34
+ `Do NOT run commands without the 'cd ${opts.workDir} &&' prefix.\n\n` +
35
+ opts.instruction
36
+ ];
37
+ const binArgs = [];
38
+ if (opts.profile) {
39
+ binArgs.push('--profile', opts.profile);
40
+ }
41
+ binArgs.push(...args);
42
+ const child = spawn('openclaw', binArgs, {
43
+ stdio: ['ignore', 'pipe', 'pipe'],
44
+ env: {
45
+ ...process.env,
46
+ // Ensure the OpenClaw CLI uses the same pinned Halo model/provider.
47
+ // (We generate this config in bench to keep apples-to-apples with Idle Hands.)
48
+ OPENCLAW_CONFIG_PATH: process.env.OPENCLAW_CONFIG_PATH || '/home/user/.openclaw-idlehands-bench/openclaw.json'
49
+ }
50
+ });
51
+ const killTimer = setTimeout(() => {
52
+ try {
53
+ child.kill('SIGKILL');
54
+ }
55
+ catch {
56
+ // ignore
57
+ }
58
+ }, Math.max(1, opts.timeoutSec + 10) * 1000);
59
+ const out = [];
60
+ const err = [];
61
+ const mark = () => {
62
+ if (ttfr == null)
63
+ ttfr = nowMs() - t0;
64
+ };
65
+ child.stdout.on('data', (d) => {
66
+ mark();
67
+ out.push(d);
68
+ });
69
+ child.stderr.on('data', (d) => {
70
+ mark();
71
+ err.push(d);
72
+ });
73
+ const exitCode = await new Promise((resolve) => child.on('close', (code) => resolve(code ?? 0)));
74
+ clearTimeout(killTimer);
75
+ const t1 = nowMs();
76
+ const stdout = Buffer.concat(out).toString('utf8');
77
+ const stderr = Buffer.concat(err).toString('utf8');
78
+ return {
79
+ exitCode,
80
+ stdout,
81
+ stderr,
82
+ ttfrMs: ttfr,
83
+ ttcMs: t1 - t0
84
+ };
85
+ }
86
+ //# sourceMappingURL=openclaw.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openclaw.js","sourceRoot":"","sources":["../../src/bench/openclaw.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,116 @@
1
+ #!/usr/bin/env node
2
+ import fs from 'node:fs/promises';
3
+ import path from 'node:path';
4
+ function percentile(sorted, p) {
5
+ if (!sorted.length)
6
+ return NaN;
7
+ const idx = (sorted.length - 1) * p;
8
+ const lo = Math.floor(idx);
9
+ const hi = Math.ceil(idx);
10
+ if (lo === hi)
11
+ return sorted[lo];
12
+ const w = idx - lo;
13
+ return sorted[lo] * (1 - w) + sorted[hi] * w;
14
+ }
15
+ function median(sorted) {
16
+ return percentile(sorted, 0.5);
17
+ }
18
+ async function main() {
19
+ const resultsDir = path.join(process.cwd(), 'bench', 'results');
20
+ const ents = await fs.readdir(resultsDir, { withFileTypes: true }).catch(() => []);
21
+ const files = ents.filter((e) => e.isFile() && e.name.endsWith('.jsonl')).map((e) => path.join(resultsDir, e.name));
22
+ const rows = [];
23
+ for (const f of files) {
24
+ const raw = await fs.readFile(f, 'utf8');
25
+ for (const line of raw.split(/\r?\n/)) {
26
+ if (!line.trim())
27
+ continue;
28
+ try {
29
+ rows.push(JSON.parse(line));
30
+ }
31
+ catch {
32
+ // ignore
33
+ }
34
+ }
35
+ }
36
+ const byKey = new Map();
37
+ for (const r of rows) {
38
+ const key = `${r.case}::${r.engine}`;
39
+ const arr = byKey.get(key) ?? [];
40
+ arr.push(r);
41
+ byKey.set(key, arr);
42
+ }
43
+ const lines = [];
44
+ lines.push('# Idle Hands — Bench Report');
45
+ lines.push('');
46
+ lines.push(`Generated: ${new Date().toISOString()}`);
47
+ lines.push('');
48
+ for (const [key, arr] of [...byKey.entries()].sort((a, b) => a[0].localeCompare(b[0]))) {
49
+ const [caseName, engine] = key.split('::');
50
+ const oks = arr.filter((r) => r.ok);
51
+ const failCount = arr.length - oks.length;
52
+ const ttc = oks.map((r) => r.ttc_ms).filter((n) => Number.isFinite(n)).sort((a, b) => a - b);
53
+ const ttfr = oks
54
+ .map((r) => r.ttfr_ms)
55
+ .filter((n) => typeof n === 'number' && Number.isFinite(n))
56
+ .sort((a, b) => a - b);
57
+ const ttft = oks
58
+ .map((r) => r.ttft_ms)
59
+ .filter((n) => typeof n === 'number' && Number.isFinite(n))
60
+ .sort((a, b) => a - b);
61
+ lines.push(`## ${caseName} (${engine})`);
62
+ lines.push('');
63
+ lines.push(`Runs: ${arr.length}, ok: ${oks.length}, fail: ${failCount}`);
64
+ lines.push('');
65
+ const init = oks
66
+ .map((r) => (typeof r.init_ms === 'number' ? r.init_ms : NaN))
67
+ // In reuse_session mode we record init_ms=0 for iter>1; ignore those.
68
+ .filter((n) => Number.isFinite(n) && n > 0)
69
+ .sort((a, b) => a - b);
70
+ if (init.length) {
71
+ lines.push(`- INIT median: ${median(init).toFixed(1)} ms (session init: model pick + warmup)`);
72
+ lines.push(`- INIT p95: ${percentile(init, 0.95).toFixed(1)} ms`);
73
+ }
74
+ if (ttc.length) {
75
+ lines.push(`- TTC median: ${median(ttc).toFixed(1)} ms (ask: completion wall time)`);
76
+ lines.push(`- TTC p95: ${percentile(ttc, 0.95).toFixed(1)} ms`);
77
+ }
78
+ if (ttfr.length) {
79
+ lines.push(`- TTFR median: ${median(ttfr).toFixed(1)} ms (ask: time-to-first-delta)`);
80
+ lines.push(`- TTFR p95: ${percentile(ttfr, 0.95).toFixed(1)} ms`);
81
+ }
82
+ if (ttft.length) {
83
+ lines.push(`- TTFT median: ${median(ttft).toFixed(1)} ms (ask: time-to-first-content-token)`);
84
+ lines.push(`- TTFT p95: ${percentile(ttft, 0.95).toFixed(1)} ms`);
85
+ }
86
+ if (!oks.length) {
87
+ lines.push('- No successful runs to compute latency statistics.');
88
+ }
89
+ // Flag warmup: iter=1 is typically slower (cold KV cache, model warmup)
90
+ const warmup = oks.find((r) => r.iter === 1);
91
+ const steady = oks.filter((r) => r.iter !== 1);
92
+ if (warmup && steady.length >= 2) {
93
+ const steadyTtc = steady.map((r) => r.ttc_ms).filter((n) => Number.isFinite(n)).sort((a, b) => a - b);
94
+ if (steadyTtc.length) {
95
+ const warmupPct = warmup.ttc_ms > 0 ? ((warmup.ttc_ms / median(steadyTtc) - 1) * 100).toFixed(0) : '?';
96
+ lines.push(`- Warmup: iter=1 TTC ${warmup.ttc_ms.toFixed(1)} ms (+${warmupPct}% vs steady median ${median(steadyTtc).toFixed(1)} ms)`);
97
+ }
98
+ }
99
+ const fails = arr.filter((r) => !r.ok).slice(0, 5);
100
+ if (fails.length) {
101
+ lines.push('');
102
+ lines.push('Top failures:');
103
+ for (const f of fails)
104
+ lines.push(`- iter ${f.iter}: ${f.reason}`);
105
+ }
106
+ lines.push('');
107
+ }
108
+ const outPath = path.join(process.cwd(), 'bench', 'REPORT.md');
109
+ await fs.writeFile(outPath, lines.join('\n') + '\n', 'utf8');
110
+ console.log(`Wrote: ${outPath}`);
111
+ }
112
+ main().catch((e) => {
113
+ console.error(e);
114
+ process.exit(1);
115
+ });
116
+ //# sourceMappingURL=report.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"report.js","sourceRoot":"","sources":["../../src/bench/report.ts"],"names":[],"mappings":"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"}