test(video): isolate provider registry mocks

This commit is contained in:
Peter Steinberger
2026-04-28 08:35:48 +01:00
parent f95f720b25
commit 47b6d3a334

View File

@@ -9,9 +9,6 @@ vi.mock("../plugins/capability-provider-runtime.js", () => ({
resolvePluginCapabilityProviders: resolvePluginCapabilityProvidersMock,
}));
const { getVideoGenerationProvider, listVideoGenerationProviders } =
await import("./provider-registry.js");
function createProvider(
params: Pick<VideoGenerationProviderPlugin, "id"> & Partial<VideoGenerationProviderPlugin>,
): VideoGenerationProviderPlugin {
@@ -25,13 +22,20 @@ function createProvider(
};
}
async function loadProviderRegistry() {
vi.resetModules();
return await import("./provider-registry.js");
}
describe("video-generation provider registry", () => {
beforeEach(() => {
resolvePluginCapabilityProvidersMock.mockReset();
resolvePluginCapabilityProvidersMock.mockReturnValue([]);
});
it("delegates provider resolution to the capability provider boundary", () => {
it("delegates provider resolution to the capability provider boundary", async () => {
const { listVideoGenerationProviders } = await loadProviderRegistry();
expect(listVideoGenerationProviders()).toEqual([]);
expect(resolvePluginCapabilityProvidersMock).toHaveBeenCalledWith({
key: "videoGenerationProviders",
@@ -39,7 +43,8 @@ describe("video-generation provider registry", () => {
});
});
it("uses active plugin providers without loading from disk", () => {
it("uses active plugin providers without loading from disk", async () => {
const { getVideoGenerationProvider } = await loadProviderRegistry();
resolvePluginCapabilityProvidersMock.mockReturnValue([createProvider({ id: "custom-video" })]);
const provider = getVideoGenerationProvider("custom-video");
@@ -51,7 +56,9 @@ describe("video-generation provider registry", () => {
});
});
it("ignores prototype-like provider ids and aliases", () => {
it("ignores prototype-like provider ids and aliases", async () => {
const { getVideoGenerationProvider, listVideoGenerationProviders } =
await loadProviderRegistry();
resolvePluginCapabilityProvidersMock.mockReturnValue([
createProvider({ id: "__proto__", aliases: ["constructor", "prototype"] }),
createProvider({ id: "safe-video", aliases: ["safe-alias", "constructor"] }),