mirror of
https://github.com/alkimake/paperclip.git
synced 2026-06-15 18:30:39 +09:00
- registry.test: fallback now uses SchemaConfigFields, not ProcessConfigFields - metadata.test: isEnabledAdapterType checks comingSoon first so intentionally withheld built-in adapters (process/http) stay disabled
51 lines
1.6 KiB
TypeScript
51 lines
1.6 KiB
TypeScript
import { describe, expect, it, beforeEach, afterEach } from "vitest";
|
|
import type { UIAdapterModule } from "./types";
|
|
import {
|
|
findUIAdapter,
|
|
getUIAdapter,
|
|
listUIAdapters,
|
|
registerUIAdapter,
|
|
unregisterUIAdapter,
|
|
} from "./registry";
|
|
import { processUIAdapter } from "./process";
|
|
import { SchemaConfigFields } from "./schema-config-fields";
|
|
|
|
const externalUIAdapter: UIAdapterModule = {
|
|
type: "external_test",
|
|
label: "External Test",
|
|
parseStdoutLine: () => [],
|
|
ConfigFields: () => null,
|
|
buildAdapterConfig: () => ({}),
|
|
};
|
|
|
|
describe("ui adapter registry", () => {
|
|
beforeEach(() => {
|
|
unregisterUIAdapter("external_test");
|
|
});
|
|
|
|
afterEach(() => {
|
|
unregisterUIAdapter("external_test");
|
|
});
|
|
|
|
it("registers adapters for lookup and listing", () => {
|
|
registerUIAdapter(externalUIAdapter);
|
|
|
|
expect(findUIAdapter("external_test")).toBe(externalUIAdapter);
|
|
expect(getUIAdapter("external_test")).toBe(externalUIAdapter);
|
|
expect(listUIAdapters().some((adapter) => adapter.type === "external_test")).toBe(true);
|
|
});
|
|
|
|
it("falls back to the process parser for unknown types after unregistering", () => {
|
|
registerUIAdapter(externalUIAdapter);
|
|
|
|
unregisterUIAdapter("external_test");
|
|
|
|
expect(findUIAdapter("external_test")).toBeNull();
|
|
const fallback = getUIAdapter("external_test");
|
|
// Unknown types return a lazy-loading wrapper (for external adapters),
|
|
// not the process adapter directly. The type is preserved.
|
|
expect(fallback.type).toBe("external_test");
|
|
// But it uses the schema-based config fields for external adapter forms.
|
|
expect(fallback.ConfigFields).toBe(SchemaConfigFields);
|
|
});
|
|
});
|