diff options
| author | ST-DDT <[email protected]> | 2022-04-07 16:08:09 +0200 |
|---|---|---|
| committer | GitHub <[email protected]> | 2022-04-07 16:08:09 +0200 |
| commit | 5aa8eeb3649955bf03239e93c4b87b1bc874cb2e (patch) | |
| tree | a2c33ddc66ff7a313e7ae40ff6d175e2fcc0644b /test/scripts | |
| parent | 81171c9f9f2e548f9a86eaae3683ead7e28dbd72 (diff) | |
| download | faker-5aa8eeb3649955bf03239e93c4b87b1bc874cb2e.tar.xz faker-5aa8eeb3649955bf03239e93c4b87b1bc874cb2e.zip | |
test: add parameter defaults to our signature generation test (#793)
Diffstat (limited to 'test/scripts')
| -rw-r--r-- | test/scripts/apidoc/signature.example.ts | 114 | ||||
| -rw-r--r-- | test/scripts/apidoc/signature.expected.json | 100 | ||||
| -rw-r--r-- | test/scripts/apidoc/signature.spec.ts | 17 |
3 files changed, 226 insertions, 5 deletions
diff --git a/test/scripts/apidoc/signature.example.ts b/test/scripts/apidoc/signature.example.ts index b413dd20..16dae935 100644 --- a/test/scripts/apidoc/signature.example.ts +++ b/test/scripts/apidoc/signature.example.ts @@ -1,3 +1,63 @@ +/** + * Parameter options type with default from signature. + */ +export type ParameterOptionsTypeA = { + /** + * Options value. + */ + value?: number; +}; + +/** + * Parameter options type with default from jsdocs. Defaults to `{value: 0}`. + */ +export type ParameterOptionsTypeB = { + /** + * Options value. + */ + value?: number; +}; + +/** + * Parameter options type with default from inner jsdocs. + */ +export type ParameterOptionsTypeC = { + /** + * Options value. Defaults to `0`. + */ + value?: number; +}; + +/** + * Parameter options type with default from signature. + */ +export interface ParameterOptionsInterfaceA { + /** + * Options value. + */ + value?: number; +} + +/** + * Parameter options type with default from jsdocs. + */ +export interface ParameterOptionsInterfaceB { + /** + * Options value. + */ + value?: number; +} + +/** + * Parameter options type with default from inner jsdocs. + */ +export interface ParameterOptionsInterfaceC { + /** + * Options value. Defaults to `0`. + */ + value?: number; +} + export class SignatureTest { /** * Test with no parameters. @@ -72,6 +132,60 @@ export class SignatureTest { } /** + * Test with a function parameters (inline types) with defaults. + * + * @param a Parameter with signature default. + * @param a.value The number parameter. + * @param b Parameter with jsdocs default. Defaults to `{ value: 1 }`. + * @param b.value The boolean parameter. + * @param c Parameter with inner jsdocs default. + * @param c.value The boolean parameter. Defaults to `2`. + */ + optionsInlineParamMethodWithDefaults( + a: { value?: number } = { value: 1 }, + b: { value?: number }, + c: { value?: number } + ): number { + return a.value ?? b.value ?? c.value ?? -1; + } + + /** + * Test with a function parameters with defaults. + * + * @param a Parameter with signature default. + * @param a.value The number parameter. + * @param b Parameter with jsdocs default. Defaults to `{ value: 1 }`. + * @param b.value The boolean parameter. + * @param c Parameter with inner jsdocs default. + * @param c.value The boolean parameter. Defaults to `2`. + */ + optionsTypeParamMethodWithDefaults( + a: ParameterOptionsTypeA = { value: 1 }, + b: ParameterOptionsTypeB, + c: ParameterOptionsTypeC + ): number { + return a.value ?? b.value ?? c.value ?? -1; + } + + /** + * Test with a function parameters with defaults. + * + * @param a Parameter with signature default. + * @param a.value The number parameter. + * @param b Parameter with jsdocs default. Defaults to `{ value: 1 }`. + * @param b.value The boolean parameter. + * @param c Parameter with inner jsdocs default. + * @param c.value The boolean parameter. Defaults to `2`. + */ + optionsInterfaceParamMethodWithDefaults( + a: ParameterOptionsInterfaceA = { value: 1 }, + b: ParameterOptionsInterfaceB, + c: ParameterOptionsInterfaceC + ): number { + return a.value ?? b.value ?? c.value ?? -1; + } + + /** * Test with example marker. * * @example diff --git a/test/scripts/apidoc/signature.expected.json b/test/scripts/apidoc/signature.expected.json index da7c2e87..f6e398fe 100644 --- a/test/scripts/apidoc/signature.expected.json +++ b/test/scripts/apidoc/signature.expected.json @@ -89,6 +89,106 @@ "deprecated": false, "seeAlsos": [] }, + "optionsInlineParamMethodWithDefaults": { + "name": "optionsInlineParamMethodWithDefaults", + "title": "Options Inline Param Method With Defaults", + "description": "<p>Test with a function parameters (inline types) with defaults.</p>\n", + "parameters": [ + { + "name": "a", + "type": "{ ... }", + "default": "{ value: 1 }", + "description": "<p>Parameter with signature default.</p>\n" + }, + { + "name": "a.value?", + "type": "number", + "description": "<p>The number parameter.</p>\n" + }, + { + "name": "b", + "type": "{ ... }", + "default": "{ value: 1 }", + "description": "<p>Parameter with jsdocs default.</p>\n" + }, + { + "name": "b.value?", + "type": "number", + "description": "<p>The boolean parameter.</p>\n" + }, + { + "name": "c", + "type": "{ ... }", + "description": "<p>Parameter with inner jsdocs default.</p>\n" + }, + { + "name": "c.value?", + "type": "number", + "default": "2", + "description": "<p>The boolean parameter.</p>\n" + } + ], + "returns": "number", + "examples": "<div class=\"language-ts\"><pre v-pre><code>faker<span class=\"token punctuation\">.</span><span class=\"token function\">optionsInlineParamMethodWithDefaults</span><span class=\"token punctuation\">(</span>a<span class=\"token operator\">:</span> <span class=\"token punctuation\">{</span>\n value<span class=\"token operator\">:</span> <span class=\"token builtin\">number</span>\n<span class=\"token punctuation\">}</span> <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> value<span class=\"token operator\">:</span> <span class=\"token number\">1</span> <span class=\"token punctuation\">}</span><span class=\"token punctuation\">,</span> b<span class=\"token operator\">:</span> <span class=\"token punctuation\">{</span>\n value<span class=\"token operator\">:</span> <span class=\"token builtin\">number</span>\n<span class=\"token punctuation\">}</span> <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> value<span class=\"token operator\">:</span> <span class=\"token number\">1</span> <span class=\"token punctuation\">}</span><span class=\"token punctuation\">,</span> c<span class=\"token operator\">:</span> <span class=\"token punctuation\">{</span>\n value<span class=\"token operator\">:</span> <span class=\"token builtin\">number</span>\n<span class=\"token punctuation\">}</span><span class=\"token punctuation\">)</span><span class=\"token operator\">:</span> <span class=\"token builtin\">number</span>\n</code></pre>\n</div>", + "deprecated": false, + "seeAlsos": [] + }, + "optionsInterfaceParamMethodWithDefaults": { + "name": "optionsInterfaceParamMethodWithDefaults", + "title": "Options Interface Param Method With Defaults", + "description": "<p>Test with a function parameters with defaults.</p>\n", + "parameters": [ + { + "name": "a", + "type": "ParameterOptionsInterfaceA", + "default": "{ value: 1 }", + "description": "<p>Parameter with signature default.</p>\n" + }, + { + "name": "b", + "type": "ParameterOptionsInterfaceB", + "default": "{ value: 1 }", + "description": "<p>Parameter with jsdocs default.</p>\n" + }, + { + "name": "c", + "type": "ParameterOptionsInterfaceC", + "description": "<p>Parameter with inner jsdocs default.</p>\n" + } + ], + "returns": "number", + "examples": "<div class=\"language-ts\"><pre v-pre><code>faker<span class=\"token punctuation\">.</span><span class=\"token function\">optionsInterfaceParamMethodWithDefaults</span><span class=\"token punctuation\">(</span>a<span class=\"token operator\">:</span> ParameterOptionsInterfaceA <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> value<span class=\"token operator\">:</span> <span class=\"token number\">1</span> <span class=\"token punctuation\">}</span><span class=\"token punctuation\">,</span> b<span class=\"token operator\">:</span> ParameterOptionsInterfaceB <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> value<span class=\"token operator\">:</span> <span class=\"token number\">1</span> <span class=\"token punctuation\">}</span><span class=\"token punctuation\">,</span> c<span class=\"token operator\">:</span> ParameterOptionsInterfaceC<span class=\"token punctuation\">)</span><span class=\"token operator\">:</span> <span class=\"token builtin\">number</span>\n</code></pre>\n</div>", + "deprecated": false, + "seeAlsos": [] + }, + "optionsTypeParamMethodWithDefaults": { + "name": "optionsTypeParamMethodWithDefaults", + "title": "Options Type Param Method With Defaults", + "description": "<p>Test with a function parameters with defaults.</p>\n", + "parameters": [ + { + "name": "a", + "type": "ParameterOptionsTypeA", + "default": "{ value: 1 }", + "description": "<p>Parameter with signature default.</p>\n" + }, + { + "name": "b", + "type": "ParameterOptionsTypeB", + "default": "{ value: 1 }", + "description": "<p>Parameter with jsdocs default.</p>\n" + }, + { + "name": "c", + "type": "ParameterOptionsTypeC", + "description": "<p>Parameter with inner jsdocs default.</p>\n" + } + ], + "returns": "number", + "examples": "<div class=\"language-ts\"><pre v-pre><code>faker<span class=\"token punctuation\">.</span><span class=\"token function\">optionsTypeParamMethodWithDefaults</span><span class=\"token punctuation\">(</span>a<span class=\"token operator\">:</span> ParameterOptionsTypeA <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> value<span class=\"token operator\">:</span> <span class=\"token number\">1</span> <span class=\"token punctuation\">}</span><span class=\"token punctuation\">,</span> b<span class=\"token operator\">:</span> ParameterOptionsTypeB <span class=\"token operator\">=</span> <span class=\"token punctuation\">{</span> value<span class=\"token operator\">:</span> <span class=\"token number\">1</span> <span class=\"token punctuation\">}</span><span class=\"token punctuation\">,</span> c<span class=\"token operator\">:</span> ParameterOptionsTypeC<span class=\"token punctuation\">)</span><span class=\"token operator\">:</span> <span class=\"token builtin\">number</span>\n</code></pre>\n</div>", + "deprecated": false, + "seeAlsos": [] + }, "optionalStringParamMethod": { "name": "optionalStringParamMethod", "title": "Optional String Param Method", diff --git a/test/scripts/apidoc/signature.spec.ts b/test/scripts/apidoc/signature.spec.ts index f536a219..d550dfd2 100644 --- a/test/scripts/apidoc/signature.spec.ts +++ b/test/scripts/apidoc/signature.spec.ts @@ -4,6 +4,8 @@ import * as TypeDoc from 'typedoc'; import { afterAll, describe, expect, it } from 'vitest'; import type { Method } from '../../../docs/.vitepress/components/api-docs/method'; import { analyzeSignature } from '../../../scripts/apidoc/signature'; +import { newTypeDocApp, patchProject } from '../../../scripts/apidoc/utils'; +import { SignatureTest } from './signature.example'; import expected_ from './signature.expected.json'; const expected: Record<string, Method> = expected_; @@ -12,17 +14,18 @@ function prettyJson(object): string { } describe('signature', () => { - const app = new TypeDoc.Application(); - - app.options.addReader(new TypeDoc.TSConfigReader()); + const app = newTypeDocApp(); app.bootstrap({ entryPoints: ['test/scripts/apidoc/signature.example.ts'], tsconfig: 'test/scripts/apidoc/tsconfig.json', }); - const methods: Record<string, TypeDoc.DeclarationReflection> = app - .convert() + const project = app.convert(); + + patchProject(project); + + const methods: Record<string, TypeDoc.DeclarationReflection> = project .getChildrenByKind(TypeDoc.ReflectionKind.Class)[0] .getChildrenByKind(TypeDoc.ReflectionKind.Method) .reduce((a, v) => ({ ...a, [v.name]: v }), {}); @@ -30,6 +33,10 @@ describe('signature', () => { describe('analyzeSignature()', () => { const actuals = {}; + it('dummy dependency to rerun the test if the example changes', () => { + expect(new SignatureTest()).toBeTruthy(); + }); + it('expected and actual methods are equal', () => { expect(Object.keys(methods).sort()).toEqual(Object.keys(expected).sort()); }); |
