* 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
50 lines
1.7 KiB
TypeScript
50 lines
1.7 KiB
TypeScript
import { vi } from "vitest";
|
|
import type { MockFn } from "../../../src/test-utils/vitest-mock-fn.js";
|
|
|
|
export const sendMock: MockFn = vi.fn();
|
|
export const reactMock: MockFn = vi.fn();
|
|
export const updateLastRouteMock: MockFn = vi.fn();
|
|
export const dispatchMock: MockFn = vi.fn();
|
|
export const readAllowFromStoreMock: MockFn = vi.fn();
|
|
export const upsertPairingRequestMock: MockFn = vi.fn();
|
|
|
|
vi.mock("./send.js", () => ({
|
|
sendMessageDiscord: (...args: unknown[]) => sendMock(...args),
|
|
reactMessageDiscord: async (...args: unknown[]) => {
|
|
reactMock(...args);
|
|
},
|
|
}));
|
|
|
|
vi.mock("../../../src/auto-reply/dispatch.js", async (importOriginal) => {
|
|
const actual = await importOriginal<typeof import("../../../src/auto-reply/dispatch.js")>();
|
|
return {
|
|
...actual,
|
|
dispatchInboundMessage: (...args: unknown[]) => dispatchMock(...args),
|
|
dispatchInboundMessageWithDispatcher: (...args: unknown[]) => dispatchMock(...args),
|
|
dispatchInboundMessageWithBufferedDispatcher: (...args: unknown[]) => dispatchMock(...args),
|
|
};
|
|
});
|
|
|
|
function createPairingStoreMocks() {
|
|
return {
|
|
readChannelAllowFromStore(...args: unknown[]) {
|
|
return readAllowFromStoreMock(...args);
|
|
},
|
|
upsertChannelPairingRequest(...args: unknown[]) {
|
|
return upsertPairingRequestMock(...args);
|
|
},
|
|
};
|
|
}
|
|
|
|
vi.mock("../../../src/pairing/pairing-store.js", () => createPairingStoreMocks());
|
|
|
|
vi.mock("../../../src/config/sessions.js", async (importOriginal) => {
|
|
const actual = await importOriginal<typeof import("../../../src/config/sessions.js")>();
|
|
return {
|
|
...actual,
|
|
resolveStorePath: vi.fn(() => "/tmp/openclaw-sessions.json"),
|
|
updateLastRoute: (...args: unknown[]) => updateLastRouteMock(...args),
|
|
resolveSessionKey: vi.fn(),
|
|
};
|
|
});
|