mirror of
https://github.com/openclaw/openclaw.git
synced 2026-04-19 11:38:38 +00:00
test: dedupe discord thread starter setup
This commit is contained in:
@@ -5,27 +5,37 @@ import {
|
|||||||
resolveDiscordThreadStarter,
|
resolveDiscordThreadStarter,
|
||||||
} from "./threading.js";
|
} 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", () => {
|
describe("resolveDiscordThreadStarter", () => {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
__resetDiscordThreadStarterCacheForTest();
|
__resetDiscordThreadStarterCacheForTest();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("falls back to joined embed title and description when content is empty", async () => {
|
it("falls back to joined embed title and description when content is empty", async () => {
|
||||||
const get = vi.fn().mockResolvedValue({
|
const result = await resolveStarter(
|
||||||
content: " ",
|
{
|
||||||
embeds: [{ title: "Alert", description: "Details" }],
|
content: " ",
|
||||||
author: { username: "Alice", discriminator: "0" },
|
embeds: [{ title: "Alert", description: "Details" }],
|
||||||
timestamp: "2026-02-24T12:00:00.000Z",
|
author: { username: "Alice", discriminator: "0" },
|
||||||
});
|
timestamp: "2026-02-24T12:00:00.000Z",
|
||||||
const client = { rest: { get } } as unknown as Client;
|
},
|
||||||
|
() => 123,
|
||||||
const result = await resolveDiscordThreadStarter({
|
);
|
||||||
channel: { id: "thread-1" },
|
|
||||||
client,
|
|
||||||
parentId: "parent-1",
|
|
||||||
parentType: ChannelType.GuildText,
|
|
||||||
resolveTimestampMs: () => 123,
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(result).toEqual({
|
expect(result).toEqual({
|
||||||
text: "Alert\nDetails",
|
text: "Alert\nDetails",
|
||||||
@@ -35,20 +45,14 @@ describe("resolveDiscordThreadStarter", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("prefers starter content over embed fallback text", async () => {
|
it("prefers starter content over embed fallback text", async () => {
|
||||||
const get = vi.fn().mockResolvedValue({
|
const result = await resolveStarter(
|
||||||
content: "starter content",
|
{
|
||||||
embeds: [{ title: "Alert", description: "Details" }],
|
content: "starter content",
|
||||||
author: { username: "Alice", discriminator: "0" },
|
embeds: [{ title: "Alert", description: "Details" }],
|
||||||
});
|
author: { username: "Alice", discriminator: "0" },
|
||||||
const client = { rest: { get } } as unknown as Client;
|
},
|
||||||
|
() => undefined,
|
||||||
const result = await resolveDiscordThreadStarter({
|
);
|
||||||
channel: { id: "thread-1" },
|
|
||||||
client,
|
|
||||||
parentId: "parent-1",
|
|
||||||
parentType: ChannelType.GuildText,
|
|
||||||
resolveTimestampMs: () => undefined,
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(result?.text).toBe("starter content");
|
expect(result?.text).toBe("starter content");
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user