refactor(telegram): share native command test menu helpers
This commit is contained in:
parent
b0dd757ec8
commit
06ae5e9d21
158
extensions/telegram/src/bot-native-commands.menu-test-support.ts
Normal file
158
extensions/telegram/src/bot-native-commands.menu-test-support.ts
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
import { expect, vi } from "vitest";
|
||||||
|
import type { OpenClawConfig } from "../../../src/config/config.js";
|
||||||
|
import type { TelegramAccountConfig } from "../../../src/config/types.js";
|
||||||
|
import type { RuntimeEnv } from "../../../src/runtime.js";
|
||||||
|
|
||||||
|
type NativeCommandBot = {
|
||||||
|
api: {
|
||||||
|
setMyCommands: ReturnType<typeof vi.fn>;
|
||||||
|
sendMessage: ReturnType<typeof vi.fn>;
|
||||||
|
};
|
||||||
|
command: ReturnType<typeof vi.fn>;
|
||||||
|
};
|
||||||
|
|
||||||
|
type RegisterTelegramNativeCommandsParams = {
|
||||||
|
bot: NativeCommandBot;
|
||||||
|
cfg: OpenClawConfig;
|
||||||
|
runtime: RuntimeEnv;
|
||||||
|
accountId: string;
|
||||||
|
telegramCfg: TelegramAccountConfig;
|
||||||
|
allowFrom: string[];
|
||||||
|
groupAllowFrom: string[];
|
||||||
|
replyToMode: string;
|
||||||
|
textLimit: number;
|
||||||
|
useAccessGroups: boolean;
|
||||||
|
nativeEnabled: boolean;
|
||||||
|
nativeSkillsEnabled: boolean;
|
||||||
|
nativeDisabledExplicit: boolean;
|
||||||
|
resolveGroupPolicy: () => { allowlistEnabled: boolean; allowed: boolean };
|
||||||
|
resolveTelegramGroupConfig: () => {
|
||||||
|
groupConfig: undefined;
|
||||||
|
topicConfig: undefined;
|
||||||
|
};
|
||||||
|
shouldSkipUpdate: () => boolean;
|
||||||
|
opts: { token: string };
|
||||||
|
};
|
||||||
|
|
||||||
|
type RegisteredCommand = {
|
||||||
|
command: string;
|
||||||
|
description: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
const skillCommandMocks = vi.hoisted(() => ({
|
||||||
|
listSkillCommandsForAgents: vi.fn(() => []),
|
||||||
|
}));
|
||||||
|
|
||||||
|
const deliveryMocks = vi.hoisted(() => ({
|
||||||
|
deliverReplies: vi.fn(async () => ({ delivered: true })),
|
||||||
|
}));
|
||||||
|
|
||||||
|
export const listSkillCommandsForAgents = skillCommandMocks.listSkillCommandsForAgents;
|
||||||
|
export const deliverReplies = deliveryMocks.deliverReplies;
|
||||||
|
|
||||||
|
vi.mock("../../../src/auto-reply/skill-commands.js", async (importOriginal) => {
|
||||||
|
const actual = await importOriginal<typeof import("../../../src/auto-reply/skill-commands.js")>();
|
||||||
|
return {
|
||||||
|
...actual,
|
||||||
|
listSkillCommandsForAgents,
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
vi.mock("./bot/delivery.js", () => ({
|
||||||
|
deliverReplies,
|
||||||
|
}));
|
||||||
|
|
||||||
|
export async function waitForRegisteredCommands(
|
||||||
|
setMyCommands: ReturnType<typeof vi.fn>,
|
||||||
|
): Promise<RegisteredCommand[]> {
|
||||||
|
await vi.waitFor(() => {
|
||||||
|
expect(setMyCommands).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
return setMyCommands.mock.calls[0]?.[0] as RegisteredCommand[];
|
||||||
|
}
|
||||||
|
|
||||||
|
export function resetNativeCommandMenuMocks() {
|
||||||
|
listSkillCommandsForAgents.mockClear();
|
||||||
|
listSkillCommandsForAgents.mockReturnValue([]);
|
||||||
|
deliverReplies.mockClear();
|
||||||
|
deliverReplies.mockResolvedValue({ delivered: true });
|
||||||
|
}
|
||||||
|
|
||||||
|
export function createCommandBot() {
|
||||||
|
const commandHandlers = new Map<string, (ctx: unknown) => Promise<void>>();
|
||||||
|
const sendMessage = vi.fn().mockResolvedValue(undefined);
|
||||||
|
const setMyCommands = vi.fn().mockResolvedValue(undefined);
|
||||||
|
const bot = {
|
||||||
|
api: {
|
||||||
|
setMyCommands,
|
||||||
|
sendMessage,
|
||||||
|
},
|
||||||
|
command: vi.fn((name: string, cb: (ctx: unknown) => Promise<void>) => {
|
||||||
|
commandHandlers.set(name, cb);
|
||||||
|
}),
|
||||||
|
} as unknown as RegisterTelegramNativeCommandsParams["bot"];
|
||||||
|
return { bot, commandHandlers, sendMessage, setMyCommands };
|
||||||
|
}
|
||||||
|
|
||||||
|
export function createNativeCommandTestParams(
|
||||||
|
cfg: OpenClawConfig,
|
||||||
|
params: Partial<RegisterTelegramNativeCommandsParams> = {},
|
||||||
|
): RegisterTelegramNativeCommandsParams {
|
||||||
|
return {
|
||||||
|
bot:
|
||||||
|
params.bot ??
|
||||||
|
({
|
||||||
|
api: {
|
||||||
|
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
||||||
|
sendMessage: vi.fn().mockResolvedValue(undefined),
|
||||||
|
},
|
||||||
|
command: vi.fn(),
|
||||||
|
} as unknown as RegisterTelegramNativeCommandsParams["bot"]),
|
||||||
|
cfg,
|
||||||
|
runtime: params.runtime ?? ({} as RuntimeEnv),
|
||||||
|
accountId: params.accountId ?? "default",
|
||||||
|
telegramCfg: params.telegramCfg ?? ({} as TelegramAccountConfig),
|
||||||
|
allowFrom: params.allowFrom ?? [],
|
||||||
|
groupAllowFrom: params.groupAllowFrom ?? [],
|
||||||
|
replyToMode: params.replyToMode ?? "off",
|
||||||
|
textLimit: params.textLimit ?? 4000,
|
||||||
|
useAccessGroups: params.useAccessGroups ?? false,
|
||||||
|
nativeEnabled: params.nativeEnabled ?? true,
|
||||||
|
nativeSkillsEnabled: params.nativeSkillsEnabled ?? true,
|
||||||
|
nativeDisabledExplicit: params.nativeDisabledExplicit ?? false,
|
||||||
|
resolveGroupPolicy:
|
||||||
|
params.resolveGroupPolicy ??
|
||||||
|
(() =>
|
||||||
|
({
|
||||||
|
allowlistEnabled: false,
|
||||||
|
allowed: true,
|
||||||
|
}) as ReturnType<RegisterTelegramNativeCommandsParams["resolveGroupPolicy"]>),
|
||||||
|
resolveTelegramGroupConfig:
|
||||||
|
params.resolveTelegramGroupConfig ??
|
||||||
|
(() => ({
|
||||||
|
groupConfig: undefined,
|
||||||
|
topicConfig: undefined,
|
||||||
|
})),
|
||||||
|
shouldSkipUpdate: params.shouldSkipUpdate ?? (() => false),
|
||||||
|
opts: params.opts ?? { token: "token" },
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function createPrivateCommandContext(params?: {
|
||||||
|
match?: string;
|
||||||
|
messageId?: number;
|
||||||
|
date?: number;
|
||||||
|
chatId?: number;
|
||||||
|
userId?: number;
|
||||||
|
username?: string;
|
||||||
|
}) {
|
||||||
|
return {
|
||||||
|
match: params?.match ?? "",
|
||||||
|
message: {
|
||||||
|
message_id: params?.messageId ?? 1,
|
||||||
|
date: params?.date ?? Math.floor(Date.now() / 1000),
|
||||||
|
chat: { id: params?.chatId ?? 123, type: "private" as const },
|
||||||
|
from: { id: params?.userId ?? 456, username: params?.username ?? "alice" },
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -1,102 +1,20 @@
|
|||||||
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
||||||
import type { OpenClawConfig } from "../../../src/config/config.js";
|
import type { OpenClawConfig } from "../../../src/config/config.js";
|
||||||
import type { TelegramAccountConfig } from "../../../src/config/types.js";
|
|
||||||
import { clearPluginCommands, registerPluginCommand } from "../../../src/plugins/commands.js";
|
import { clearPluginCommands, registerPluginCommand } from "../../../src/plugins/commands.js";
|
||||||
import type { RuntimeEnv } from "../../../src/runtime.js";
|
|
||||||
import { registerTelegramNativeCommands } from "./bot-native-commands.js";
|
import { registerTelegramNativeCommands } from "./bot-native-commands.js";
|
||||||
|
import {
|
||||||
const { listSkillCommandsForAgents } = vi.hoisted(() => ({
|
createCommandBot,
|
||||||
listSkillCommandsForAgents: vi.fn(() => []),
|
createNativeCommandTestParams,
|
||||||
}));
|
createPrivateCommandContext,
|
||||||
const deliveryMocks = vi.hoisted(() => ({
|
deliverReplies,
|
||||||
deliverReplies: vi.fn(async () => ({ delivered: true })),
|
resetNativeCommandMenuMocks,
|
||||||
}));
|
waitForRegisteredCommands,
|
||||||
|
} from "./bot-native-commands.menu-test-support.js";
|
||||||
vi.mock("../../../src/auto-reply/skill-commands.js", async (importOriginal) => {
|
|
||||||
const actual = await importOriginal<typeof import("../../../src/auto-reply/skill-commands.js")>();
|
|
||||||
return {
|
|
||||||
...actual,
|
|
||||||
listSkillCommandsForAgents,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
vi.mock("./bot/delivery.js", () => ({
|
|
||||||
deliverReplies: deliveryMocks.deliverReplies,
|
|
||||||
}));
|
|
||||||
|
|
||||||
describe("registerTelegramNativeCommands real plugin registry", () => {
|
describe("registerTelegramNativeCommands real plugin registry", () => {
|
||||||
type RegisteredCommand = {
|
|
||||||
command: string;
|
|
||||||
description: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
function createCommandBot() {
|
|
||||||
const commandHandlers = new Map<string, (ctx: unknown) => Promise<void>>();
|
|
||||||
const sendMessage = vi.fn().mockResolvedValue(undefined);
|
|
||||||
const setMyCommands = vi.fn().mockResolvedValue(undefined);
|
|
||||||
const bot = {
|
|
||||||
api: {
|
|
||||||
setMyCommands,
|
|
||||||
sendMessage,
|
|
||||||
},
|
|
||||||
command: vi.fn((name: string, cb: (ctx: unknown) => Promise<void>) => {
|
|
||||||
commandHandlers.set(name, cb);
|
|
||||||
}),
|
|
||||||
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"];
|
|
||||||
return { bot, commandHandlers, sendMessage, setMyCommands };
|
|
||||||
}
|
|
||||||
|
|
||||||
async function waitForRegisteredCommands(
|
|
||||||
setMyCommands: ReturnType<typeof vi.fn>,
|
|
||||||
): Promise<RegisteredCommand[]> {
|
|
||||||
await vi.waitFor(() => {
|
|
||||||
expect(setMyCommands).toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
return setMyCommands.mock.calls[0]?.[0] as RegisteredCommand[];
|
|
||||||
}
|
|
||||||
|
|
||||||
const buildParams = (cfg: OpenClawConfig, accountId = "default") =>
|
|
||||||
({
|
|
||||||
bot: {
|
|
||||||
api: {
|
|
||||||
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
|
||||||
sendMessage: vi.fn().mockResolvedValue(undefined),
|
|
||||||
},
|
|
||||||
command: vi.fn(),
|
|
||||||
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"],
|
|
||||||
cfg,
|
|
||||||
runtime: {} as RuntimeEnv,
|
|
||||||
accountId,
|
|
||||||
telegramCfg: {} as TelegramAccountConfig,
|
|
||||||
allowFrom: [],
|
|
||||||
groupAllowFrom: [],
|
|
||||||
replyToMode: "off",
|
|
||||||
textLimit: 4000,
|
|
||||||
useAccessGroups: false,
|
|
||||||
nativeEnabled: true,
|
|
||||||
nativeSkillsEnabled: true,
|
|
||||||
nativeDisabledExplicit: false,
|
|
||||||
resolveGroupPolicy: () =>
|
|
||||||
({
|
|
||||||
allowlistEnabled: false,
|
|
||||||
allowed: true,
|
|
||||||
}) as ReturnType<
|
|
||||||
Parameters<typeof registerTelegramNativeCommands>[0]["resolveGroupPolicy"]
|
|
||||||
>,
|
|
||||||
resolveTelegramGroupConfig: () => ({
|
|
||||||
groupConfig: undefined,
|
|
||||||
topicConfig: undefined,
|
|
||||||
}),
|
|
||||||
shouldSkipUpdate: () => false,
|
|
||||||
opts: { token: "token" },
|
|
||||||
}) satisfies Parameters<typeof registerTelegramNativeCommands>[0];
|
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
clearPluginCommands();
|
clearPluginCommands();
|
||||||
deliveryMocks.deliverReplies.mockClear();
|
resetNativeCommandMenuMocks();
|
||||||
deliveryMocks.deliverReplies.mockResolvedValue({ delivered: true });
|
|
||||||
listSkillCommandsForAgents.mockClear();
|
|
||||||
listSkillCommandsForAgents.mockReturnValue([]);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
@ -117,7 +35,7 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
).toEqual({ ok: true });
|
).toEqual({ ok: true });
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({}),
|
...createNativeCommandTestParams({}),
|
||||||
bot,
|
bot,
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -129,17 +47,9 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
const handler = commandHandlers.get("pair");
|
const handler = commandHandlers.get("pair");
|
||||||
expect(handler).toBeTruthy();
|
expect(handler).toBeTruthy();
|
||||||
|
|
||||||
await handler?.({
|
await handler?.(createPrivateCommandContext({ match: "now" }));
|
||||||
match: "now",
|
|
||||||
message: {
|
|
||||||
message_id: 1,
|
|
||||||
date: Math.floor(Date.now() / 1000),
|
|
||||||
chat: { id: 123, type: "private" },
|
|
||||||
from: { id: 456, username: "alice" },
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(deliveryMocks.deliverReplies).toHaveBeenCalledWith(
|
expect(deliverReplies).toHaveBeenCalledWith(
|
||||||
expect.objectContaining({
|
expect.objectContaining({
|
||||||
replies: [expect.objectContaining({ text: "paired:now" })],
|
replies: [expect.objectContaining({ text: "paired:now" })],
|
||||||
}),
|
}),
|
||||||
@ -165,7 +75,7 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
).toEqual({ ok: true });
|
).toEqual({ ok: true });
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({}),
|
...createNativeCommandTestParams({}),
|
||||||
bot,
|
bot,
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -177,17 +87,9 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
const handler = commandHandlers.get("pair_device");
|
const handler = commandHandlers.get("pair_device");
|
||||||
expect(handler).toBeTruthy();
|
expect(handler).toBeTruthy();
|
||||||
|
|
||||||
await handler?.({
|
await handler?.(createPrivateCommandContext({ match: "now", messageId: 2 }));
|
||||||
match: "now",
|
|
||||||
message: {
|
|
||||||
message_id: 2,
|
|
||||||
date: Math.floor(Date.now() / 1000),
|
|
||||||
chat: { id: 123, type: "private" },
|
|
||||||
from: { id: 456, username: "alice" },
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(deliveryMocks.deliverReplies).toHaveBeenCalledWith(
|
expect(deliverReplies).toHaveBeenCalledWith(
|
||||||
expect.objectContaining({
|
expect.objectContaining({
|
||||||
replies: [expect.objectContaining({ text: "paired:now" })],
|
replies: [expect.objectContaining({ text: "paired:now" })],
|
||||||
}),
|
}),
|
||||||
@ -209,7 +111,7 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
).toEqual({ ok: true });
|
).toEqual({ ok: true });
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({}, "default"),
|
...createNativeCommandTestParams({}, { accountId: "default" }),
|
||||||
bot,
|
bot,
|
||||||
nativeEnabled: false,
|
nativeEnabled: false,
|
||||||
});
|
});
|
||||||
@ -232,7 +134,7 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
).toEqual({ ok: true });
|
).toEqual({ ok: true });
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({
|
...createNativeCommandTestParams({
|
||||||
commands: { allowFrom: { telegram: ["999"] } } as OpenClawConfig["commands"],
|
commands: { allowFrom: { telegram: ["999"] } } as OpenClawConfig["commands"],
|
||||||
}),
|
}),
|
||||||
bot,
|
bot,
|
||||||
@ -245,17 +147,17 @@ describe("registerTelegramNativeCommands real plugin registry", () => {
|
|||||||
const handler = commandHandlers.get("pair");
|
const handler = commandHandlers.get("pair");
|
||||||
expect(handler).toBeTruthy();
|
expect(handler).toBeTruthy();
|
||||||
|
|
||||||
await handler?.({
|
await handler?.(
|
||||||
match: "now",
|
createPrivateCommandContext({
|
||||||
message: {
|
match: "now",
|
||||||
message_id: 10,
|
messageId: 10,
|
||||||
date: 123456,
|
date: 123456,
|
||||||
chat: { id: 123, type: "private" },
|
userId: 111,
|
||||||
from: { id: 111, username: "nope" },
|
username: "nope",
|
||||||
},
|
}),
|
||||||
});
|
);
|
||||||
|
|
||||||
expect(deliveryMocks.deliverReplies).toHaveBeenCalledWith(
|
expect(deliverReplies).toHaveBeenCalledWith(
|
||||||
expect.objectContaining({
|
expect.objectContaining({
|
||||||
replies: [expect.objectContaining({ text: "paired:now" })],
|
replies: [expect.objectContaining({ text: "paired:now" })],
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -6,99 +6,38 @@ import { TELEGRAM_COMMAND_NAME_PATTERN } from "../../../src/config/telegram-cust
|
|||||||
import type { TelegramAccountConfig } from "../../../src/config/types.js";
|
import type { TelegramAccountConfig } from "../../../src/config/types.js";
|
||||||
import type { RuntimeEnv } from "../../../src/runtime.js";
|
import type { RuntimeEnv } from "../../../src/runtime.js";
|
||||||
import { registerTelegramNativeCommands } from "./bot-native-commands.js";
|
import { registerTelegramNativeCommands } from "./bot-native-commands.js";
|
||||||
|
import {
|
||||||
|
createCommandBot,
|
||||||
|
createNativeCommandTestParams,
|
||||||
|
createPrivateCommandContext,
|
||||||
|
deliverReplies,
|
||||||
|
listSkillCommandsForAgents,
|
||||||
|
resetNativeCommandMenuMocks,
|
||||||
|
waitForRegisteredCommands,
|
||||||
|
} from "./bot-native-commands.menu-test-support.js";
|
||||||
|
|
||||||
const { listSkillCommandsForAgents } = vi.hoisted(() => ({
|
|
||||||
listSkillCommandsForAgents: vi.fn(() => []),
|
|
||||||
}));
|
|
||||||
const pluginCommandMocks = vi.hoisted(() => ({
|
const pluginCommandMocks = vi.hoisted(() => ({
|
||||||
getPluginCommandSpecs: vi.fn(() => []),
|
getPluginCommandSpecs: vi.fn(() => []),
|
||||||
matchPluginCommand: vi.fn(() => null),
|
matchPluginCommand: vi.fn(() => null),
|
||||||
executePluginCommand: vi.fn(async () => ({ text: "ok" })),
|
executePluginCommand: vi.fn(async () => ({ text: "ok" })),
|
||||||
}));
|
}));
|
||||||
const deliveryMocks = vi.hoisted(() => ({
|
|
||||||
deliverReplies: vi.fn(async () => ({ delivered: true })),
|
|
||||||
}));
|
|
||||||
|
|
||||||
vi.mock("../../../src/auto-reply/skill-commands.js", async (importOriginal) => {
|
|
||||||
const actual = await importOriginal<typeof import("../../../src/auto-reply/skill-commands.js")>();
|
|
||||||
return {
|
|
||||||
...actual,
|
|
||||||
listSkillCommandsForAgents,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
vi.mock("../../../src/plugins/commands.js", () => ({
|
vi.mock("../../../src/plugins/commands.js", () => ({
|
||||||
getPluginCommandSpecs: pluginCommandMocks.getPluginCommandSpecs,
|
getPluginCommandSpecs: pluginCommandMocks.getPluginCommandSpecs,
|
||||||
matchPluginCommand: pluginCommandMocks.matchPluginCommand,
|
matchPluginCommand: pluginCommandMocks.matchPluginCommand,
|
||||||
executePluginCommand: pluginCommandMocks.executePluginCommand,
|
executePluginCommand: pluginCommandMocks.executePluginCommand,
|
||||||
}));
|
}));
|
||||||
vi.mock("./bot/delivery.js", () => ({
|
|
||||||
deliverReplies: deliveryMocks.deliverReplies,
|
|
||||||
}));
|
|
||||||
|
|
||||||
describe("registerTelegramNativeCommands", () => {
|
describe("registerTelegramNativeCommands", () => {
|
||||||
type RegisteredCommand = {
|
|
||||||
command: string;
|
|
||||||
description: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
async function waitForRegisteredCommands(
|
|
||||||
setMyCommands: ReturnType<typeof vi.fn>,
|
|
||||||
): Promise<RegisteredCommand[]> {
|
|
||||||
await vi.waitFor(() => {
|
|
||||||
expect(setMyCommands).toHaveBeenCalled();
|
|
||||||
});
|
|
||||||
return setMyCommands.mock.calls[0]?.[0] as RegisteredCommand[];
|
|
||||||
}
|
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
listSkillCommandsForAgents.mockClear();
|
resetNativeCommandMenuMocks();
|
||||||
listSkillCommandsForAgents.mockReturnValue([]);
|
|
||||||
pluginCommandMocks.getPluginCommandSpecs.mockClear();
|
pluginCommandMocks.getPluginCommandSpecs.mockClear();
|
||||||
pluginCommandMocks.getPluginCommandSpecs.mockReturnValue([]);
|
pluginCommandMocks.getPluginCommandSpecs.mockReturnValue([]);
|
||||||
pluginCommandMocks.matchPluginCommand.mockClear();
|
pluginCommandMocks.matchPluginCommand.mockClear();
|
||||||
pluginCommandMocks.matchPluginCommand.mockReturnValue(null);
|
pluginCommandMocks.matchPluginCommand.mockReturnValue(null);
|
||||||
pluginCommandMocks.executePluginCommand.mockClear();
|
pluginCommandMocks.executePluginCommand.mockClear();
|
||||||
pluginCommandMocks.executePluginCommand.mockResolvedValue({ text: "ok" });
|
pluginCommandMocks.executePluginCommand.mockResolvedValue({ text: "ok" });
|
||||||
deliveryMocks.deliverReplies.mockClear();
|
|
||||||
deliveryMocks.deliverReplies.mockResolvedValue({ delivered: true });
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const buildParams = (cfg: OpenClawConfig, accountId = "default") =>
|
|
||||||
({
|
|
||||||
bot: {
|
|
||||||
api: {
|
|
||||||
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
|
||||||
sendMessage: vi.fn().mockResolvedValue(undefined),
|
|
||||||
},
|
|
||||||
command: vi.fn(),
|
|
||||||
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"],
|
|
||||||
cfg,
|
|
||||||
runtime: {} as RuntimeEnv,
|
|
||||||
accountId,
|
|
||||||
telegramCfg: {} as TelegramAccountConfig,
|
|
||||||
allowFrom: [],
|
|
||||||
groupAllowFrom: [],
|
|
||||||
replyToMode: "off",
|
|
||||||
textLimit: 4000,
|
|
||||||
useAccessGroups: false,
|
|
||||||
nativeEnabled: true,
|
|
||||||
nativeSkillsEnabled: true,
|
|
||||||
nativeDisabledExplicit: false,
|
|
||||||
resolveGroupPolicy: () =>
|
|
||||||
({
|
|
||||||
allowlistEnabled: false,
|
|
||||||
allowed: true,
|
|
||||||
}) as ReturnType<
|
|
||||||
Parameters<typeof registerTelegramNativeCommands>[0]["resolveGroupPolicy"]
|
|
||||||
>,
|
|
||||||
resolveTelegramGroupConfig: () => ({
|
|
||||||
groupConfig: undefined,
|
|
||||||
topicConfig: undefined,
|
|
||||||
}),
|
|
||||||
shouldSkipUpdate: () => false,
|
|
||||||
opts: { token: "token" },
|
|
||||||
}) satisfies Parameters<typeof registerTelegramNativeCommands>[0];
|
|
||||||
|
|
||||||
it("scopes skill commands when account binding exists", () => {
|
it("scopes skill commands when account binding exists", () => {
|
||||||
const cfg: OpenClawConfig = {
|
const cfg: OpenClawConfig = {
|
||||||
agents: {
|
agents: {
|
||||||
@ -112,7 +51,7 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
],
|
],
|
||||||
};
|
};
|
||||||
|
|
||||||
registerTelegramNativeCommands(buildParams(cfg, "bot-a"));
|
registerTelegramNativeCommands(createNativeCommandTestParams(cfg, { accountId: "bot-a" }));
|
||||||
|
|
||||||
expect(listSkillCommandsForAgents).toHaveBeenCalledWith({
|
expect(listSkillCommandsForAgents).toHaveBeenCalledWith({
|
||||||
cfg,
|
cfg,
|
||||||
@ -127,7 +66,7 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
registerTelegramNativeCommands(buildParams(cfg, "bot-a"));
|
registerTelegramNativeCommands(createNativeCommandTestParams(cfg, { accountId: "bot-a" }));
|
||||||
|
|
||||||
expect(listSkillCommandsForAgents).toHaveBeenCalledWith({
|
expect(listSkillCommandsForAgents).toHaveBeenCalledWith({
|
||||||
cfg,
|
cfg,
|
||||||
@ -147,7 +86,7 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
const runtimeLog = vi.fn();
|
const runtimeLog = vi.fn();
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams(cfg),
|
...createNativeCommandTestParams(cfg),
|
||||||
bot: {
|
bot: {
|
||||||
api: {
|
api: {
|
||||||
setMyCommands,
|
setMyCommands,
|
||||||
@ -174,7 +113,7 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
const command = vi.fn();
|
const command = vi.fn();
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({}),
|
...createNativeCommandTestParams({}),
|
||||||
bot: {
|
bot: {
|
||||||
api: {
|
api: {
|
||||||
setMyCommands,
|
setMyCommands,
|
||||||
@ -202,7 +141,7 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
] as never);
|
] as never);
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({}),
|
...createNativeCommandTestParams({}),
|
||||||
bot: {
|
bot: {
|
||||||
api: {
|
api: {
|
||||||
setMyCommands,
|
setMyCommands,
|
||||||
@ -259,31 +198,24 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
} as never);
|
} as never);
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams(cfg),
|
...createNativeCommandTestParams(cfg, {
|
||||||
bot: {
|
bot: {
|
||||||
api: {
|
api: {
|
||||||
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
||||||
sendMessage,
|
sendMessage,
|
||||||
},
|
},
|
||||||
command: vi.fn((name: string, cb: (ctx: unknown) => Promise<void>) => {
|
command: vi.fn((name: string, cb: (ctx: unknown) => Promise<void>) => {
|
||||||
commandHandlers.set(name, cb);
|
commandHandlers.set(name, cb);
|
||||||
}),
|
}),
|
||||||
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"],
|
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"],
|
||||||
|
}),
|
||||||
});
|
});
|
||||||
|
|
||||||
const handler = commandHandlers.get("plug");
|
const handler = commandHandlers.get("plug");
|
||||||
expect(handler).toBeTruthy();
|
expect(handler).toBeTruthy();
|
||||||
await handler?.({
|
await handler?.(createPrivateCommandContext());
|
||||||
match: "",
|
|
||||||
message: {
|
|
||||||
message_id: 1,
|
|
||||||
date: Math.floor(Date.now() / 1000),
|
|
||||||
chat: { id: 123, type: "private" },
|
|
||||||
from: { id: 456, username: "alice" },
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(deliveryMocks.deliverReplies).toHaveBeenCalledWith(
|
expect(deliverReplies).toHaveBeenCalledWith(
|
||||||
expect.objectContaining({
|
expect.objectContaining({
|
||||||
mediaLocalRoots: expect.arrayContaining([path.join(STATE_DIR, "workspace-work")]),
|
mediaLocalRoots: expect.arrayContaining([path.join(STATE_DIR, "workspace-work")]),
|
||||||
}),
|
}),
|
||||||
@ -310,32 +242,28 @@ describe("registerTelegramNativeCommands", () => {
|
|||||||
} as never);
|
} as never);
|
||||||
|
|
||||||
registerTelegramNativeCommands({
|
registerTelegramNativeCommands({
|
||||||
...buildParams({}),
|
...createNativeCommandTestParams(
|
||||||
bot: {
|
{},
|
||||||
api: {
|
{
|
||||||
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
bot: {
|
||||||
sendMessage: vi.fn().mockResolvedValue(undefined),
|
api: {
|
||||||
|
setMyCommands: vi.fn().mockResolvedValue(undefined),
|
||||||
|
sendMessage: vi.fn().mockResolvedValue(undefined),
|
||||||
|
},
|
||||||
|
command: vi.fn((name: string, cb: (ctx: unknown) => Promise<void>) => {
|
||||||
|
commandHandlers.set(name, cb);
|
||||||
|
}),
|
||||||
|
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"],
|
||||||
},
|
},
|
||||||
command: vi.fn((name: string, cb: (ctx: unknown) => Promise<void>) => {
|
),
|
||||||
commandHandlers.set(name, cb);
|
|
||||||
}),
|
|
||||||
} as unknown as Parameters<typeof registerTelegramNativeCommands>[0]["bot"],
|
|
||||||
telegramCfg: { silentErrorReplies: true } as TelegramAccountConfig,
|
telegramCfg: { silentErrorReplies: true } as TelegramAccountConfig,
|
||||||
});
|
});
|
||||||
|
|
||||||
const handler = commandHandlers.get("plug");
|
const handler = commandHandlers.get("plug");
|
||||||
expect(handler).toBeTruthy();
|
expect(handler).toBeTruthy();
|
||||||
await handler?.({
|
await handler?.(createPrivateCommandContext());
|
||||||
match: "",
|
|
||||||
message: {
|
|
||||||
message_id: 1,
|
|
||||||
date: Math.floor(Date.now() / 1000),
|
|
||||||
chat: { id: 123, type: "private" },
|
|
||||||
from: { id: 456, username: "alice" },
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(deliveryMocks.deliverReplies).toHaveBeenCalledWith(
|
expect(deliverReplies).toHaveBeenCalledWith(
|
||||||
expect.objectContaining({
|
expect.objectContaining({
|
||||||
silent: true,
|
silent: true,
|
||||||
replies: [expect.objectContaining({ isError: true })],
|
replies: [expect.objectContaining({ isError: true })],
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user