diff --git a/src/auto-reply/reply/commands.test.ts b/src/auto-reply/reply/commands.test.ts index b98fbf4ecdc..c0f5a7be067 100644 --- a/src/auto-reply/reply/commands.test.ts +++ b/src/auto-reply/reply/commands.test.ts @@ -377,7 +377,7 @@ describe("handleCommands subagents", () => { const params = buildParams("/subagents list", cfg); const result = await handleCommands(params); expect(result.shouldContinue).toBe(false); - expect(result.reply?.text).toContain("tokens 1k (in 12 / out 1k)"); + expect(result.reply?.text).toMatch(/tokens 1(\.0)?k \(in 12 \/ out 1(\.0)?k\)/); expect(result.reply?.text).toContain("prompt/cache 197k"); expect(result.reply?.text).not.toContain("1k io"); }); diff --git a/src/infra/process-respawn.test.ts b/src/infra/process-respawn.test.ts index 3760abebed1..d7ea3649af3 100644 --- a/src/infra/process-respawn.test.ts +++ b/src/infra/process-respawn.test.ts @@ -34,6 +34,14 @@ afterEach(() => { spawnMock.mockReset(); }); +function clearSupervisorHints() { + delete process.env.LAUNCH_JOB_LABEL; + delete process.env.LAUNCH_JOB_NAME; + delete process.env.INVOCATION_ID; + delete process.env.SYSTEMD_EXEC_PID; + delete process.env.JOURNAL_STREAM; +} + describe("restartGatewayProcessWithFreshPid", () => { it("returns disabled when OPENCLAW_NO_RESPAWN is set", () => { process.env.OPENCLAW_NO_RESPAWN = "1"; @@ -51,7 +59,7 @@ describe("restartGatewayProcessWithFreshPid", () => { it("spawns detached child with current exec argv", () => { delete process.env.OPENCLAW_NO_RESPAWN; - delete process.env.LAUNCH_JOB_LABEL; + clearSupervisorHints(); process.execArgv = ["--import", "tsx"]; process.argv = ["/usr/local/bin/node", "/repo/dist/index.js", "gateway", "run"]; spawnMock.mockReturnValue({ pid: 4242, unref: vi.fn() }); @@ -70,6 +78,9 @@ describe("restartGatewayProcessWithFreshPid", () => { }); it("returns failed when spawn throws", () => { + delete process.env.OPENCLAW_NO_RESPAWN; + clearSupervisorHints(); + spawnMock.mockImplementation(() => { throw new Error("spawn failed"); });