@kubb/core 5.0.0-alpha.4 → 5.0.0-alpha.41

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/dist/PluginDriver-BQwm8hDd.cjs +1729 -0
  2. package/dist/PluginDriver-BQwm8hDd.cjs.map +1 -0
  3. package/dist/PluginDriver-CgXFtmNP.js +1617 -0
  4. package/dist/PluginDriver-CgXFtmNP.js.map +1 -0
  5. package/dist/index.cjs +915 -1901
  6. package/dist/index.cjs.map +1 -1
  7. package/dist/index.d.ts +268 -264
  8. package/dist/index.js +894 -1863
  9. package/dist/index.js.map +1 -1
  10. package/dist/mocks.cjs +164 -0
  11. package/dist/mocks.cjs.map +1 -0
  12. package/dist/mocks.d.ts +74 -0
  13. package/dist/mocks.js +159 -0
  14. package/dist/mocks.js.map +1 -0
  15. package/dist/types-C6NCtNqM.d.ts +2151 -0
  16. package/package.json +11 -14
  17. package/src/FileManager.ts +131 -0
  18. package/src/FileProcessor.ts +84 -0
  19. package/src/Kubb.ts +174 -85
  20. package/src/PluginDriver.ts +941 -0
  21. package/src/constants.ts +33 -43
  22. package/src/createAdapter.ts +25 -0
  23. package/src/createKubb.ts +605 -0
  24. package/src/createPlugin.ts +31 -0
  25. package/src/createRenderer.ts +57 -0
  26. package/src/createStorage.ts +58 -0
  27. package/src/defineGenerator.ts +88 -100
  28. package/src/defineLogger.ts +13 -3
  29. package/src/defineParser.ts +45 -0
  30. package/src/definePlugin.ts +90 -7
  31. package/src/defineResolver.ts +453 -0
  32. package/src/devtools.ts +14 -14
  33. package/src/index.ts +12 -17
  34. package/src/mocks.ts +234 -0
  35. package/src/renderNode.ts +35 -0
  36. package/src/storages/fsStorage.ts +29 -9
  37. package/src/storages/memoryStorage.ts +2 -2
  38. package/src/types.ts +821 -152
  39. package/src/utils/TreeNode.ts +47 -9
  40. package/src/utils/diagnostics.ts +4 -1
  41. package/src/utils/executeStrategies.ts +16 -13
  42. package/src/utils/getBarrelFiles.ts +88 -15
  43. package/src/utils/isInputPath.ts +10 -0
  44. package/src/utils/packageJSON.ts +75 -0
  45. package/dist/chunk-ByKO4r7w.cjs +0 -38
  46. package/dist/hooks.cjs +0 -50
  47. package/dist/hooks.cjs.map +0 -1
  48. package/dist/hooks.d.ts +0 -49
  49. package/dist/hooks.js +0 -46
  50. package/dist/hooks.js.map +0 -1
  51. package/dist/types-Bbh1o0yW.d.ts +0 -1057
  52. package/src/BarrelManager.ts +0 -74
  53. package/src/PackageManager.ts +0 -180
  54. package/src/PluginManager.ts +0 -668
  55. package/src/PromiseManager.ts +0 -40
  56. package/src/build.ts +0 -420
  57. package/src/config.ts +0 -56
  58. package/src/defineAdapter.ts +0 -22
  59. package/src/defineStorage.ts +0 -56
  60. package/src/errors.ts +0 -1
  61. package/src/hooks/index.ts +0 -8
  62. package/src/hooks/useKubb.ts +0 -22
  63. package/src/hooks/useMode.ts +0 -11
  64. package/src/hooks/usePlugin.ts +0 -11
  65. package/src/hooks/usePluginManager.ts +0 -11
  66. package/src/utils/FunctionParams.ts +0 -155
  67. package/src/utils/formatters.ts +0 -56
  68. package/src/utils/getConfigs.ts +0 -30
  69. package/src/utils/getPlugins.ts +0 -23
  70. package/src/utils/linters.ts +0 -25
  71. package/src/utils/resolveOptions.ts +0 -93
package/dist/mocks.cjs ADDED
@@ -0,0 +1,164 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ const require_PluginDriver = require("./PluginDriver-BQwm8hDd.cjs");
3
+ let node_path = require("node:path");
4
+ let _kubb_ast = require("@kubb/ast");
5
+ //#region src/mocks.ts
6
+ function toCamelOrPascal(text, pascal) {
7
+ return text.trim().replace(/([a-z\d])([A-Z])/g, "$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g, "$1 $2").replace(/(\d)([a-z])/g, "$1 $2").split(/[\s\-_./\\:]+/).filter(Boolean).map((word, i) => {
8
+ if (word.length > 1 && word === word.toUpperCase()) return word;
9
+ if (i === 0 && !pascal) return word.charAt(0).toLowerCase() + word.slice(1);
10
+ return word.charAt(0).toUpperCase() + word.slice(1);
11
+ }).join("").replace(/[^a-zA-Z0-9]/g, "");
12
+ }
13
+ function camelCase(text) {
14
+ return toCamelOrPascal(text, false);
15
+ }
16
+ function pascalCase(text) {
17
+ return toCamelOrPascal(text, true);
18
+ }
19
+ /**
20
+ * Creates a minimal `PluginDriver` mock suitable for unit tests.
21
+ */
22
+ function createMockedPluginDriver(options = {}) {
23
+ return {
24
+ resolveName: (result) => {
25
+ if (result.type === "file") return camelCase(options?.name || result.name);
26
+ if (result.type === "type") return pascalCase(result.name);
27
+ if (result.type === "function") return camelCase(result.name);
28
+ return camelCase(result.name);
29
+ },
30
+ config: options?.config ?? {
31
+ root: ".",
32
+ output: { path: "./path" }
33
+ },
34
+ resolvePath: ({ baseName }) => baseName,
35
+ getFile: ({ name, extname, pluginName, options: fileOptions }) => {
36
+ const baseName = `${name}${extname}`;
37
+ const groupDir = fileOptions?.group?.tag ?? fileOptions?.group?.path?.split("/").filter(Boolean)[0];
38
+ return {
39
+ path: groupDir ? `${groupDir}/${baseName}` : baseName,
40
+ baseName,
41
+ meta: { pluginName }
42
+ };
43
+ },
44
+ getPlugin(_pluginName) {
45
+ return options?.plugin;
46
+ },
47
+ fileManager: new require_PluginDriver.FileManager()
48
+ };
49
+ }
50
+ /**
51
+ * Creates a minimal `Adapter` mock suitable for unit tests.
52
+ *
53
+ * - `parse` returns an empty `InputNode` by default; override via `options.parse`.
54
+ * - `getImports` returns `[]` by default (single-file mode, no cross-file imports).
55
+ */
56
+ function createMockedAdapter(options = {}) {
57
+ return {
58
+ name: options.name ?? "oas",
59
+ options: options.resolvedOptions ?? {},
60
+ inputNode: options.inputNode ?? null,
61
+ parse: options.parse ?? (async () => ({
62
+ kind: "Input",
63
+ schemas: [],
64
+ operations: []
65
+ })),
66
+ getImports: options.getImports ?? ((_node, _resolve) => [])
67
+ };
68
+ }
69
+ /**
70
+ * Creates a minimal `Plugin` mock suitable for unit tests.
71
+ *
72
+ * @example
73
+ * const plugin = createMockedPlugin<PluginTs>({ name: '@kubb/plugin-ts', options })
74
+ */
75
+ function createMockedPlugin(params) {
76
+ return {
77
+ name: params.name,
78
+ options: params.options,
79
+ resolver: params.resolver,
80
+ transformer: params.transformer,
81
+ dependencies: params.dependencies,
82
+ install: () => {},
83
+ inject: () => void 0
84
+ };
85
+ }
86
+ function createMockedPluginContext(opts) {
87
+ const root = (0, node_path.resolve)(opts.config.root, opts.config.output.path);
88
+ return {
89
+ config: opts.config,
90
+ root,
91
+ getMode: (output) => require_PluginDriver.PluginDriver.getMode((0, node_path.resolve)(root, output.path)),
92
+ adapter: opts.adapter,
93
+ resolver: opts.resolver,
94
+ plugin: opts.plugin,
95
+ driver: opts.driver,
96
+ inputNode: {
97
+ kind: "Input",
98
+ schemas: [],
99
+ operations: []
100
+ },
101
+ upsertFile: async (...files) => opts.driver.fileManager.upsert(...files),
102
+ warn: (msg) => console.warn(msg),
103
+ error: (msg) => console.error(msg),
104
+ info: (msg) => console.info(msg),
105
+ openInStudio: async () => {}
106
+ };
107
+ }
108
+ /**
109
+ * Renders a generator's `schema` method in a test context.
110
+ *
111
+ * @example
112
+ * await renderGeneratorSchema(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })
113
+ * await matchFiles(driver.fileManager.files)
114
+ */
115
+ async function renderGeneratorSchema(generator, node, opts) {
116
+ if (!generator.schema) return;
117
+ const context = createMockedPluginContext(opts);
118
+ const transformedNode = opts.plugin.transformer ? (0, _kubb_ast.transform)(node, opts.plugin.transformer) : node;
119
+ await require_PluginDriver.applyHookResult(await generator.schema(transformedNode, {
120
+ ...context,
121
+ options: opts.options
122
+ }), opts.driver, generator.renderer ?? void 0);
123
+ }
124
+ /**
125
+ * Renders a generator's `operation` method in a test context.
126
+ *
127
+ * @example
128
+ * await renderGeneratorOperation(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })
129
+ * await matchFiles(driver.fileManager.files)
130
+ */
131
+ async function renderGeneratorOperation(generator, node, opts) {
132
+ if (!generator.operation) return;
133
+ const context = createMockedPluginContext(opts);
134
+ const transformedNode = opts.plugin.transformer ? (0, _kubb_ast.transform)(node, opts.plugin.transformer) : node;
135
+ await require_PluginDriver.applyHookResult(await generator.operation(transformedNode, {
136
+ ...context,
137
+ options: opts.options
138
+ }), opts.driver, generator.renderer ?? void 0);
139
+ }
140
+ /**
141
+ * Renders a generator's `operations` method in a test context.
142
+ *
143
+ * @example
144
+ * await renderGeneratorOperations(classClientGenerator, nodes, { config, adapter, driver, plugin, options, resolver })
145
+ * await matchFiles(driver.fileManager.files)
146
+ */
147
+ async function renderGeneratorOperations(generator, nodes, opts) {
148
+ if (!generator.operations) return;
149
+ const context = createMockedPluginContext(opts);
150
+ const transformedNodes = opts.plugin.transformer ? nodes.map((n) => (0, _kubb_ast.transform)(n, opts.plugin.transformer)) : nodes;
151
+ await require_PluginDriver.applyHookResult(await generator.operations(transformedNodes, {
152
+ ...context,
153
+ options: opts.options
154
+ }), opts.driver, generator.renderer ?? void 0);
155
+ }
156
+ //#endregion
157
+ exports.createMockedAdapter = createMockedAdapter;
158
+ exports.createMockedPlugin = createMockedPlugin;
159
+ exports.createMockedPluginDriver = createMockedPluginDriver;
160
+ exports.renderGeneratorOperation = renderGeneratorOperation;
161
+ exports.renderGeneratorOperations = renderGeneratorOperations;
162
+ exports.renderGeneratorSchema = renderGeneratorSchema;
163
+
164
+ //# sourceMappingURL=mocks.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mocks.cjs","names":["FileManager","PluginDriver","applyHookResult"],"sources":["../src/mocks.ts"],"sourcesContent":["import { resolve } from 'node:path'\nimport type { FileNode, OperationNode, SchemaNode, Visitor } from '@kubb/ast'\nimport { transform } from '@kubb/ast'\nimport { FileManager } from './FileManager.ts'\nimport { PluginDriver } from './PluginDriver.ts'\nimport { applyHookResult } from './renderNode.ts'\nimport type {\n Adapter,\n AdapterFactoryOptions,\n Config,\n Generator,\n GeneratorContext,\n Plugin,\n PluginFactoryOptions,\n ResolveNameParams,\n ResolvePathParams,\n} from './types.ts'\n\nfunction toCamelOrPascal(text: string, pascal: boolean): string {\n const normalized = text\n .trim()\n .replace(/([a-z\\d])([A-Z])/g, '$1 $2')\n .replace(/([A-Z]+)([A-Z][a-z])/g, '$1 $2')\n .replace(/(\\d)([a-z])/g, '$1 $2')\n\n const words = normalized.split(/[\\s\\-_./\\\\:]+/).filter(Boolean)\n\n return words\n .map((word, i) => {\n const allUpper = word.length > 1 && word === word.toUpperCase()\n if (allUpper) return word\n if (i === 0 && !pascal) return word.charAt(0).toLowerCase() + word.slice(1)\n return word.charAt(0).toUpperCase() + word.slice(1)\n })\n .join('')\n .replace(/[^a-zA-Z0-9]/g, '')\n}\n\nfunction camelCase(text: string): string {\n return toCamelOrPascal(text, false)\n}\n\nfunction pascalCase(text: string): string {\n return toCamelOrPascal(text, true)\n}\n\n/**\n * Creates a minimal `PluginDriver` mock suitable for unit tests.\n */\nexport function createMockedPluginDriver(options: { name?: string; plugin?: Plugin; config?: Config } = {}): PluginDriver {\n return {\n resolveName: (result: ResolveNameParams) => {\n if (result.type === 'file') {\n return camelCase(options?.name || result.name)\n }\n\n if (result.type === 'type') {\n return pascalCase(result.name)\n }\n\n if (result.type === 'function') {\n return camelCase(result.name)\n }\n\n return camelCase(result.name)\n },\n config: options?.config ?? {\n root: '.',\n output: {\n path: './path',\n },\n },\n resolvePath: ({ baseName }: ResolvePathParams) => baseName,\n getFile: ({\n name,\n extname,\n pluginName,\n options: fileOptions,\n }: {\n name: string\n extname: `.${string}`\n pluginName: string\n options?: { group?: { tag?: string; path?: string } }\n }) => {\n const baseName = `${name}${extname}`\n const groupDir = fileOptions?.group?.tag ?? fileOptions?.group?.path?.split('/').filter(Boolean)[0]\n const filePath = groupDir ? `${groupDir}/${baseName}` : baseName\n\n return {\n path: filePath,\n baseName,\n meta: { pluginName },\n }\n },\n getPlugin(_pluginName: Plugin['name']): Plugin | undefined {\n return options?.plugin\n },\n fileManager: new FileManager(),\n } as unknown as PluginDriver\n}\n\n/**\n * Creates a minimal `Adapter` mock suitable for unit tests.\n *\n * - `parse` returns an empty `InputNode` by default; override via `options.parse`.\n * - `getImports` returns `[]` by default (single-file mode, no cross-file imports).\n */\nexport function createMockedAdapter<TOptions extends AdapterFactoryOptions = AdapterFactoryOptions>(\n options: {\n name?: TOptions['name']\n resolvedOptions?: TOptions['resolvedOptions']\n inputNode?: Adapter<TOptions>['inputNode']\n parse?: Adapter<TOptions>['parse']\n getImports?: Adapter<TOptions>['getImports']\n } = {},\n): Adapter<TOptions> {\n return {\n name: (options.name ?? 'oas') as TOptions['name'],\n options: (options.resolvedOptions ?? {}) as TOptions['resolvedOptions'],\n inputNode: options.inputNode ?? null,\n parse: options.parse ?? (async () => ({ kind: 'Input' as const, schemas: [], operations: [] })),\n getImports: options.getImports ?? ((_node: SchemaNode, _resolve: (schemaName: string) => { name: string; path: string }) => []),\n } as Adapter<TOptions>\n}\n\n/**\n * Creates a minimal `Plugin` mock suitable for unit tests.\n *\n * @example\n * const plugin = createMockedPlugin<PluginTs>({ name: '@kubb/plugin-ts', options })\n */\nexport function createMockedPlugin<TOptions extends PluginFactoryOptions = PluginFactoryOptions>(params: {\n name: TOptions['name']\n options: TOptions['resolvedOptions']\n resolver?: TOptions['resolver']\n transformer?: Visitor\n dependencies?: Array<string>\n}): Plugin<TOptions> {\n return {\n name: params.name,\n options: params.options,\n resolver: params.resolver,\n transformer: params.transformer,\n dependencies: params.dependencies,\n install: () => {},\n inject: () => undefined as TOptions['context'],\n } as unknown as Plugin<TOptions>\n}\n\ntype RenderGeneratorOptions<TOptions extends PluginFactoryOptions> = {\n config: Config\n adapter: Adapter\n driver: PluginDriver\n plugin: Plugin<TOptions>\n options: TOptions['resolvedOptions']\n resolver: TOptions['resolver']\n}\n\nfunction createMockedPluginContext<TOptions extends PluginFactoryOptions>(opts: RenderGeneratorOptions<TOptions>): Omit<GeneratorContext<TOptions>, 'options'> {\n const root = resolve(opts.config.root, opts.config.output.path)\n\n return {\n config: opts.config,\n root,\n getMode: (output: { path: string }) => PluginDriver.getMode(resolve(root, output.path)),\n adapter: opts.adapter,\n resolver: opts.resolver,\n plugin: opts.plugin,\n driver: opts.driver,\n inputNode: { kind: 'Input', schemas: [], operations: [] },\n upsertFile: async (...files: Array<FileNode>) => opts.driver.fileManager.upsert(...files),\n warn: (msg: string) => console.warn(msg),\n error: (msg: string) => console.error(msg),\n info: (msg: string) => console.info(msg),\n openInStudio: async () => {},\n } as unknown as Omit<GeneratorContext<TOptions>, 'options'>\n}\n\n/**\n * Renders a generator's `schema` method in a test context.\n *\n * @example\n * await renderGeneratorSchema(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })\n * await matchFiles(driver.fileManager.files)\n */\nexport async function renderGeneratorSchema<TOptions extends PluginFactoryOptions>(\n generator: Generator<TOptions>,\n node: SchemaNode,\n opts: RenderGeneratorOptions<TOptions>,\n): Promise<void> {\n if (!generator.schema) return\n const context = createMockedPluginContext(opts)\n const transformedNode = opts.plugin.transformer ? transform(node, opts.plugin.transformer) : node\n const result = await generator.schema(transformedNode, { ...context, options: opts.options })\n await applyHookResult(result, opts.driver, generator.renderer ?? undefined)\n}\n\n/**\n * Renders a generator's `operation` method in a test context.\n *\n * @example\n * await renderGeneratorOperation(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })\n * await matchFiles(driver.fileManager.files)\n */\nexport async function renderGeneratorOperation<TOptions extends PluginFactoryOptions>(\n generator: Generator<TOptions>,\n node: OperationNode,\n opts: RenderGeneratorOptions<TOptions>,\n): Promise<void> {\n if (!generator.operation) return\n const context = createMockedPluginContext(opts)\n const transformedNode = opts.plugin.transformer ? transform(node, opts.plugin.transformer) : node\n const result = await generator.operation(transformedNode, { ...context, options: opts.options })\n await applyHookResult(result, opts.driver, generator.renderer ?? undefined)\n}\n\n/**\n * Renders a generator's `operations` method in a test context.\n *\n * @example\n * await renderGeneratorOperations(classClientGenerator, nodes, { config, adapter, driver, plugin, options, resolver })\n * await matchFiles(driver.fileManager.files)\n */\nexport async function renderGeneratorOperations<TOptions extends PluginFactoryOptions>(\n generator: Generator<TOptions>,\n nodes: Array<OperationNode>,\n opts: RenderGeneratorOptions<TOptions>,\n): Promise<void> {\n if (!generator.operations) return\n const context = createMockedPluginContext(opts)\n const transformedNodes = opts.plugin.transformer ? nodes.map((n) => transform(n, opts.plugin.transformer!)) : nodes\n const result = await generator.operations(transformedNodes, { ...context, options: opts.options })\n await applyHookResult(result, opts.driver, generator.renderer ?? undefined)\n}\n"],"mappings":";;;;;AAkBA,SAAS,gBAAgB,MAAc,QAAyB;AAS9D,QARmB,KAChB,MAAM,CACN,QAAQ,qBAAqB,QAAQ,CACrC,QAAQ,yBAAyB,QAAQ,CACzC,QAAQ,gBAAgB,QAAQ,CAEV,MAAM,gBAAgB,CAAC,OAAO,QAAQ,CAG5D,KAAK,MAAM,MAAM;AAEhB,MADiB,KAAK,SAAS,KAAK,SAAS,KAAK,aAAa,CACjD,QAAO;AACrB,MAAI,MAAM,KAAK,CAAC,OAAQ,QAAO,KAAK,OAAO,EAAE,CAAC,aAAa,GAAG,KAAK,MAAM,EAAE;AAC3E,SAAO,KAAK,OAAO,EAAE,CAAC,aAAa,GAAG,KAAK,MAAM,EAAE;GACnD,CACD,KAAK,GAAG,CACR,QAAQ,iBAAiB,GAAG;;AAGjC,SAAS,UAAU,MAAsB;AACvC,QAAO,gBAAgB,MAAM,MAAM;;AAGrC,SAAS,WAAW,MAAsB;AACxC,QAAO,gBAAgB,MAAM,KAAK;;;;;AAMpC,SAAgB,yBAAyB,UAA+D,EAAE,EAAgB;AACxH,QAAO;EACL,cAAc,WAA8B;AAC1C,OAAI,OAAO,SAAS,OAClB,QAAO,UAAU,SAAS,QAAQ,OAAO,KAAK;AAGhD,OAAI,OAAO,SAAS,OAClB,QAAO,WAAW,OAAO,KAAK;AAGhC,OAAI,OAAO,SAAS,WAClB,QAAO,UAAU,OAAO,KAAK;AAG/B,UAAO,UAAU,OAAO,KAAK;;EAE/B,QAAQ,SAAS,UAAU;GACzB,MAAM;GACN,QAAQ,EACN,MAAM,UACP;GACF;EACD,cAAc,EAAE,eAAkC;EAClD,UAAU,EACR,MACA,SACA,YACA,SAAS,kBAML;GACJ,MAAM,WAAW,GAAG,OAAO;GAC3B,MAAM,WAAW,aAAa,OAAO,OAAO,aAAa,OAAO,MAAM,MAAM,IAAI,CAAC,OAAO,QAAQ,CAAC;AAGjG,UAAO;IACL,MAHe,WAAW,GAAG,SAAS,GAAG,aAAa;IAItD;IACA,MAAM,EAAE,YAAY;IACrB;;EAEH,UAAU,aAAiD;AACzD,UAAO,SAAS;;EAElB,aAAa,IAAIA,qBAAAA,aAAa;EAC/B;;;;;;;;AASH,SAAgB,oBACd,UAMI,EAAE,EACa;AACnB,QAAO;EACL,MAAO,QAAQ,QAAQ;EACvB,SAAU,QAAQ,mBAAmB,EAAE;EACvC,WAAW,QAAQ,aAAa;EAChC,OAAO,QAAQ,UAAU,aAAa;GAAE,MAAM;GAAkB,SAAS,EAAE;GAAE,YAAY,EAAE;GAAE;EAC7F,YAAY,QAAQ,gBAAgB,OAAmB,aAAqE,EAAE;EAC/H;;;;;;;;AASH,SAAgB,mBAAiF,QAM5E;AACnB,QAAO;EACL,MAAM,OAAO;EACb,SAAS,OAAO;EAChB,UAAU,OAAO;EACjB,aAAa,OAAO;EACpB,cAAc,OAAO;EACrB,eAAe;EACf,cAAc,KAAA;EACf;;AAYH,SAAS,0BAAiE,MAAqF;CAC7J,MAAM,QAAA,GAAA,UAAA,SAAe,KAAK,OAAO,MAAM,KAAK,OAAO,OAAO,KAAK;AAE/D,QAAO;EACL,QAAQ,KAAK;EACb;EACA,UAAU,WAA6BC,qBAAAA,aAAa,SAAA,GAAA,UAAA,SAAgB,MAAM,OAAO,KAAK,CAAC;EACvF,SAAS,KAAK;EACd,UAAU,KAAK;EACf,QAAQ,KAAK;EACb,QAAQ,KAAK;EACb,WAAW;GAAE,MAAM;GAAS,SAAS,EAAE;GAAE,YAAY,EAAE;GAAE;EACzD,YAAY,OAAO,GAAG,UAA2B,KAAK,OAAO,YAAY,OAAO,GAAG,MAAM;EACzF,OAAO,QAAgB,QAAQ,KAAK,IAAI;EACxC,QAAQ,QAAgB,QAAQ,MAAM,IAAI;EAC1C,OAAO,QAAgB,QAAQ,KAAK,IAAI;EACxC,cAAc,YAAY;EAC3B;;;;;;;;;AAUH,eAAsB,sBACpB,WACA,MACA,MACe;AACf,KAAI,CAAC,UAAU,OAAQ;CACvB,MAAM,UAAU,0BAA0B,KAAK;CAC/C,MAAM,kBAAkB,KAAK,OAAO,eAAA,GAAA,UAAA,WAAwB,MAAM,KAAK,OAAO,YAAY,GAAG;AAE7F,OAAMC,qBAAAA,gBADS,MAAM,UAAU,OAAO,iBAAiB;EAAE,GAAG;EAAS,SAAS,KAAK;EAAS,CAAC,EAC/D,KAAK,QAAQ,UAAU,YAAY,KAAA,EAAU;;;;;;;;;AAU7E,eAAsB,yBACpB,WACA,MACA,MACe;AACf,KAAI,CAAC,UAAU,UAAW;CAC1B,MAAM,UAAU,0BAA0B,KAAK;CAC/C,MAAM,kBAAkB,KAAK,OAAO,eAAA,GAAA,UAAA,WAAwB,MAAM,KAAK,OAAO,YAAY,GAAG;AAE7F,OAAMA,qBAAAA,gBADS,MAAM,UAAU,UAAU,iBAAiB;EAAE,GAAG;EAAS,SAAS,KAAK;EAAS,CAAC,EAClE,KAAK,QAAQ,UAAU,YAAY,KAAA,EAAU;;;;;;;;;AAU7E,eAAsB,0BACpB,WACA,OACA,MACe;AACf,KAAI,CAAC,UAAU,WAAY;CAC3B,MAAM,UAAU,0BAA0B,KAAK;CAC/C,MAAM,mBAAmB,KAAK,OAAO,cAAc,MAAM,KAAK,OAAA,GAAA,UAAA,WAAgB,GAAG,KAAK,OAAO,YAAa,CAAC,GAAG;AAE9G,OAAMA,qBAAAA,gBADS,MAAM,UAAU,WAAW,kBAAkB;EAAE,GAAG;EAAS,SAAS,KAAK;EAAS,CAAC,EACpE,KAAK,QAAQ,UAAU,YAAY,KAAA,EAAU"}
@@ -0,0 +1,74 @@
1
+ import { t as __name } from "./chunk--u3MIqq1.js";
2
+ import { D as PluginFactoryOptions, T as Plugin, n as AdapterFactoryOptions, nt as PluginDriver, ot as Generator, s as Config, t as Adapter } from "./types-C6NCtNqM.js";
3
+ import { OperationNode, SchemaNode, Visitor } from "@kubb/ast";
4
+
5
+ //#region src/mocks.d.ts
6
+ /**
7
+ * Creates a minimal `PluginDriver` mock suitable for unit tests.
8
+ */
9
+ declare function createMockedPluginDriver(options?: {
10
+ name?: string;
11
+ plugin?: Plugin;
12
+ config?: Config;
13
+ }): PluginDriver;
14
+ /**
15
+ * Creates a minimal `Adapter` mock suitable for unit tests.
16
+ *
17
+ * - `parse` returns an empty `InputNode` by default; override via `options.parse`.
18
+ * - `getImports` returns `[]` by default (single-file mode, no cross-file imports).
19
+ */
20
+ declare function createMockedAdapter<TOptions extends AdapterFactoryOptions = AdapterFactoryOptions>(options?: {
21
+ name?: TOptions['name'];
22
+ resolvedOptions?: TOptions['resolvedOptions'];
23
+ inputNode?: Adapter<TOptions>['inputNode'];
24
+ parse?: Adapter<TOptions>['parse'];
25
+ getImports?: Adapter<TOptions>['getImports'];
26
+ }): Adapter<TOptions>;
27
+ /**
28
+ * Creates a minimal `Plugin` mock suitable for unit tests.
29
+ *
30
+ * @example
31
+ * const plugin = createMockedPlugin<PluginTs>({ name: '@kubb/plugin-ts', options })
32
+ */
33
+ declare function createMockedPlugin<TOptions extends PluginFactoryOptions = PluginFactoryOptions>(params: {
34
+ name: TOptions['name'];
35
+ options: TOptions['resolvedOptions'];
36
+ resolver?: TOptions['resolver'];
37
+ transformer?: Visitor;
38
+ dependencies?: Array<string>;
39
+ }): Plugin<TOptions>;
40
+ type RenderGeneratorOptions<TOptions extends PluginFactoryOptions> = {
41
+ config: Config;
42
+ adapter: Adapter;
43
+ driver: PluginDriver;
44
+ plugin: Plugin<TOptions>;
45
+ options: TOptions['resolvedOptions'];
46
+ resolver: TOptions['resolver'];
47
+ };
48
+ /**
49
+ * Renders a generator's `schema` method in a test context.
50
+ *
51
+ * @example
52
+ * await renderGeneratorSchema(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })
53
+ * await matchFiles(driver.fileManager.files)
54
+ */
55
+ declare function renderGeneratorSchema<TOptions extends PluginFactoryOptions>(generator: Generator<TOptions>, node: SchemaNode, opts: RenderGeneratorOptions<TOptions>): Promise<void>;
56
+ /**
57
+ * Renders a generator's `operation` method in a test context.
58
+ *
59
+ * @example
60
+ * await renderGeneratorOperation(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })
61
+ * await matchFiles(driver.fileManager.files)
62
+ */
63
+ declare function renderGeneratorOperation<TOptions extends PluginFactoryOptions>(generator: Generator<TOptions>, node: OperationNode, opts: RenderGeneratorOptions<TOptions>): Promise<void>;
64
+ /**
65
+ * Renders a generator's `operations` method in a test context.
66
+ *
67
+ * @example
68
+ * await renderGeneratorOperations(classClientGenerator, nodes, { config, adapter, driver, plugin, options, resolver })
69
+ * await matchFiles(driver.fileManager.files)
70
+ */
71
+ declare function renderGeneratorOperations<TOptions extends PluginFactoryOptions>(generator: Generator<TOptions>, nodes: Array<OperationNode>, opts: RenderGeneratorOptions<TOptions>): Promise<void>;
72
+ //#endregion
73
+ export { createMockedAdapter, createMockedPlugin, createMockedPluginDriver, renderGeneratorOperation, renderGeneratorOperations, renderGeneratorSchema };
74
+ //# sourceMappingURL=mocks.d.ts.map
package/dist/mocks.js ADDED
@@ -0,0 +1,159 @@
1
+ import "./chunk--u3MIqq1.js";
2
+ import { n as applyHookResult, r as FileManager, t as PluginDriver } from "./PluginDriver-CgXFtmNP.js";
3
+ import { resolve } from "node:path";
4
+ import { transform } from "@kubb/ast";
5
+ //#region src/mocks.ts
6
+ function toCamelOrPascal(text, pascal) {
7
+ return text.trim().replace(/([a-z\d])([A-Z])/g, "$1 $2").replace(/([A-Z]+)([A-Z][a-z])/g, "$1 $2").replace(/(\d)([a-z])/g, "$1 $2").split(/[\s\-_./\\:]+/).filter(Boolean).map((word, i) => {
8
+ if (word.length > 1 && word === word.toUpperCase()) return word;
9
+ if (i === 0 && !pascal) return word.charAt(0).toLowerCase() + word.slice(1);
10
+ return word.charAt(0).toUpperCase() + word.slice(1);
11
+ }).join("").replace(/[^a-zA-Z0-9]/g, "");
12
+ }
13
+ function camelCase(text) {
14
+ return toCamelOrPascal(text, false);
15
+ }
16
+ function pascalCase(text) {
17
+ return toCamelOrPascal(text, true);
18
+ }
19
+ /**
20
+ * Creates a minimal `PluginDriver` mock suitable for unit tests.
21
+ */
22
+ function createMockedPluginDriver(options = {}) {
23
+ return {
24
+ resolveName: (result) => {
25
+ if (result.type === "file") return camelCase(options?.name || result.name);
26
+ if (result.type === "type") return pascalCase(result.name);
27
+ if (result.type === "function") return camelCase(result.name);
28
+ return camelCase(result.name);
29
+ },
30
+ config: options?.config ?? {
31
+ root: ".",
32
+ output: { path: "./path" }
33
+ },
34
+ resolvePath: ({ baseName }) => baseName,
35
+ getFile: ({ name, extname, pluginName, options: fileOptions }) => {
36
+ const baseName = `${name}${extname}`;
37
+ const groupDir = fileOptions?.group?.tag ?? fileOptions?.group?.path?.split("/").filter(Boolean)[0];
38
+ return {
39
+ path: groupDir ? `${groupDir}/${baseName}` : baseName,
40
+ baseName,
41
+ meta: { pluginName }
42
+ };
43
+ },
44
+ getPlugin(_pluginName) {
45
+ return options?.plugin;
46
+ },
47
+ fileManager: new FileManager()
48
+ };
49
+ }
50
+ /**
51
+ * Creates a minimal `Adapter` mock suitable for unit tests.
52
+ *
53
+ * - `parse` returns an empty `InputNode` by default; override via `options.parse`.
54
+ * - `getImports` returns `[]` by default (single-file mode, no cross-file imports).
55
+ */
56
+ function createMockedAdapter(options = {}) {
57
+ return {
58
+ name: options.name ?? "oas",
59
+ options: options.resolvedOptions ?? {},
60
+ inputNode: options.inputNode ?? null,
61
+ parse: options.parse ?? (async () => ({
62
+ kind: "Input",
63
+ schemas: [],
64
+ operations: []
65
+ })),
66
+ getImports: options.getImports ?? ((_node, _resolve) => [])
67
+ };
68
+ }
69
+ /**
70
+ * Creates a minimal `Plugin` mock suitable for unit tests.
71
+ *
72
+ * @example
73
+ * const plugin = createMockedPlugin<PluginTs>({ name: '@kubb/plugin-ts', options })
74
+ */
75
+ function createMockedPlugin(params) {
76
+ return {
77
+ name: params.name,
78
+ options: params.options,
79
+ resolver: params.resolver,
80
+ transformer: params.transformer,
81
+ dependencies: params.dependencies,
82
+ install: () => {},
83
+ inject: () => void 0
84
+ };
85
+ }
86
+ function createMockedPluginContext(opts) {
87
+ const root = resolve(opts.config.root, opts.config.output.path);
88
+ return {
89
+ config: opts.config,
90
+ root,
91
+ getMode: (output) => PluginDriver.getMode(resolve(root, output.path)),
92
+ adapter: opts.adapter,
93
+ resolver: opts.resolver,
94
+ plugin: opts.plugin,
95
+ driver: opts.driver,
96
+ inputNode: {
97
+ kind: "Input",
98
+ schemas: [],
99
+ operations: []
100
+ },
101
+ upsertFile: async (...files) => opts.driver.fileManager.upsert(...files),
102
+ warn: (msg) => console.warn(msg),
103
+ error: (msg) => console.error(msg),
104
+ info: (msg) => console.info(msg),
105
+ openInStudio: async () => {}
106
+ };
107
+ }
108
+ /**
109
+ * Renders a generator's `schema` method in a test context.
110
+ *
111
+ * @example
112
+ * await renderGeneratorSchema(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })
113
+ * await matchFiles(driver.fileManager.files)
114
+ */
115
+ async function renderGeneratorSchema(generator, node, opts) {
116
+ if (!generator.schema) return;
117
+ const context = createMockedPluginContext(opts);
118
+ const transformedNode = opts.plugin.transformer ? transform(node, opts.plugin.transformer) : node;
119
+ await applyHookResult(await generator.schema(transformedNode, {
120
+ ...context,
121
+ options: opts.options
122
+ }), opts.driver, generator.renderer ?? void 0);
123
+ }
124
+ /**
125
+ * Renders a generator's `operation` method in a test context.
126
+ *
127
+ * @example
128
+ * await renderGeneratorOperation(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })
129
+ * await matchFiles(driver.fileManager.files)
130
+ */
131
+ async function renderGeneratorOperation(generator, node, opts) {
132
+ if (!generator.operation) return;
133
+ const context = createMockedPluginContext(opts);
134
+ const transformedNode = opts.plugin.transformer ? transform(node, opts.plugin.transformer) : node;
135
+ await applyHookResult(await generator.operation(transformedNode, {
136
+ ...context,
137
+ options: opts.options
138
+ }), opts.driver, generator.renderer ?? void 0);
139
+ }
140
+ /**
141
+ * Renders a generator's `operations` method in a test context.
142
+ *
143
+ * @example
144
+ * await renderGeneratorOperations(classClientGenerator, nodes, { config, adapter, driver, plugin, options, resolver })
145
+ * await matchFiles(driver.fileManager.files)
146
+ */
147
+ async function renderGeneratorOperations(generator, nodes, opts) {
148
+ if (!generator.operations) return;
149
+ const context = createMockedPluginContext(opts);
150
+ const transformedNodes = opts.plugin.transformer ? nodes.map((n) => transform(n, opts.plugin.transformer)) : nodes;
151
+ await applyHookResult(await generator.operations(transformedNodes, {
152
+ ...context,
153
+ options: opts.options
154
+ }), opts.driver, generator.renderer ?? void 0);
155
+ }
156
+ //#endregion
157
+ export { createMockedAdapter, createMockedPlugin, createMockedPluginDriver, renderGeneratorOperation, renderGeneratorOperations, renderGeneratorSchema };
158
+
159
+ //# sourceMappingURL=mocks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mocks.js","names":[],"sources":["../src/mocks.ts"],"sourcesContent":["import { resolve } from 'node:path'\nimport type { FileNode, OperationNode, SchemaNode, Visitor } from '@kubb/ast'\nimport { transform } from '@kubb/ast'\nimport { FileManager } from './FileManager.ts'\nimport { PluginDriver } from './PluginDriver.ts'\nimport { applyHookResult } from './renderNode.ts'\nimport type {\n Adapter,\n AdapterFactoryOptions,\n Config,\n Generator,\n GeneratorContext,\n Plugin,\n PluginFactoryOptions,\n ResolveNameParams,\n ResolvePathParams,\n} from './types.ts'\n\nfunction toCamelOrPascal(text: string, pascal: boolean): string {\n const normalized = text\n .trim()\n .replace(/([a-z\\d])([A-Z])/g, '$1 $2')\n .replace(/([A-Z]+)([A-Z][a-z])/g, '$1 $2')\n .replace(/(\\d)([a-z])/g, '$1 $2')\n\n const words = normalized.split(/[\\s\\-_./\\\\:]+/).filter(Boolean)\n\n return words\n .map((word, i) => {\n const allUpper = word.length > 1 && word === word.toUpperCase()\n if (allUpper) return word\n if (i === 0 && !pascal) return word.charAt(0).toLowerCase() + word.slice(1)\n return word.charAt(0).toUpperCase() + word.slice(1)\n })\n .join('')\n .replace(/[^a-zA-Z0-9]/g, '')\n}\n\nfunction camelCase(text: string): string {\n return toCamelOrPascal(text, false)\n}\n\nfunction pascalCase(text: string): string {\n return toCamelOrPascal(text, true)\n}\n\n/**\n * Creates a minimal `PluginDriver` mock suitable for unit tests.\n */\nexport function createMockedPluginDriver(options: { name?: string; plugin?: Plugin; config?: Config } = {}): PluginDriver {\n return {\n resolveName: (result: ResolveNameParams) => {\n if (result.type === 'file') {\n return camelCase(options?.name || result.name)\n }\n\n if (result.type === 'type') {\n return pascalCase(result.name)\n }\n\n if (result.type === 'function') {\n return camelCase(result.name)\n }\n\n return camelCase(result.name)\n },\n config: options?.config ?? {\n root: '.',\n output: {\n path: './path',\n },\n },\n resolvePath: ({ baseName }: ResolvePathParams) => baseName,\n getFile: ({\n name,\n extname,\n pluginName,\n options: fileOptions,\n }: {\n name: string\n extname: `.${string}`\n pluginName: string\n options?: { group?: { tag?: string; path?: string } }\n }) => {\n const baseName = `${name}${extname}`\n const groupDir = fileOptions?.group?.tag ?? fileOptions?.group?.path?.split('/').filter(Boolean)[0]\n const filePath = groupDir ? `${groupDir}/${baseName}` : baseName\n\n return {\n path: filePath,\n baseName,\n meta: { pluginName },\n }\n },\n getPlugin(_pluginName: Plugin['name']): Plugin | undefined {\n return options?.plugin\n },\n fileManager: new FileManager(),\n } as unknown as PluginDriver\n}\n\n/**\n * Creates a minimal `Adapter` mock suitable for unit tests.\n *\n * - `parse` returns an empty `InputNode` by default; override via `options.parse`.\n * - `getImports` returns `[]` by default (single-file mode, no cross-file imports).\n */\nexport function createMockedAdapter<TOptions extends AdapterFactoryOptions = AdapterFactoryOptions>(\n options: {\n name?: TOptions['name']\n resolvedOptions?: TOptions['resolvedOptions']\n inputNode?: Adapter<TOptions>['inputNode']\n parse?: Adapter<TOptions>['parse']\n getImports?: Adapter<TOptions>['getImports']\n } = {},\n): Adapter<TOptions> {\n return {\n name: (options.name ?? 'oas') as TOptions['name'],\n options: (options.resolvedOptions ?? {}) as TOptions['resolvedOptions'],\n inputNode: options.inputNode ?? null,\n parse: options.parse ?? (async () => ({ kind: 'Input' as const, schemas: [], operations: [] })),\n getImports: options.getImports ?? ((_node: SchemaNode, _resolve: (schemaName: string) => { name: string; path: string }) => []),\n } as Adapter<TOptions>\n}\n\n/**\n * Creates a minimal `Plugin` mock suitable for unit tests.\n *\n * @example\n * const plugin = createMockedPlugin<PluginTs>({ name: '@kubb/plugin-ts', options })\n */\nexport function createMockedPlugin<TOptions extends PluginFactoryOptions = PluginFactoryOptions>(params: {\n name: TOptions['name']\n options: TOptions['resolvedOptions']\n resolver?: TOptions['resolver']\n transformer?: Visitor\n dependencies?: Array<string>\n}): Plugin<TOptions> {\n return {\n name: params.name,\n options: params.options,\n resolver: params.resolver,\n transformer: params.transformer,\n dependencies: params.dependencies,\n install: () => {},\n inject: () => undefined as TOptions['context'],\n } as unknown as Plugin<TOptions>\n}\n\ntype RenderGeneratorOptions<TOptions extends PluginFactoryOptions> = {\n config: Config\n adapter: Adapter\n driver: PluginDriver\n plugin: Plugin<TOptions>\n options: TOptions['resolvedOptions']\n resolver: TOptions['resolver']\n}\n\nfunction createMockedPluginContext<TOptions extends PluginFactoryOptions>(opts: RenderGeneratorOptions<TOptions>): Omit<GeneratorContext<TOptions>, 'options'> {\n const root = resolve(opts.config.root, opts.config.output.path)\n\n return {\n config: opts.config,\n root,\n getMode: (output: { path: string }) => PluginDriver.getMode(resolve(root, output.path)),\n adapter: opts.adapter,\n resolver: opts.resolver,\n plugin: opts.plugin,\n driver: opts.driver,\n inputNode: { kind: 'Input', schemas: [], operations: [] },\n upsertFile: async (...files: Array<FileNode>) => opts.driver.fileManager.upsert(...files),\n warn: (msg: string) => console.warn(msg),\n error: (msg: string) => console.error(msg),\n info: (msg: string) => console.info(msg),\n openInStudio: async () => {},\n } as unknown as Omit<GeneratorContext<TOptions>, 'options'>\n}\n\n/**\n * Renders a generator's `schema` method in a test context.\n *\n * @example\n * await renderGeneratorSchema(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })\n * await matchFiles(driver.fileManager.files)\n */\nexport async function renderGeneratorSchema<TOptions extends PluginFactoryOptions>(\n generator: Generator<TOptions>,\n node: SchemaNode,\n opts: RenderGeneratorOptions<TOptions>,\n): Promise<void> {\n if (!generator.schema) return\n const context = createMockedPluginContext(opts)\n const transformedNode = opts.plugin.transformer ? transform(node, opts.plugin.transformer) : node\n const result = await generator.schema(transformedNode, { ...context, options: opts.options })\n await applyHookResult(result, opts.driver, generator.renderer ?? undefined)\n}\n\n/**\n * Renders a generator's `operation` method in a test context.\n *\n * @example\n * await renderGeneratorOperation(typeGenerator, node, { config, adapter, driver, plugin, options, resolver })\n * await matchFiles(driver.fileManager.files)\n */\nexport async function renderGeneratorOperation<TOptions extends PluginFactoryOptions>(\n generator: Generator<TOptions>,\n node: OperationNode,\n opts: RenderGeneratorOptions<TOptions>,\n): Promise<void> {\n if (!generator.operation) return\n const context = createMockedPluginContext(opts)\n const transformedNode = opts.plugin.transformer ? transform(node, opts.plugin.transformer) : node\n const result = await generator.operation(transformedNode, { ...context, options: opts.options })\n await applyHookResult(result, opts.driver, generator.renderer ?? undefined)\n}\n\n/**\n * Renders a generator's `operations` method in a test context.\n *\n * @example\n * await renderGeneratorOperations(classClientGenerator, nodes, { config, adapter, driver, plugin, options, resolver })\n * await matchFiles(driver.fileManager.files)\n */\nexport async function renderGeneratorOperations<TOptions extends PluginFactoryOptions>(\n generator: Generator<TOptions>,\n nodes: Array<OperationNode>,\n opts: RenderGeneratorOptions<TOptions>,\n): Promise<void> {\n if (!generator.operations) return\n const context = createMockedPluginContext(opts)\n const transformedNodes = opts.plugin.transformer ? nodes.map((n) => transform(n, opts.plugin.transformer!)) : nodes\n const result = await generator.operations(transformedNodes, { ...context, options: opts.options })\n await applyHookResult(result, opts.driver, generator.renderer ?? undefined)\n}\n"],"mappings":"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"}