* refactor: move Discord channel implementation to extensions/discord/src/ Move all Discord source files from src/discord/ to extensions/discord/src/, following the extension migration pattern. Source files in src/discord/ are replaced with re-export shims. Channel-plugin files from src/channels/plugins/*/discord* are similarly moved and shimmed. - Copy all .ts source files preserving subdirectory structure (monitor/, voice/) - Move channel-plugin files (actions, normalize, onboarding, outbound, status-issues) - Fix all relative imports to use correct paths from new location - Create re-export shims at original locations for backward compatibility - Delete test files from shim locations (tests live in extension now) - Update tsconfig.plugin-sdk.dts.json rootDir from "src" to "." to accommodate extension files outside src/ - Update write-plugin-sdk-entry-dts.ts to match new declaration output paths * fix: add importOriginal to thread-bindings session-meta mock for extensions test * style: fix formatting in thread-bindings lifecycle test
38 lines
984 B
TypeScript
38 lines
984 B
TypeScript
import { describe, vi } from "vitest";
|
|
import type { ReplyPayload } from "../../../src/auto-reply/types.js";
|
|
import {
|
|
installSendPayloadContractSuite,
|
|
primeSendMock,
|
|
} from "../../../src/test-utils/send-payload-contract.js";
|
|
import { discordOutbound } from "./outbound-adapter.js";
|
|
|
|
function createHarness(params: {
|
|
payload: ReplyPayload;
|
|
sendResults?: Array<{ messageId: string }>;
|
|
}) {
|
|
const sendDiscord = vi.fn();
|
|
primeSendMock(sendDiscord, { messageId: "dc-1", channelId: "123456" }, params.sendResults);
|
|
const ctx = {
|
|
cfg: {},
|
|
to: "channel:123456",
|
|
text: "",
|
|
payload: params.payload,
|
|
deps: {
|
|
sendDiscord,
|
|
},
|
|
};
|
|
return {
|
|
run: async () => await discordOutbound.sendPayload!(ctx),
|
|
sendMock: sendDiscord,
|
|
to: ctx.to,
|
|
};
|
|
}
|
|
|
|
describe("discordOutbound sendPayload", () => {
|
|
installSendPayloadContractSuite({
|
|
channel: "discord",
|
|
chunking: { mode: "passthrough", longTextLength: 3000 },
|
|
createHarness,
|
|
});
|
|
});
|