import { Command } from "commander" ;
import { beforeEach, describe, expect, it, vi } from "vitest" ;
import { createCliRuntimeCapture } from "./test-runtime-capture.js" ;
const callGatewayFromCli = vi.fn();
const addGatewayClientOptions = vi.fn((command: Command) => command);
const { runtimeLogs, runtimeErrors, defaultRuntime, resetRuntimeCapture } =
createCliRuntimeCapture();
vi.mock("./gateway-rpc.js" , () => ({
addGatewayClientOptions,
callGatewayFromCli,
}));
vi.mock("../runtime.js" , async () => ({
...(await vi.importActual<typeof import ("../runtime.js" )>("../runtime.js" )),
defaultRuntime,
writeRuntimeJson: (runtime: { log: (...args: unknown[]) => void }, value: unknown, space = 2 ) =>
runtime.log(JSON.stringify(value, null , space > 0 ? space : undefined)),
}));
const { registerSystemCli } = await import ("./system-cli.js" );
describe("system-cli" , () => {
async function runCli(args: string[]) {
const program = new Command();
registerSystemCli(program);
try {
await program.parseAsync(args, { from: "user" });
} catch (err) {
if (!(err instanceof Error && err.message.startsWith("__exit__:" ))) {
throw err;
}
}
}
beforeEach(() => {
vi.clearAllMocks();
resetRuntimeCapture();
callGatewayFromCli.mockResolvedValue({ ok: true });
});
it("runs system event with default wake mode and text output" , async () => {
await runCli(["system" , "event" , "--text" , " hello world " ]);
expect(callGatewayFromCli).toHaveBeenCalledWith(
"wake" ,
expect.objectContaining({ text: " hello world " }),
{ mode: "next-heartbeat" , text: "hello world" },
{ expectFinal: false },
);
expect(runtimeLogs).toEqual(["ok" ]);
});
it("prints JSON for event when --json is enabled" , async () => {
callGatewayFromCli.mockResolvedValueOnce({ id: "wake-1" });
await runCli(["system" , "event" , "--text" , "hello" , "--json" ]);
expect(runtimeLogs).toEqual([JSON.stringify({ id: "wake-1" }, null , 2 )]);
});
it("handles invalid wake mode as runtime error" , async () => {
await runCli(["system" , "event" , "--text" , "hello" , "--mode" , "later" ]);
expect(callGatewayFromCli).not.toHaveBeenCalled();
expect(runtimeErrors[0 ]).toContain("--mode must be now or next-heartbeat" );
});
it.each([
{ args: ["system" , "heartbeat" , "last" ], method: "last-heartbeat" , params: undefined },
{
args: ["system" , "heartbeat" , "enable" ],
method: "set-heartbeats" ,
params: { enabled: true },
},
{
args: ["system" , "heartbeat" , "disable" ],
method: "set-heartbeats" ,
params: { enabled: false },
},
{ args: ["system" , "presence" ], method: "system-presence" , params: undefined },
])("routes $args to gateway" , async ({ args, method, params }) => {
callGatewayFromCli.mockResolvedValueOnce({ method });
await runCli(args);
expect(callGatewayFromCli).toHaveBeenCalledWith(method, expect.any(Object), params, {
expectFinal: false ,
});
expect(runtimeLogs).toEqual([JSON.stringify({ method }, null , 2 )]);
});
});
Messung V0.5 in Prozent C=100 H=100 G=100
¤ Dauer der Verarbeitung: 0.9 Sekunden
(vorverarbeitet am 2026-06-09)
¤
*© Formatika GbR, Deutschland