Files
openwork/scripts/select-session-debug.mjs
Benjamin Shafii 02e08e08da mixb ags
2026-01-18 22:43:10 -08:00

91 lines
2.7 KiB
JavaScript

import assert from "node:assert/strict";
import {
findFreePort,
makeClient,
parseArgs,
spawnOpencodeServe,
waitForHealthy,
} from "./_util.mjs";
const args = parseArgs(process.argv.slice(2));
const directory = args.get("dir") ?? process.cwd();
const baseUrlOverride = args.get("baseUrl") ?? null;
const count = Number.parseInt(args.get("count") ?? "2", 10);
const sessionIdOverride = args.get("session") ?? null;
const withTiming = async (label, fn) => {
const start = Date.now();
try {
const result = await fn();
const elapsed = Date.now() - start;
return { ok: true, label, elapsed, result };
} catch (error) {
const elapsed = Date.now() - start;
return { ok: false, label, elapsed, error: error instanceof Error ? error.message : String(error) };
}
};
let server = null;
try {
if (!baseUrlOverride) {
const port = await findFreePort();
server = await spawnOpencodeServe({ directory, port });
}
const baseUrl = baseUrlOverride ?? server.baseUrl;
const client = makeClient({ baseUrl, directory: server?.cwd ?? directory });
await waitForHealthy(client);
console.log(
JSON.stringify({
ok: true,
baseUrl,
directory: server?.cwd ?? directory,
count,
sessionIdOverride,
}),
);
for (let i = 0; i < count; i += 1) {
console.log(`\n=== Iteration ${i + 1}/${count} ===`);
const health = await withTiming("global.health", async () => client.global.health());
console.log(JSON.stringify(health));
let sessionId = sessionIdOverride;
if (!sessionId) {
const create = await withTiming("session.create", async () =>
client.session.create({ title: `Debug session ${i + 1}`, directory }),
);
console.log(JSON.stringify(create));
assert.ok(create.ok, "session.create failed");
sessionId = create.result.id;
}
const list = await withTiming("session.list", async () => client.session.list({ limit: 50 }));
console.log(JSON.stringify(list));
const messages = await withTiming("session.messages", async () =>
client.session.messages({ sessionID: sessionId, limit: 50 }),
);
console.log(JSON.stringify(messages));
const todos = await withTiming("session.todo", async () => client.session.todo({ sessionID: sessionId }));
console.log(JSON.stringify(todos));
const permissions = await withTiming("permission.list", async () => client.permission.list());
console.log(JSON.stringify(permissions));
}
} catch (e) {
const message = e instanceof Error ? e.message : String(e);
console.error(JSON.stringify({ ok: false, error: message, stderr: server?.getStderr?.() ?? null }));
process.exitCode = 1;
} finally {
if (server) {
await server.close();
}
}