Files
openclaw/src/discord/monitor/threading.starter.test.ts
2026-03-13 23:35:27 +00:00

60 lines
1.6 KiB
TypeScript

import { ChannelType, type Client } from "@buape/carbon";
import { beforeEach, describe, expect, it, vi } from "vitest";
import {
__resetDiscordThreadStarterCacheForTest,
resolveDiscordThreadStarter,
} from "./threading.js";
async function resolveStarter(
message: Partial<Awaited<ReturnType<Client["rest"]["get"]>>>,
resolveTimestampMs: () => number | undefined,
) {
const get = vi.fn().mockResolvedValue(message);
const client = { rest: { get } } as unknown as Client;
return resolveDiscordThreadStarter({
channel: { id: "thread-1" },
client,
parentId: "parent-1",
parentType: ChannelType.GuildText,
resolveTimestampMs,
});
}
describe("resolveDiscordThreadStarter", () => {
beforeEach(() => {
__resetDiscordThreadStarterCacheForTest();
});
it("falls back to joined embed title and description when content is empty", async () => {
const result = await resolveStarter(
{
content: " ",
embeds: [{ title: "Alert", description: "Details" }],
author: { username: "Alice", discriminator: "0" },
timestamp: "2026-02-24T12:00:00.000Z",
},
() => 123,
);
expect(result).toEqual({
text: "Alert\nDetails",
author: "Alice",
timestamp: 123,
});
});
it("prefers starter content over embed fallback text", async () => {
const result = await resolveStarter(
{
content: "starter content",
embeds: [{ title: "Alert", description: "Details" }],
author: { username: "Alice", discriminator: "0" },
},
() => undefined,
);
expect(result?.text).toBe("starter content");
});
});