import { describe, expect, it, vi } from "vitest"; const mocks = vi.hoisted(() => ({ loadSessionStore: vi.fn().mockReturnValue({ "+1000": { updatedAt: Date.now() - 60_000, verboseLevel: "on", thinkingLevel: "low", inputTokens: 2_000, outputTokens: 3_000, contextTokens: 10_000, model: "pi:opus", sessionId: "abc123", systemSent: true, }, }), resolveMainSessionKey: vi.fn().mockReturnValue("agent:main:main"), resolveStorePath: vi.fn().mockReturnValue("/tmp/sessions.json"), webAuthExists: vi.fn().mockResolvedValue(true), getWebAuthAgeMs: vi.fn().mockReturnValue(5000), readWebSelfId: vi.fn().mockReturnValue({ e164: "+1999" }), logWebSelfId: vi.fn(), })); vi.mock("../config/sessions.js", () => ({ loadSessionStore: mocks.loadSessionStore, resolveMainSessionKey: mocks.resolveMainSessionKey, resolveStorePath: mocks.resolveStorePath, })); vi.mock("../web/session.js", () => ({ webAuthExists: mocks.webAuthExists, getWebAuthAgeMs: mocks.getWebAuthAgeMs, readWebSelfId: mocks.readWebSelfId, logWebSelfId: mocks.logWebSelfId, })); vi.mock("../config/config.js", async (importOriginal) => { const actual = await importOriginal(); return { ...actual, loadConfig: () => ({ session: {} }), }; }); vi.mock("../daemon/service.js", () => ({ resolveGatewayService: () => ({ label: "LaunchAgent", loadedText: "loaded", notLoadedText: "not loaded", isLoaded: async () => true, readRuntime: async () => ({ status: "running", pid: 1234 }), }), })); import { statusCommand } from "./status.js"; const runtime = { log: vi.fn(), error: vi.fn(), exit: vi.fn(), }; describe("statusCommand", () => { it("prints JSON when requested", async () => { await statusCommand({ json: true }, runtime as never); const payload = JSON.parse((runtime.log as vi.Mock).mock.calls[0][0]); expect(payload.web.linked).toBe(true); expect(payload.sessions.count).toBe(1); expect(payload.sessions.path).toBe("/tmp/sessions.json"); expect(payload.sessions.defaults.model).toBeTruthy(); expect(payload.sessions.defaults.contextTokens).toBeGreaterThan(0); expect(payload.sessions.recent[0].percentUsed).toBe(50); expect(payload.sessions.recent[0].remainingTokens).toBe(5000); expect(payload.sessions.recent[0].flags).toContain("verbose:on"); }); it("prints formatted lines otherwise", async () => { (runtime.log as vi.Mock).mockClear(); await statusCommand({}, runtime as never); const logs = (runtime.log as vi.Mock).mock.calls.map((c) => String(c[0])); expect(logs.some((l) => l.includes("Web session"))).toBe(true); expect(logs.some((l) => l.includes("Active sessions"))).toBe(true); expect(logs.some((l) => l.includes("Default model"))).toBe(true); expect(logs.some((l) => l.includes("tokens:"))).toBe(true); expect(logs.some((l) => l.includes("Daemon:"))).toBe(true); expect(logs.some((l) => l.includes("FAQ:"))).toBe(true); expect(logs.some((l) => l.includes("Troubleshooting:"))).toBe(true); expect( logs.some((l) => l.includes("flags:") && l.includes("verbose:on")), ).toBe(true); expect(mocks.logWebSelfId).toHaveBeenCalled(); }); });