mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 22:50:42 +00:00
167 lines
7.1 KiB
TypeScript
167 lines
7.1 KiB
TypeScript
import { vi } from "vitest";
|
|
import type { OpenClawConfig } from "../../../src/config/config.js";
|
|
import type { ImageGenerationProvider } from "../../../src/image-generation/types.js";
|
|
import type { MusicGenerationProvider } from "../../../src/music-generation/types.js";
|
|
import type { VideoGenerationProvider } from "../../../src/video-generation/types.js";
|
|
import { resetGenerationRuntimeMocks } from "./runtime-test-mocks.js";
|
|
|
|
type ModelRef = { provider: string; model: string };
|
|
|
|
const mediaRuntimeMocks = vi.hoisted(() => {
|
|
const debug = vi.fn();
|
|
const warn = vi.fn();
|
|
const parseGenerationModelRef = (raw?: string): ModelRef | undefined => {
|
|
const trimmed = raw?.trim();
|
|
if (!trimmed) {
|
|
return undefined;
|
|
}
|
|
const slash = trimmed.indexOf("/");
|
|
if (slash <= 0 || slash === trimmed.length - 1) {
|
|
return undefined;
|
|
}
|
|
return {
|
|
provider: trimmed.slice(0, slash),
|
|
model: trimmed.slice(slash + 1),
|
|
};
|
|
};
|
|
return {
|
|
createSubsystemLogger: vi.fn(() => ({ debug, warn })),
|
|
describeFailoverError: vi.fn(),
|
|
getImageGenerationProvider: vi.fn<
|
|
(providerId: string, config?: OpenClawConfig) => ImageGenerationProvider | undefined
|
|
>(() => undefined),
|
|
getMusicGenerationProvider: vi.fn<
|
|
(providerId: string, config?: OpenClawConfig) => MusicGenerationProvider | undefined
|
|
>(() => undefined),
|
|
getProviderEnvVars: vi.fn<(providerId: string) => string[]>(() => []),
|
|
getVideoGenerationProvider: vi.fn<
|
|
(providerId: string, config?: OpenClawConfig) => VideoGenerationProvider | undefined
|
|
>(() => undefined),
|
|
isFailoverError: vi.fn<(err: unknown) => boolean>(() => false),
|
|
listImageGenerationProviders: vi.fn<(config?: OpenClawConfig) => ImageGenerationProvider[]>(
|
|
() => [],
|
|
),
|
|
listMusicGenerationProviders: vi.fn<(config?: OpenClawConfig) => MusicGenerationProvider[]>(
|
|
() => [],
|
|
),
|
|
listVideoGenerationProviders: vi.fn<(config?: OpenClawConfig) => VideoGenerationProvider[]>(
|
|
() => [],
|
|
),
|
|
parseImageGenerationModelRef:
|
|
vi.fn<(raw?: string) => ModelRef | undefined>(parseGenerationModelRef),
|
|
parseMusicGenerationModelRef:
|
|
vi.fn<(raw?: string) => ModelRef | undefined>(parseGenerationModelRef),
|
|
parseVideoGenerationModelRef:
|
|
vi.fn<(raw?: string) => ModelRef | undefined>(parseGenerationModelRef),
|
|
ensureAuthProfileStore: vi.fn(() => ({ version: 1, profiles: {} })),
|
|
listProfilesForProvider: vi.fn(() => []),
|
|
resolveEnvApiKey: vi.fn(() => undefined),
|
|
resolveAgentModelFallbackValues: vi.fn<(value: unknown) => string[]>(() => []),
|
|
resolveAgentModelPrimaryValue: vi.fn<(value: unknown) => string | undefined>(() => undefined),
|
|
resolveAgentModelTimeoutMsValue: vi.fn<(value: unknown) => number | undefined>((value) => {
|
|
if (!value || typeof value !== "object" || !("timeoutMs" in value)) {
|
|
return undefined;
|
|
}
|
|
const timeoutMs = (value as { timeoutMs?: unknown }).timeoutMs;
|
|
return typeof timeoutMs === "number" && Number.isFinite(timeoutMs) && timeoutMs > 0
|
|
? Math.floor(timeoutMs)
|
|
: undefined;
|
|
}),
|
|
resolveProviderAuthEnvVarCandidates: vi.fn(() => ({})),
|
|
debug,
|
|
warn,
|
|
};
|
|
});
|
|
|
|
vi.mock("../../../src/agents/auth-profiles.js", () => ({
|
|
ensureAuthProfileStore: mediaRuntimeMocks.ensureAuthProfileStore,
|
|
listProfilesForProvider: mediaRuntimeMocks.listProfilesForProvider,
|
|
}));
|
|
vi.mock("../../../src/agents/defaults.js", () => ({
|
|
DEFAULT_PROVIDER: "openai",
|
|
}));
|
|
vi.mock("../../../src/agents/failover-error.js", () => ({
|
|
describeFailoverError: mediaRuntimeMocks.describeFailoverError,
|
|
isFailoverError: mediaRuntimeMocks.isFailoverError,
|
|
}));
|
|
vi.mock("../../../src/agents/model-auth-env.js", () => ({
|
|
resolveEnvApiKey: mediaRuntimeMocks.resolveEnvApiKey,
|
|
}));
|
|
vi.mock("../../../src/config/model-input.js", () => ({
|
|
resolveAgentModelFallbackValues: mediaRuntimeMocks.resolveAgentModelFallbackValues,
|
|
resolveAgentModelPrimaryValue: mediaRuntimeMocks.resolveAgentModelPrimaryValue,
|
|
resolveAgentModelTimeoutMsValue: mediaRuntimeMocks.resolveAgentModelTimeoutMsValue,
|
|
}));
|
|
vi.mock("../../../src/logging/subsystem.js", () => ({
|
|
createSubsystemLogger: mediaRuntimeMocks.createSubsystemLogger,
|
|
}));
|
|
vi.mock("../../../src/secrets/provider-env-vars.js", () => ({
|
|
getProviderEnvVars: mediaRuntimeMocks.getProviderEnvVars,
|
|
resolveProviderAuthEnvVarCandidates: mediaRuntimeMocks.resolveProviderAuthEnvVarCandidates,
|
|
}));
|
|
|
|
vi.mock("../../../src/image-generation/model-ref.js", () => ({
|
|
parseImageGenerationModelRef: mediaRuntimeMocks.parseImageGenerationModelRef,
|
|
}));
|
|
vi.mock("../../../src/image-generation/provider-registry.js", () => ({
|
|
getImageGenerationProvider: mediaRuntimeMocks.getImageGenerationProvider,
|
|
listImageGenerationProviders: mediaRuntimeMocks.listImageGenerationProviders,
|
|
}));
|
|
vi.mock("../../../src/music-generation/model-ref.js", () => ({
|
|
parseMusicGenerationModelRef: mediaRuntimeMocks.parseMusicGenerationModelRef,
|
|
}));
|
|
vi.mock("../../../src/music-generation/provider-registry.js", () => ({
|
|
getMusicGenerationProvider: mediaRuntimeMocks.getMusicGenerationProvider,
|
|
listMusicGenerationProviders: mediaRuntimeMocks.listMusicGenerationProviders,
|
|
}));
|
|
vi.mock("../../../src/video-generation/model-ref.js", () => ({
|
|
parseVideoGenerationModelRef: mediaRuntimeMocks.parseVideoGenerationModelRef,
|
|
}));
|
|
vi.mock("../../../src/video-generation/provider-registry.js", () => ({
|
|
getVideoGenerationProvider: mediaRuntimeMocks.getVideoGenerationProvider,
|
|
listVideoGenerationProviders: mediaRuntimeMocks.listVideoGenerationProviders,
|
|
}));
|
|
|
|
export function getMediaGenerationRuntimeMocks() {
|
|
return mediaRuntimeMocks;
|
|
}
|
|
|
|
export function resetImageGenerationRuntimeMocks(): void {
|
|
resetSharedRuntimeImportMocks();
|
|
resetGenerationRuntimeMocks({
|
|
...mediaRuntimeMocks,
|
|
getProvider: mediaRuntimeMocks.getImageGenerationProvider,
|
|
listProviders: mediaRuntimeMocks.listImageGenerationProviders,
|
|
parseModelRef: mediaRuntimeMocks.parseImageGenerationModelRef,
|
|
});
|
|
}
|
|
|
|
export function resetMusicGenerationRuntimeMocks(): void {
|
|
resetSharedRuntimeImportMocks();
|
|
resetGenerationRuntimeMocks({
|
|
...mediaRuntimeMocks,
|
|
getProvider: mediaRuntimeMocks.getMusicGenerationProvider,
|
|
listProviders: mediaRuntimeMocks.listMusicGenerationProviders,
|
|
parseModelRef: mediaRuntimeMocks.parseMusicGenerationModelRef,
|
|
});
|
|
}
|
|
|
|
export function resetVideoGenerationRuntimeMocks(): void {
|
|
resetSharedRuntimeImportMocks();
|
|
resetGenerationRuntimeMocks({
|
|
...mediaRuntimeMocks,
|
|
getProvider: mediaRuntimeMocks.getVideoGenerationProvider,
|
|
listProviders: mediaRuntimeMocks.listVideoGenerationProviders,
|
|
parseModelRef: mediaRuntimeMocks.parseVideoGenerationModelRef,
|
|
});
|
|
}
|
|
|
|
function resetSharedRuntimeImportMocks(): void {
|
|
mediaRuntimeMocks.ensureAuthProfileStore.mockReset();
|
|
mediaRuntimeMocks.ensureAuthProfileStore.mockReturnValue({ version: 1, profiles: {} });
|
|
mediaRuntimeMocks.listProfilesForProvider.mockReset();
|
|
mediaRuntimeMocks.listProfilesForProvider.mockReturnValue([]);
|
|
mediaRuntimeMocks.resolveEnvApiKey.mockReset();
|
|
mediaRuntimeMocks.resolveEnvApiKey.mockReturnValue(undefined);
|
|
}
|