@agentteams/runner 0.0.46
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/dist/api-client.d.ts +22 -0
- package/dist/api-client.js +201 -0
- package/dist/api-client.js.map +1 -0
- package/dist/api-client.test.d.ts +1 -0
- package/dist/api-client.test.js +118 -0
- package/dist/api-client.test.js.map +1 -0
- package/dist/autostart.d.ts +19 -0
- package/dist/autostart.js +359 -0
- package/dist/autostart.js.map +1 -0
- package/dist/autostart.test.d.ts +1 -0
- package/dist/autostart.test.js +42 -0
- package/dist/autostart.test.js.map +1 -0
- package/dist/commands/cleanup.d.ts +1 -0
- package/dist/commands/cleanup.js +12 -0
- package/dist/commands/cleanup.js.map +1 -0
- package/dist/commands/init.d.ts +1 -0
- package/dist/commands/init.js +57 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/restart.d.ts +1 -0
- package/dist/commands/restart.js +7 -0
- package/dist/commands/restart.js.map +1 -0
- package/dist/commands/start.d.ts +1 -0
- package/dist/commands/start.js +34 -0
- package/dist/commands/start.js.map +1 -0
- package/dist/commands/status.d.ts +1 -0
- package/dist/commands/status.js +20 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/stop.d.ts +1 -0
- package/dist/commands/stop.js +21 -0
- package/dist/commands/stop.js.map +1 -0
- package/dist/commands/uninstall.d.ts +1 -0
- package/dist/commands/uninstall.js +21 -0
- package/dist/commands/uninstall.js.map +1 -0
- package/dist/commands/update.d.ts +10 -0
- package/dist/commands/update.js +58 -0
- package/dist/commands/update.js.map +1 -0
- package/dist/commands/update.test.d.ts +1 -0
- package/dist/commands/update.test.js +104 -0
- package/dist/commands/update.test.js.map +1 -0
- package/dist/config.d.ts +6 -0
- package/dist/config.js +69 -0
- package/dist/config.js.map +1 -0
- package/dist/config.test.d.ts +1 -0
- package/dist/config.test.js +133 -0
- package/dist/config.test.js.map +1 -0
- package/dist/daemon-control.d.ts +21 -0
- package/dist/daemon-control.js +58 -0
- package/dist/daemon-control.js.map +1 -0
- package/dist/daemon-control.test.d.ts +1 -0
- package/dist/daemon-control.test.js +48 -0
- package/dist/daemon-control.test.js.map +1 -0
- package/dist/executable.d.ts +25 -0
- package/dist/executable.js +141 -0
- package/dist/executable.js.map +1 -0
- package/dist/executable.test.d.ts +1 -0
- package/dist/executable.test.js +57 -0
- package/dist/executable.test.js.map +1 -0
- package/dist/handlers/trigger-handler.d.ts +25 -0
- package/dist/handlers/trigger-handler.js +308 -0
- package/dist/handlers/trigger-handler.js.map +1 -0
- package/dist/handlers/trigger-handler.test.d.ts +1 -0
- package/dist/handlers/trigger-handler.test.js +496 -0
- package/dist/handlers/trigger-handler.test.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +82 -0
- package/dist/index.js.map +1 -0
- package/dist/logger.d.ts +5 -0
- package/dist/logger.js +25 -0
- package/dist/logger.js.map +1 -0
- package/dist/pid.d.ts +8 -0
- package/dist/pid.js +49 -0
- package/dist/pid.js.map +1 -0
- package/dist/poller.d.ts +20 -0
- package/dist/poller.js +214 -0
- package/dist/poller.js.map +1 -0
- package/dist/poller.test.d.ts +1 -0
- package/dist/poller.test.js +382 -0
- package/dist/poller.test.js.map +1 -0
- package/dist/runners/amp.d.ts +5 -0
- package/dist/runners/amp.js +316 -0
- package/dist/runners/amp.js.map +1 -0
- package/dist/runners/claude-code.d.ts +6 -0
- package/dist/runners/claude-code.js +340 -0
- package/dist/runners/claude-code.js.map +1 -0
- package/dist/runners/claude-code.test.d.ts +1 -0
- package/dist/runners/claude-code.test.js +39 -0
- package/dist/runners/claude-code.test.js.map +1 -0
- package/dist/runners/codex.d.ts +6 -0
- package/dist/runners/codex.js +324 -0
- package/dist/runners/codex.js.map +1 -0
- package/dist/runners/codex.test.d.ts +1 -0
- package/dist/runners/codex.test.js +66 -0
- package/dist/runners/codex.test.js.map +1 -0
- package/dist/runners/gemini.d.ts +5 -0
- package/dist/runners/gemini.js +304 -0
- package/dist/runners/gemini.js.map +1 -0
- package/dist/runners/gemini.test.d.ts +1 -0
- package/dist/runners/gemini.test.js +16 -0
- package/dist/runners/gemini.test.js.map +1 -0
- package/dist/runners/index.d.ts +2 -0
- package/dist/runners/index.js +27 -0
- package/dist/runners/index.js.map +1 -0
- package/dist/runners/index.test.d.ts +1 -0
- package/dist/runners/index.test.js +19 -0
- package/dist/runners/index.test.js.map +1 -0
- package/dist/runners/log-reporter.d.ts +18 -0
- package/dist/runners/log-reporter.js +127 -0
- package/dist/runners/log-reporter.js.map +1 -0
- package/dist/runners/log-reporter.test.d.ts +1 -0
- package/dist/runners/log-reporter.test.js +152 -0
- package/dist/runners/log-reporter.test.js.map +1 -0
- package/dist/runners/opencode.d.ts +6 -0
- package/dist/runners/opencode.js +304 -0
- package/dist/runners/opencode.js.map +1 -0
- package/dist/runners/stream-json-parser.d.ts +17 -0
- package/dist/runners/stream-json-parser.js +116 -0
- package/dist/runners/stream-json-parser.js.map +1 -0
- package/dist/runners/types.d.ts +26 -0
- package/dist/runners/types.js +2 -0
- package/dist/runners/types.js.map +1 -0
- package/dist/types.d.ts +69 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/auth-path-store.d.ts +3 -0
- package/dist/utils/auth-path-store.js +37 -0
- package/dist/utils/auth-path-store.js.map +1 -0
- package/dist/utils/auth-path-store.test.d.ts +1 -0
- package/dist/utils/auth-path-store.test.js +70 -0
- package/dist/utils/auth-path-store.test.js.map +1 -0
- package/dist/utils/convention-sync.d.ts +8 -0
- package/dist/utils/convention-sync.js +41 -0
- package/dist/utils/convention-sync.js.map +1 -0
- package/dist/utils/convention-sync.test.d.ts +1 -0
- package/dist/utils/convention-sync.test.js +75 -0
- package/dist/utils/convention-sync.test.js.map +1 -0
- package/dist/utils/git-worktree.d.ts +9 -0
- package/dist/utils/git-worktree.js +150 -0
- package/dist/utils/git-worktree.js.map +1 -0
- package/dist/utils/git-worktree.test.d.ts +1 -0
- package/dist/utils/git-worktree.test.js +294 -0
- package/dist/utils/git-worktree.test.js.map +1 -0
- package/dist/utils/origin-issue-safeguard.d.ts +16 -0
- package/dist/utils/origin-issue-safeguard.js +198 -0
- package/dist/utils/origin-issue-safeguard.js.map +1 -0
- package/dist/utils/runner-cleanup.d.ts +10 -0
- package/dist/utils/runner-cleanup.js +59 -0
- package/dist/utils/runner-cleanup.js.map +1 -0
- package/dist/utils/runner-cleanup.test.d.ts +1 -0
- package/dist/utils/runner-cleanup.test.js +93 -0
- package/dist/utils/runner-cleanup.test.js.map +1 -0
- package/dist/utils/runner-history.d.ts +6 -0
- package/dist/utils/runner-history.js +13 -0
- package/dist/utils/runner-history.js.map +1 -0
- package/dist/utils/runner-history.test.d.ts +1 -0
- package/dist/utils/runner-history.test.js +25 -0
- package/dist/utils/runner-history.test.js.map +1 -0
- package/package.json +50 -0
- package/readme.md +188 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import assert from "node:assert/strict";
|
|
2
|
+
import test, { mock } from "node:test";
|
|
3
|
+
import { logger } from "../logger.js";
|
|
4
|
+
import { TriggerLogReporter, mergeLogs } from "./log-reporter.js";
|
|
5
|
+
test.afterEach(() => {
|
|
6
|
+
mock.restoreAll();
|
|
7
|
+
});
|
|
8
|
+
test("TriggerLogReporter normalizes log messages and drains them on stop", async () => {
|
|
9
|
+
const payloads = [];
|
|
10
|
+
const client = {
|
|
11
|
+
appendTriggerLogs: async (_triggerId, payload) => {
|
|
12
|
+
payloads.push(payload);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
const reporter = new TriggerLogReporter(client, "trigger-1");
|
|
16
|
+
reporter.append("INFO", "\u001B[31m hello \r\n\r\n\r\nworld \u0007");
|
|
17
|
+
reporter.append("WARN", " ");
|
|
18
|
+
await reporter.stop();
|
|
19
|
+
assert.equal(payloads.length, 1);
|
|
20
|
+
assert.deepEqual(payloads[0], {
|
|
21
|
+
logs: [{ level: "INFO", message: "hello \n\nworld" }],
|
|
22
|
+
heartbeat: true
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
test("TriggerLogReporter prepends a dropped-log warning when the buffer overflows", async () => {
|
|
26
|
+
const payloads = [];
|
|
27
|
+
const client = {
|
|
28
|
+
appendTriggerLogs: async (_triggerId, payload) => {
|
|
29
|
+
payloads.push(payload);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
const reporter = new TriggerLogReporter(client, "trigger-1");
|
|
33
|
+
for (let index = 0; index < 501; index += 1) {
|
|
34
|
+
reporter.append("INFO", `line-${index}`);
|
|
35
|
+
}
|
|
36
|
+
await reporter.stop();
|
|
37
|
+
const flattened = payloads.flatMap((payload) => payload.logs ?? []);
|
|
38
|
+
assert.match(flattened[0]?.message ?? "", /Dropped 1 log line/);
|
|
39
|
+
// After merging, 501 individual logs are compressed into fewer records.
|
|
40
|
+
// The dropped warning (WARN) splits from the INFO logs, so we get at least 2 records.
|
|
41
|
+
assert.ok(flattened.length < 501, `Expected merged log count to be less than 501, got ${flattened.length}`);
|
|
42
|
+
assert.ok(flattened.length >= 2, `Expected at least 2 merged records (WARN + INFO), got ${flattened.length}`);
|
|
43
|
+
// Last merged record should contain line-500
|
|
44
|
+
assert.match(flattened.at(-1)?.message ?? "", /line-500/);
|
|
45
|
+
});
|
|
46
|
+
test("TriggerLogReporter sends heartbeat flushes on interval and start is idempotent", async () => {
|
|
47
|
+
const payloads = [];
|
|
48
|
+
const intervals = [];
|
|
49
|
+
const intervalHandles = [];
|
|
50
|
+
const originalSetInterval = globalThis.setInterval;
|
|
51
|
+
const originalClearInterval = globalThis.clearInterval;
|
|
52
|
+
globalThis.setInterval = ((callback) => {
|
|
53
|
+
intervals.push(callback);
|
|
54
|
+
const handle = {};
|
|
55
|
+
intervalHandles.push(handle);
|
|
56
|
+
return handle;
|
|
57
|
+
});
|
|
58
|
+
globalThis.clearInterval = ((handle) => {
|
|
59
|
+
assert.equal(intervalHandles.includes(handle), true);
|
|
60
|
+
});
|
|
61
|
+
try {
|
|
62
|
+
const client = {
|
|
63
|
+
appendTriggerLogs: async (_triggerId, payload) => {
|
|
64
|
+
payloads.push(payload);
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
const reporter = new TriggerLogReporter(client, "trigger-1", 10);
|
|
68
|
+
reporter.start();
|
|
69
|
+
reporter.start();
|
|
70
|
+
assert.equal(intervals.length, 1);
|
|
71
|
+
await intervals[0]?.();
|
|
72
|
+
await reporter.stop();
|
|
73
|
+
assert.equal(payloads[0]?.heartbeat, true);
|
|
74
|
+
assert.equal(payloads[0]?.logs, undefined);
|
|
75
|
+
}
|
|
76
|
+
finally {
|
|
77
|
+
globalThis.setInterval = originalSetInterval;
|
|
78
|
+
globalThis.clearInterval = originalClearInterval;
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
test("TriggerLogReporter logs warnings when log delivery fails", async () => {
|
|
82
|
+
const warnings = [];
|
|
83
|
+
mock.method(logger, "warn", (message, meta) => {
|
|
84
|
+
warnings.push({ message, meta });
|
|
85
|
+
});
|
|
86
|
+
const client = {
|
|
87
|
+
appendTriggerLogs: async () => {
|
|
88
|
+
throw new Error("network down");
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
const reporter = new TriggerLogReporter(client, "trigger-1");
|
|
92
|
+
reporter.append("ERROR", "failure");
|
|
93
|
+
await reporter.stop();
|
|
94
|
+
assert.equal(warnings.length, 1);
|
|
95
|
+
assert.match(warnings[0]?.message ?? "", /Failed to report trigger logs/);
|
|
96
|
+
assert.equal(warnings[0]?.meta?.payloadSize, 1);
|
|
97
|
+
});
|
|
98
|
+
test("mergeLogs merges consecutive same-level logs with newline separator", () => {
|
|
99
|
+
const result = mergeLogs([
|
|
100
|
+
{ level: "INFO", message: "line 1" },
|
|
101
|
+
{ level: "INFO", message: "line 2" },
|
|
102
|
+
{ level: "INFO", message: "line 3" }
|
|
103
|
+
]);
|
|
104
|
+
assert.equal(result.length, 1);
|
|
105
|
+
assert.equal(result[0].level, "INFO");
|
|
106
|
+
assert.equal(result[0].message, "line 1\nline 2\nline 3");
|
|
107
|
+
});
|
|
108
|
+
test("mergeLogs splits at level boundaries", () => {
|
|
109
|
+
const result = mergeLogs([
|
|
110
|
+
{ level: "INFO", message: "info 1" },
|
|
111
|
+
{ level: "INFO", message: "info 2" },
|
|
112
|
+
{ level: "WARN", message: "warn 1" },
|
|
113
|
+
{ level: "INFO", message: "info 3" }
|
|
114
|
+
]);
|
|
115
|
+
assert.equal(result.length, 3);
|
|
116
|
+
assert.deepEqual(result[0], { level: "INFO", message: "info 1\ninfo 2" });
|
|
117
|
+
assert.deepEqual(result[1], { level: "WARN", message: "warn 1" });
|
|
118
|
+
assert.deepEqual(result[2], { level: "INFO", message: "info 3" });
|
|
119
|
+
});
|
|
120
|
+
test("mergeLogs splits when combined message exceeds 2000 chars", () => {
|
|
121
|
+
const longMessage = "x".repeat(1500);
|
|
122
|
+
const result = mergeLogs([
|
|
123
|
+
{ level: "INFO", message: longMessage },
|
|
124
|
+
{ level: "INFO", message: longMessage }
|
|
125
|
+
]);
|
|
126
|
+
assert.equal(result.length, 2);
|
|
127
|
+
assert.equal(result[0].message, longMessage);
|
|
128
|
+
assert.equal(result[1].message, longMessage);
|
|
129
|
+
});
|
|
130
|
+
test("mergeLogs returns empty array for empty input", () => {
|
|
131
|
+
assert.deepEqual(mergeLogs([]), []);
|
|
132
|
+
});
|
|
133
|
+
test("TriggerLogReporter merges same-level logs during flush", async () => {
|
|
134
|
+
const payloads = [];
|
|
135
|
+
const client = {
|
|
136
|
+
appendTriggerLogs: async (_triggerId, payload) => {
|
|
137
|
+
payloads.push(payload);
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
const reporter = new TriggerLogReporter(client, "trigger-1");
|
|
141
|
+
reporter.append("INFO", "line 1");
|
|
142
|
+
reporter.append("INFO", "line 2");
|
|
143
|
+
reporter.append("WARN", "warning");
|
|
144
|
+
reporter.append("INFO", "line 3");
|
|
145
|
+
await reporter.stop();
|
|
146
|
+
const logs = payloads.flatMap((p) => p.logs ?? []);
|
|
147
|
+
assert.equal(logs.length, 3);
|
|
148
|
+
assert.deepEqual(logs[0], { level: "INFO", message: "line 1\nline 2" });
|
|
149
|
+
assert.deepEqual(logs[1], { level: "WARN", message: "warning" });
|
|
150
|
+
assert.deepEqual(logs[2], { level: "INFO", message: "line 3" });
|
|
151
|
+
});
|
|
152
|
+
//# sourceMappingURL=log-reporter.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-reporter.test.js","sourceRoot":"","sources":["../../src/runners/log-reporter.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,304 @@
|
|
|
1
|
+
import { createWriteStream } from "node:fs";
|
|
2
|
+
import { execFileSync, spawn } from "node:child_process";
|
|
3
|
+
import { mkdir } from "node:fs/promises";
|
|
4
|
+
import { platform } from "node:os";
|
|
5
|
+
import { dirname, join } from "node:path";
|
|
6
|
+
import { describeExecutableResolution, resolveExecutablePathWithPreference, spawnExecutable } from "../executable.js";
|
|
7
|
+
import { logger } from "../logger.js";
|
|
8
|
+
const FORCE_KILL_AFTER_MS = 10_000;
|
|
9
|
+
const PROMPT_PREVIEW_MAX = 500;
|
|
10
|
+
const OUTPUT_PREVIEW_MAX = 400;
|
|
11
|
+
const OUTPUT_CAPTURE_MAX = 200_000;
|
|
12
|
+
const toPowerShellEncodedCommand = (resolvedExecutablePath, prompt, model) => {
|
|
13
|
+
const modelSegment = model ? ` '--model' '${model.replaceAll("'", "''")}'` : "";
|
|
14
|
+
const scriptContent = [
|
|
15
|
+
"$ErrorActionPreference = 'Stop'",
|
|
16
|
+
"$utf8NoBom = [System.Text.UTF8Encoding]::new($false)",
|
|
17
|
+
"[Console]::InputEncoding = $utf8NoBom",
|
|
18
|
+
"[Console]::OutputEncoding = $utf8NoBom",
|
|
19
|
+
"$OutputEncoding = $utf8NoBom",
|
|
20
|
+
"chcp 65001 > $null",
|
|
21
|
+
`$promptText = @'`,
|
|
22
|
+
`${prompt.replaceAll("'@", "'@")}`,
|
|
23
|
+
`'@`,
|
|
24
|
+
`$promptText | & '${resolvedExecutablePath.replaceAll("'", "''")}' 'run'${modelSegment}`
|
|
25
|
+
].join("\r\n");
|
|
26
|
+
return Buffer.from(scriptContent, "utf16le").toString("base64");
|
|
27
|
+
};
|
|
28
|
+
const toPromptPreview = (prompt) => {
|
|
29
|
+
if (prompt.length <= PROMPT_PREVIEW_MAX) {
|
|
30
|
+
return prompt;
|
|
31
|
+
}
|
|
32
|
+
return `${prompt.slice(0, PROMPT_PREVIEW_MAX)}...`;
|
|
33
|
+
};
|
|
34
|
+
const toOutputPreview = (chunk) => {
|
|
35
|
+
const text = (typeof chunk === "string" ? chunk : String(chunk)).trim();
|
|
36
|
+
if (text.length <= OUTPUT_PREVIEW_MAX) {
|
|
37
|
+
return text;
|
|
38
|
+
}
|
|
39
|
+
return `${text.slice(0, OUTPUT_PREVIEW_MAX)}...`;
|
|
40
|
+
};
|
|
41
|
+
const terminateRunnerChild = (child, isWindows, triggerId, reason) => {
|
|
42
|
+
if (!child.pid) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
logger.warn(reason === "cancel" ? "Runner cancellation requested; sending SIGTERM" : "Runner fail-safe timeout reached; sending SIGTERM", {
|
|
46
|
+
triggerId,
|
|
47
|
+
pid: child.pid
|
|
48
|
+
});
|
|
49
|
+
try {
|
|
50
|
+
if (isWindows) {
|
|
51
|
+
execFileSync("taskkill", ["/F", "/T", "/PID", String(child.pid)], { stdio: "ignore" });
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
process.kill(-child.pid, "SIGTERM");
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
catch {
|
|
58
|
+
// ignore
|
|
59
|
+
}
|
|
60
|
+
if (!isWindows) {
|
|
61
|
+
setTimeout(() => {
|
|
62
|
+
try {
|
|
63
|
+
if (child.pid) {
|
|
64
|
+
process.kill(-child.pid, "SIGKILL");
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch {
|
|
68
|
+
// ignore
|
|
69
|
+
}
|
|
70
|
+
}, FORCE_KILL_AFTER_MS);
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
export class OpenCodeRunner {
|
|
74
|
+
runnerCmd;
|
|
75
|
+
constructor(runnerCmd = "opencode") {
|
|
76
|
+
this.runnerCmd = runnerCmd;
|
|
77
|
+
}
|
|
78
|
+
async run(opts) {
|
|
79
|
+
if (!opts.authPath || opts.authPath.trim().length === 0) {
|
|
80
|
+
logger.error("authPath is missing for trigger");
|
|
81
|
+
return {
|
|
82
|
+
exitCode: 1,
|
|
83
|
+
errorMessage: "authPath is missing for trigger"
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
const cwd = opts.authPath;
|
|
87
|
+
const logPath = join(cwd, ".agentteams", "runner", "log", `${opts.triggerId}.log`);
|
|
88
|
+
await mkdir(dirname(logPath), { recursive: true });
|
|
89
|
+
const isWindows = platform() === "win32";
|
|
90
|
+
const resolvedExecutablePath = isWindows
|
|
91
|
+
? resolveExecutablePathWithPreference(this.runnerCmd, [`${this.runnerCmd}.cmd`, this.runnerCmd])
|
|
92
|
+
: resolveExecutablePathWithPreference(this.runnerCmd, [this.runnerCmd]);
|
|
93
|
+
const windowsEncodedCommand = isWindows
|
|
94
|
+
? toPowerShellEncodedCommand(resolvedExecutablePath, opts.prompt, opts.model)
|
|
95
|
+
: null;
|
|
96
|
+
const executableInfo = describeExecutableResolution(this.runnerCmd, {
|
|
97
|
+
platform: () => (isWindows ? "win32" : platform())
|
|
98
|
+
});
|
|
99
|
+
logger.info("Runner prompt", {
|
|
100
|
+
triggerId: opts.triggerId,
|
|
101
|
+
promptLength: opts.prompt.length,
|
|
102
|
+
promptPreview: toPromptPreview(opts.prompt),
|
|
103
|
+
requestedCommand: executableInfo.requestedCommand,
|
|
104
|
+
resolvedExecutablePath,
|
|
105
|
+
platform: executableInfo.platform,
|
|
106
|
+
shell: executableInfo.shell,
|
|
107
|
+
detached: isWindows ? false : true,
|
|
108
|
+
windowsWrapper: isWindows ? "powershell.exe -EncodedCommand" : null
|
|
109
|
+
});
|
|
110
|
+
const modelArgs = opts.model ? ["--model", opts.model] : [];
|
|
111
|
+
const child = isWindows
|
|
112
|
+
? spawn("powershell.exe", [
|
|
113
|
+
"-NoLogo",
|
|
114
|
+
"-NonInteractive",
|
|
115
|
+
"-ExecutionPolicy",
|
|
116
|
+
"Bypass",
|
|
117
|
+
"-EncodedCommand",
|
|
118
|
+
windowsEncodedCommand ?? ""
|
|
119
|
+
], {
|
|
120
|
+
cwd,
|
|
121
|
+
detached: false,
|
|
122
|
+
shell: false,
|
|
123
|
+
windowsHide: true,
|
|
124
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
125
|
+
env: {
|
|
126
|
+
...process.env,
|
|
127
|
+
AGENTTEAMS_API_KEY: opts.apiKey,
|
|
128
|
+
AGENTTEAMS_API_URL: opts.apiUrl,
|
|
129
|
+
AGENTTEAMS_TEAM_ID: opts.teamId,
|
|
130
|
+
AGENTTEAMS_PROJECT_ID: opts.projectId,
|
|
131
|
+
AGENTTEAMS_AGENT_NAME: opts.agentConfigId
|
|
132
|
+
}
|
|
133
|
+
})
|
|
134
|
+
: spawnExecutable(this.runnerCmd, ["run", ...modelArgs, opts.prompt], {
|
|
135
|
+
cwd,
|
|
136
|
+
detached: true,
|
|
137
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
138
|
+
env: {
|
|
139
|
+
...process.env,
|
|
140
|
+
AGENTTEAMS_API_KEY: opts.apiKey,
|
|
141
|
+
AGENTTEAMS_API_URL: opts.apiUrl,
|
|
142
|
+
AGENTTEAMS_TEAM_ID: opts.teamId,
|
|
143
|
+
AGENTTEAMS_PROJECT_ID: opts.projectId,
|
|
144
|
+
AGENTTEAMS_AGENT_NAME: opts.agentConfigId
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
const logStream = createWriteStream(logPath, { flags: "a" });
|
|
148
|
+
logStream.on("error", (err) => {
|
|
149
|
+
logger.warn("Runner log stream error", { triggerId: opts.triggerId, error: err.message });
|
|
150
|
+
});
|
|
151
|
+
child.stdout?.pipe(logStream);
|
|
152
|
+
child.stderr?.pipe(logStream);
|
|
153
|
+
let lastOutput = "";
|
|
154
|
+
let lastErrorOutput = "";
|
|
155
|
+
let outputText = "";
|
|
156
|
+
const appendOutputText = (chunk) => {
|
|
157
|
+
if (outputText.length >= OUTPUT_CAPTURE_MAX) {
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
outputText += chunk.slice(0, OUTPUT_CAPTURE_MAX - outputText.length);
|
|
161
|
+
};
|
|
162
|
+
const idleTimer = { reset: () => { } };
|
|
163
|
+
child.stdout?.on("data", (chunk) => {
|
|
164
|
+
const rawOutput = Buffer.isBuffer(chunk) ? chunk.toString("utf8") : String(chunk);
|
|
165
|
+
appendOutputText(rawOutput);
|
|
166
|
+
const output = toOutputPreview(rawOutput);
|
|
167
|
+
if (output.length > 0) {
|
|
168
|
+
lastOutput = output;
|
|
169
|
+
idleTimer.reset();
|
|
170
|
+
opts.onStdoutChunk?.(output);
|
|
171
|
+
logger.info("Runner stdout", {
|
|
172
|
+
triggerId: opts.triggerId,
|
|
173
|
+
pid: child.pid,
|
|
174
|
+
output
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
child.stderr?.on("data", (chunk) => {
|
|
179
|
+
const output = toOutputPreview(Buffer.isBuffer(chunk) ? chunk.toString("utf8") : chunk);
|
|
180
|
+
if (output.length > 0) {
|
|
181
|
+
lastOutput = output;
|
|
182
|
+
lastErrorOutput = output;
|
|
183
|
+
idleTimer.reset();
|
|
184
|
+
opts.onStderrChunk?.(output);
|
|
185
|
+
logger.warn("Runner stderr", {
|
|
186
|
+
triggerId: opts.triggerId,
|
|
187
|
+
pid: child.pid,
|
|
188
|
+
output
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
logger.info("Runner started", {
|
|
193
|
+
triggerId: opts.triggerId,
|
|
194
|
+
cwd,
|
|
195
|
+
logPath,
|
|
196
|
+
pid: child.pid
|
|
197
|
+
});
|
|
198
|
+
return await new Promise((resolve) => {
|
|
199
|
+
let finished = false;
|
|
200
|
+
let timedOut = false;
|
|
201
|
+
let idleTimedOut = false;
|
|
202
|
+
let cancelled = false;
|
|
203
|
+
let idleTimeoutId = null;
|
|
204
|
+
const startIdleTimeout = () => {
|
|
205
|
+
if (idleTimeoutId) {
|
|
206
|
+
clearTimeout(idleTimeoutId);
|
|
207
|
+
}
|
|
208
|
+
idleTimeoutId = setTimeout(() => {
|
|
209
|
+
idleTimedOut = true;
|
|
210
|
+
timedOut = true;
|
|
211
|
+
logger.warn("Runner idle timeout reached; no output for configured idle period", {
|
|
212
|
+
triggerId: opts.triggerId,
|
|
213
|
+
idleTimeoutMs: opts.idleTimeoutMs
|
|
214
|
+
});
|
|
215
|
+
terminateRunnerChild(child, isWindows, opts.triggerId, "timeout");
|
|
216
|
+
}, opts.idleTimeoutMs);
|
|
217
|
+
};
|
|
218
|
+
idleTimer.reset = () => {
|
|
219
|
+
startIdleTimeout();
|
|
220
|
+
};
|
|
221
|
+
startIdleTimeout();
|
|
222
|
+
const cleanup = () => {
|
|
223
|
+
if (finished) {
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
finished = true;
|
|
227
|
+
if (idleTimeoutId) {
|
|
228
|
+
clearTimeout(idleTimeoutId);
|
|
229
|
+
}
|
|
230
|
+
idleTimer.reset = () => { };
|
|
231
|
+
logStream.end();
|
|
232
|
+
if (opts.signal) {
|
|
233
|
+
opts.signal.removeEventListener("abort", handleAbort);
|
|
234
|
+
}
|
|
235
|
+
};
|
|
236
|
+
const handleAbort = () => {
|
|
237
|
+
cancelled = true;
|
|
238
|
+
terminateRunnerChild(child, isWindows, opts.triggerId, "cancel");
|
|
239
|
+
};
|
|
240
|
+
const timeoutId = setTimeout(() => {
|
|
241
|
+
timedOut = true;
|
|
242
|
+
terminateRunnerChild(child, isWindows, opts.triggerId, "timeout");
|
|
243
|
+
}, opts.timeoutMs);
|
|
244
|
+
if (opts.signal?.aborted) {
|
|
245
|
+
handleAbort();
|
|
246
|
+
}
|
|
247
|
+
else if (opts.signal) {
|
|
248
|
+
opts.signal.addEventListener("abort", handleAbort, { once: true });
|
|
249
|
+
}
|
|
250
|
+
child.on("error", (error) => {
|
|
251
|
+
clearTimeout(timeoutId);
|
|
252
|
+
cleanup();
|
|
253
|
+
logger.error("Runner process launch failed", {
|
|
254
|
+
triggerId: opts.triggerId,
|
|
255
|
+
error: error.message
|
|
256
|
+
});
|
|
257
|
+
resolve({
|
|
258
|
+
exitCode: 1,
|
|
259
|
+
lastOutput,
|
|
260
|
+
outputText: outputText.trim() || undefined,
|
|
261
|
+
errorMessage: error.message
|
|
262
|
+
});
|
|
263
|
+
});
|
|
264
|
+
child.on("close", (code) => {
|
|
265
|
+
clearTimeout(timeoutId);
|
|
266
|
+
cleanup();
|
|
267
|
+
logger.info("Runner process closed", {
|
|
268
|
+
triggerId: opts.triggerId,
|
|
269
|
+
pid: child.pid,
|
|
270
|
+
exitCode: code,
|
|
271
|
+
timedOut
|
|
272
|
+
});
|
|
273
|
+
if (timedOut) {
|
|
274
|
+
resolve({
|
|
275
|
+
exitCode: 1,
|
|
276
|
+
lastOutput,
|
|
277
|
+
outputText: outputText.trim() || undefined,
|
|
278
|
+
errorMessage: idleTimedOut
|
|
279
|
+
? `Runner idle timed out after ${Math.round(opts.idleTimeoutMs / 60_000)}m of no output`
|
|
280
|
+
: `Runner fail-safe timed out after ${Math.round(opts.timeoutMs / 3_600_000)}h`
|
|
281
|
+
});
|
|
282
|
+
return;
|
|
283
|
+
}
|
|
284
|
+
if (cancelled) {
|
|
285
|
+
resolve({
|
|
286
|
+
exitCode: 1,
|
|
287
|
+
cancelled: true,
|
|
288
|
+
lastOutput,
|
|
289
|
+
outputText: outputText.trim() || undefined,
|
|
290
|
+
errorMessage: "Runner cancelled by user"
|
|
291
|
+
});
|
|
292
|
+
return;
|
|
293
|
+
}
|
|
294
|
+
resolve({
|
|
295
|
+
exitCode: code ?? 1,
|
|
296
|
+
lastOutput,
|
|
297
|
+
outputText: outputText.trim() || undefined,
|
|
298
|
+
errorMessage: code === 0 ? undefined : (lastErrorOutput || lastOutput || `Runner exited with code ${code ?? 1}`)
|
|
299
|
+
});
|
|
300
|
+
});
|
|
301
|
+
});
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
//# sourceMappingURL=opencode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"opencode.js","sourceRoot":"","sources":["../../src/runners/opencode.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parses Claude Code / AMP compatible stream-json lines into structured log entries.
|
|
3
|
+
* Shared by claude-code and amp runners to convert raw JSON output into human-readable logs.
|
|
4
|
+
*/
|
|
5
|
+
export type ParsedLogEntry = {
|
|
6
|
+
level: "INFO" | "WARN";
|
|
7
|
+
message: string;
|
|
8
|
+
};
|
|
9
|
+
export declare const parseStreamJsonLine: (line: string) => ParsedLogEntry[];
|
|
10
|
+
/**
|
|
11
|
+
* Creates a line-buffered parser that handles chunked stdout data.
|
|
12
|
+
* Stream data may arrive as partial lines, so this buffers until newlines.
|
|
13
|
+
*/
|
|
14
|
+
export declare const createStreamJsonLineParser: (onEntries: (entries: ParsedLogEntry[]) => void) => {
|
|
15
|
+
push: (chunk: string) => void;
|
|
16
|
+
flush: () => void;
|
|
17
|
+
};
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parses Claude Code / AMP compatible stream-json lines into structured log entries.
|
|
3
|
+
* Shared by claude-code and amp runners to convert raw JSON output into human-readable logs.
|
|
4
|
+
*/
|
|
5
|
+
const THINKING_PREVIEW_MAX = 300;
|
|
6
|
+
const TEXT_PREVIEW_MAX = 500;
|
|
7
|
+
const TOOL_INPUT_PREVIEW_MAX = 200;
|
|
8
|
+
const truncate = (text, max) => text.length <= max ? text : `${text.slice(0, max)}...`;
|
|
9
|
+
export const parseStreamJsonLine = (line) => {
|
|
10
|
+
const trimmed = line.trim();
|
|
11
|
+
if (trimmed.length === 0) {
|
|
12
|
+
return [];
|
|
13
|
+
}
|
|
14
|
+
let parsed;
|
|
15
|
+
try {
|
|
16
|
+
parsed = JSON.parse(trimmed);
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
return [];
|
|
20
|
+
}
|
|
21
|
+
if (!parsed.type) {
|
|
22
|
+
return [];
|
|
23
|
+
}
|
|
24
|
+
const entries = [];
|
|
25
|
+
switch (parsed.type) {
|
|
26
|
+
case "system": {
|
|
27
|
+
if (parsed.subtype === "init") {
|
|
28
|
+
const toolCount = parsed.tools?.length ?? 0;
|
|
29
|
+
const model = parsed.model ?? "unknown";
|
|
30
|
+
entries.push({ level: "INFO", message: `Session initialized (model=${model}, tools=${toolCount})` });
|
|
31
|
+
}
|
|
32
|
+
break;
|
|
33
|
+
}
|
|
34
|
+
case "assistant": {
|
|
35
|
+
const content = parsed.message?.content;
|
|
36
|
+
if (!Array.isArray(content)) {
|
|
37
|
+
break;
|
|
38
|
+
}
|
|
39
|
+
for (const block of content) {
|
|
40
|
+
switch (block.type) {
|
|
41
|
+
case "thinking": {
|
|
42
|
+
const thinking = block.thinking;
|
|
43
|
+
if (thinking && thinking.trim().length > 0) {
|
|
44
|
+
entries.push({ level: "INFO", message: `[Thinking] ${truncate(thinking.trim(), THINKING_PREVIEW_MAX)}` });
|
|
45
|
+
}
|
|
46
|
+
break;
|
|
47
|
+
}
|
|
48
|
+
case "text": {
|
|
49
|
+
const text = block.text;
|
|
50
|
+
if (text && text.trim().length > 0) {
|
|
51
|
+
entries.push({ level: "INFO", message: truncate(text.trim(), TEXT_PREVIEW_MAX) });
|
|
52
|
+
}
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
case "tool_use": {
|
|
56
|
+
const toolBlock = block;
|
|
57
|
+
const name = toolBlock.name ?? "unknown";
|
|
58
|
+
const inputPreview = toolBlock.input
|
|
59
|
+
? truncate(JSON.stringify(toolBlock.input), TOOL_INPUT_PREVIEW_MAX)
|
|
60
|
+
: "";
|
|
61
|
+
entries.push({ level: "INFO", message: inputPreview ? `[Tool] ${name}: ${inputPreview}` : `[Tool] ${name}` });
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
default:
|
|
65
|
+
break;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
case "result": {
|
|
71
|
+
const duration = parsed.duration_ms ? `${Math.round(parsed.duration_ms / 1000)}s` : "unknown";
|
|
72
|
+
const turns = parsed.num_turns ?? 0;
|
|
73
|
+
if (parsed.is_error) {
|
|
74
|
+
const result = parsed.result ?? "Unknown error";
|
|
75
|
+
entries.push({ level: "WARN", message: `[Result] Error after ${duration} (${turns} turns): ${truncate(result, TEXT_PREVIEW_MAX)}` });
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
entries.push({ level: "INFO", message: `[Result] Completed in ${duration} (${turns} turns)` });
|
|
79
|
+
}
|
|
80
|
+
break;
|
|
81
|
+
}
|
|
82
|
+
default:
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
85
|
+
return entries;
|
|
86
|
+
};
|
|
87
|
+
/**
|
|
88
|
+
* Creates a line-buffered parser that handles chunked stdout data.
|
|
89
|
+
* Stream data may arrive as partial lines, so this buffers until newlines.
|
|
90
|
+
*/
|
|
91
|
+
export const createStreamJsonLineParser = (onEntries) => {
|
|
92
|
+
let buffer = "";
|
|
93
|
+
return {
|
|
94
|
+
push(chunk) {
|
|
95
|
+
buffer += chunk;
|
|
96
|
+
const lines = buffer.split("\n");
|
|
97
|
+
buffer = lines.pop() ?? "";
|
|
98
|
+
for (const line of lines) {
|
|
99
|
+
const entries = parseStreamJsonLine(line);
|
|
100
|
+
if (entries.length > 0) {
|
|
101
|
+
onEntries(entries);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
flush() {
|
|
106
|
+
if (buffer.trim().length > 0) {
|
|
107
|
+
const entries = parseStreamJsonLine(buffer);
|
|
108
|
+
if (entries.length > 0) {
|
|
109
|
+
onEntries(entries);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
buffer = "";
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
};
|
|
116
|
+
//# sourceMappingURL=stream-json-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-json-parser.js","sourceRoot":"","sources":["../../src/runners/stream-json-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export interface Runner {
|
|
2
|
+
run(opts: RunnerOptions): Promise<RunResult>;
|
|
3
|
+
}
|
|
4
|
+
export interface RunnerOptions {
|
|
5
|
+
triggerId: string;
|
|
6
|
+
prompt: string;
|
|
7
|
+
authPath: string | null;
|
|
8
|
+
apiKey: string;
|
|
9
|
+
apiUrl: string;
|
|
10
|
+
teamId: string;
|
|
11
|
+
projectId: string;
|
|
12
|
+
timeoutMs: number;
|
|
13
|
+
idleTimeoutMs: number;
|
|
14
|
+
agentConfigId: string;
|
|
15
|
+
model?: string | null;
|
|
16
|
+
signal?: AbortSignal;
|
|
17
|
+
onStdoutChunk?: (chunk: string) => void;
|
|
18
|
+
onStderrChunk?: (chunk: string) => void;
|
|
19
|
+
}
|
|
20
|
+
export type RunResult = {
|
|
21
|
+
exitCode: number;
|
|
22
|
+
cancelled?: boolean;
|
|
23
|
+
lastOutput?: string;
|
|
24
|
+
outputText?: string;
|
|
25
|
+
errorMessage?: string;
|
|
26
|
+
};
|