Files
openclaw/src/plugins/wired-hooks-gateway.test.ts
2026-02-15 14:44:15 +00:00

41 lines
1.6 KiB
TypeScript

/**
* Test: gateway_start & gateway_stop hook wiring (server.impl.ts)
*
* Since startGatewayServer is heavily integrated, we test the hook runner
* calls at the unit level by verifying the hook runner functions exist
* and validating the integration pattern.
*/
import { describe, expect, it, vi } from "vitest";
import { createHookRunner } from "./hooks.js";
import { createMockPluginRegistry } from "./hooks.test-helpers.js";
describe("gateway hook runner methods", () => {
it("runGatewayStart invokes registered gateway_start hooks", async () => {
const handler = vi.fn();
const registry = createMockPluginRegistry([{ hookName: "gateway_start", handler }]);
const runner = createHookRunner(registry);
await runner.runGatewayStart({ port: 18789 }, { port: 18789 });
expect(handler).toHaveBeenCalledWith({ port: 18789 }, { port: 18789 });
});
it("runGatewayStop invokes registered gateway_stop hooks", async () => {
const handler = vi.fn();
const registry = createMockPluginRegistry([{ hookName: "gateway_stop", handler }]);
const runner = createHookRunner(registry);
await runner.runGatewayStop({ reason: "test shutdown" }, { port: 18789 });
expect(handler).toHaveBeenCalledWith({ reason: "test shutdown" }, { port: 18789 });
});
it("hasHooks returns true for registered gateway hooks", () => {
const registry = createMockPluginRegistry([{ hookName: "gateway_start", handler: vi.fn() }]);
const runner = createHookRunner(registry);
expect(runner.hasHooks("gateway_start")).toBe(true);
expect(runner.hasHooks("gateway_stop")).toBe(false);
});
});