refactor(test): share plugin hook registry helper
This commit is contained in:
@@ -4,37 +4,13 @@
|
||||
* Tests the hook runner methods directly since outbound delivery is deeply integrated.
|
||||
*/
|
||||
import { describe, expect, it, vi } from "vitest";
|
||||
import type { PluginRegistry } from "./registry.js";
|
||||
import { createHookRunner } from "./hooks.js";
|
||||
|
||||
function createMockRegistry(
|
||||
hooks: Array<{ hookName: string; handler: (...args: unknown[]) => unknown }>,
|
||||
): PluginRegistry {
|
||||
return {
|
||||
hooks: hooks as never[],
|
||||
typedHooks: hooks.map((h) => ({
|
||||
pluginId: "test-plugin",
|
||||
hookName: h.hookName,
|
||||
handler: h.handler,
|
||||
priority: 0,
|
||||
source: "test",
|
||||
})),
|
||||
tools: [],
|
||||
httpHandlers: [],
|
||||
httpRoutes: [],
|
||||
channelRegistrations: [],
|
||||
gatewayHandlers: {},
|
||||
cliRegistrars: [],
|
||||
services: [],
|
||||
providers: [],
|
||||
commands: [],
|
||||
} as unknown as PluginRegistry;
|
||||
}
|
||||
import { createMockPluginRegistry } from "./hooks.test-helpers.js";
|
||||
|
||||
describe("message_sending hook runner", () => {
|
||||
it("runMessageSending invokes registered hooks and returns modified content", async () => {
|
||||
const handler = vi.fn().mockReturnValue({ content: "modified content" });
|
||||
const registry = createMockRegistry([{ hookName: "message_sending", handler }]);
|
||||
const registry = createMockPluginRegistry([{ hookName: "message_sending", handler }]);
|
||||
const runner = createHookRunner(registry);
|
||||
|
||||
const result = await runner.runMessageSending(
|
||||
@@ -51,7 +27,7 @@ describe("message_sending hook runner", () => {
|
||||
|
||||
it("runMessageSending can cancel message delivery", async () => {
|
||||
const handler = vi.fn().mockReturnValue({ cancel: true });
|
||||
const registry = createMockRegistry([{ hookName: "message_sending", handler }]);
|
||||
const registry = createMockPluginRegistry([{ hookName: "message_sending", handler }]);
|
||||
const runner = createHookRunner(registry);
|
||||
|
||||
const result = await runner.runMessageSending(
|
||||
@@ -66,7 +42,7 @@ describe("message_sending hook runner", () => {
|
||||
describe("message_sent hook runner", () => {
|
||||
it("runMessageSent invokes registered hooks with success=true", async () => {
|
||||
const handler = vi.fn();
|
||||
const registry = createMockRegistry([{ hookName: "message_sent", handler }]);
|
||||
const registry = createMockPluginRegistry([{ hookName: "message_sent", handler }]);
|
||||
const runner = createHookRunner(registry);
|
||||
|
||||
await runner.runMessageSent(
|
||||
@@ -82,7 +58,7 @@ describe("message_sent hook runner", () => {
|
||||
|
||||
it("runMessageSent invokes registered hooks with error on failure", async () => {
|
||||
const handler = vi.fn();
|
||||
const registry = createMockRegistry([{ hookName: "message_sent", handler }]);
|
||||
const registry = createMockPluginRegistry([{ hookName: "message_sent", handler }]);
|
||||
const runner = createHookRunner(registry);
|
||||
|
||||
await runner.runMessageSent(
|
||||
|
||||
Reference in New Issue
Block a user