90 lines
3.1 KiB
TypeScript
90 lines
3.1 KiB
TypeScript
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,
|
|
},
|
|
}),
|
|
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,
|
|
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<typeof import("../config/config.js")>();
|
|
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();
|
|
});
|
|
});
|