mirror of https://github.com/openclaw/openclaw.git
93 lines
3.2 KiB
TypeScript
93 lines
3.2 KiB
TypeScript
import { describe, expect, it, vi, beforeEach } from "vitest";
|
|
|
|
// Mock recordInboundSession to capture updateLastRoute parameter
|
|
const recordInboundSessionMock = vi.fn().mockResolvedValue(undefined);
|
|
vi.mock("openclaw/plugin-sdk/conversation-runtime", async (importOriginal) => {
|
|
const actual = await importOriginal<typeof import("openclaw/plugin-sdk/conversation-runtime")>();
|
|
return {
|
|
...actual,
|
|
recordInboundSession: (...args: unknown[]) => recordInboundSessionMock(...args),
|
|
};
|
|
});
|
|
|
|
let buildTelegramMessageContextForTest: typeof import("./bot-message-context.test-harness.js").buildTelegramMessageContextForTest;
|
|
|
|
describe("buildTelegramMessageContext DM topic threadId in deliveryContext (#8891)", () => {
|
|
async function buildCtx(params: {
|
|
message: Record<string, unknown>;
|
|
options?: Record<string, unknown>;
|
|
resolveGroupActivation?: () => boolean | undefined;
|
|
}) {
|
|
return await buildTelegramMessageContextForTest({
|
|
message: params.message,
|
|
options: params.options,
|
|
resolveGroupActivation: params.resolveGroupActivation,
|
|
});
|
|
}
|
|
|
|
function getUpdateLastRoute(): unknown {
|
|
const callArgs = recordInboundSessionMock.mock.calls[0]?.[0] as { updateLastRoute?: unknown };
|
|
return callArgs?.updateLastRoute;
|
|
}
|
|
|
|
beforeEach(async () => {
|
|
vi.resetModules();
|
|
recordInboundSessionMock.mockClear();
|
|
({ buildTelegramMessageContextForTest } =
|
|
await import("./bot-message-context.test-harness.js"));
|
|
});
|
|
|
|
it("passes threadId to updateLastRoute for DM topics", async () => {
|
|
const ctx = await buildCtx({
|
|
message: {
|
|
chat: { id: 1234, type: "private" },
|
|
message_thread_id: 42, // DM Topic ID
|
|
},
|
|
});
|
|
|
|
expect(ctx).not.toBeNull();
|
|
expect(recordInboundSessionMock).toHaveBeenCalled();
|
|
|
|
// Check that updateLastRoute includes threadId
|
|
const updateLastRoute = getUpdateLastRoute() as { threadId?: string; to?: string } | undefined;
|
|
expect(updateLastRoute).toBeDefined();
|
|
expect(updateLastRoute?.to).toBe("telegram:1234");
|
|
expect(updateLastRoute?.threadId).toBe("42");
|
|
});
|
|
|
|
it("does not pass threadId for regular DM without topic", async () => {
|
|
const ctx = await buildCtx({
|
|
message: {
|
|
chat: { id: 1234, type: "private" },
|
|
},
|
|
});
|
|
|
|
expect(ctx).not.toBeNull();
|
|
expect(recordInboundSessionMock).toHaveBeenCalled();
|
|
|
|
// Check that updateLastRoute does NOT include threadId
|
|
const updateLastRoute = getUpdateLastRoute() as { threadId?: string; to?: string } | undefined;
|
|
expect(updateLastRoute).toBeDefined();
|
|
expect(updateLastRoute?.to).toBe("telegram:1234");
|
|
expect(updateLastRoute?.threadId).toBeUndefined();
|
|
});
|
|
|
|
it("does not set updateLastRoute for group messages", async () => {
|
|
const ctx = await buildCtx({
|
|
message: {
|
|
chat: { id: -1001234567890, type: "supergroup", title: "Test Group" },
|
|
text: "@bot hello",
|
|
message_thread_id: 99,
|
|
},
|
|
options: { forceWasMentioned: true },
|
|
resolveGroupActivation: () => true,
|
|
});
|
|
|
|
expect(ctx).not.toBeNull();
|
|
expect(recordInboundSessionMock).toHaveBeenCalled();
|
|
|
|
// Check that updateLastRoute is undefined for groups
|
|
expect(getUpdateLastRoute()).toBeUndefined();
|
|
});
|
|
});
|