mirror of
https://github.com/different-ai/openwork
synced 2026-04-26 01:25:10 +02:00
91 lines
2.7 KiB
JavaScript
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();
|
|
}
|
|
}
|