test: dedupe discord thread starter setup

This commit is contained in:
Peter Steinberger
2026-03-13 22:15:07 +00:00
parent bbb52087ed
commit 7b70fa26e6

View File

@@ -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");
}); });