Skip to content

Commit

Permalink
fix: add tests, fix types
Browse files Browse the repository at this point in the history
  • Loading branch information
Chaim Lev-Ari committed Jan 9, 2024
1 parent 70864b4 commit d4587aa
Show file tree
Hide file tree
Showing 9 changed files with 121 additions and 43 deletions.
2 changes: 1 addition & 1 deletion e2e/kubb.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const schemas = [
['requestBody', './schemas/requestBody.yaml'],
['box', './schemas/box.json'],
['digitalocean', './schemas/digitalocean.yaml'],
['enums', './schemas/enums.yaml']
['enums', './schemas/enums.yaml'],
]

/** @type {import('@kubb/core').KubbUserConfig} */
Expand Down
39 changes: 39 additions & 0 deletions packages/swagger-faker/mocks/enums.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
definitions:
enumVarNames.Type:
enum:
- 0
- 1
type: integer
x-enum-varnames:
- Pending
- Received
enumNames.Type:
enum:
- 0
- 1
x-enumNames:
- Pending
- Received
swagger: "2.0"
info:
title: test
version: "1.0.0"
paths:
/var-names:
get:
consumes:
- application/json
responses:
200:
description: Success
schema:
$ref: '#/definitions/enumVarNames.Type'
/names:
get:
consumes:
- application/json
responses:
200:
description: Success
schema:
$ref: '#/definitions/enumNames.Type'
33 changes: 33 additions & 0 deletions packages/swagger-faker/src/FakerGenerator.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
import { OasManager } from '@kubb/swagger'
import { FakerGenerator } from './FakerGenerator'
import path from 'node:path'
import { mockedPluginManager } from '@kubb/core/mocks'
import type { OasTypes } from '@kubb/swagger/oas'

describe('FakeGenerator enums', async () => {
const schemaPath = path.resolve(__dirname, '../mocks/enums.yaml')
const oas = await new OasManager().parse(schemaPath)
const generator = new FakerGenerator({
dateType: 'string',
mapper: {},
seed: 1,
transformers: {},
}, {
oas,
pluginManager: mockedPluginManager,
})

const schemas = oas.getDefinition().components?.schemas

test('generate x-enum-varnames types', async () => {
const node = generator.build({ schema: schemas?.['enumVarNames.Type'] as OasTypes.SchemaObject, baseName: 'enumVarNames' })

expect(node).toMatchSnapshot()
})

test('generate x-enumNames types', async () => {
const node = generator.build({ schema: schemas?.['enumNames.Type'] as OasTypes.SchemaObject, baseName: 'enumNames' })

expect(node).toMatchSnapshot()
})
})
21 changes: 9 additions & 12 deletions packages/swagger-faker/src/FakerGenerator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -244,22 +244,19 @@ export class FakerGenerator extends Generator<PluginOptions['resolvedOptions'],
}

if (schema.enum) {
const extensionEnums = (['x-enumNames', 'x-enum-varnames'] as Array<keyof typeof schema>)
.filter(extensionKey => extensionKey in schema)
.map((extensionKey) => {
return [
{
keyword: fakerKeywords.enum,
args: [`[${[...new Set(schema[extensionKey] as string[])].map((value) => `\`${value}\``).join(', ')}]`],
},
]
})

const extensionEnums = ['x-enumNames', 'x-enum-varnames']
.filter(extensionKey => extensionKey in schema)
.map((extensionKey) => [
{
keyword: fakerKeywords.enum,
args: [`[${[...new Set(schema[extensionKey as keyof typeof schema] as string[])].map((value) => `\`${value}\``).join(', ')}]`],
},
])

if (extensionEnums.length > 0 && extensionEnums[0]) {
return extensionEnums[0]
}


if (schema.type === 'number' || schema.type === 'integer') {
return [
{
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html

exports[`FakeGenerator enums > generate x-enum-varnames types 1`] = `
[
"
export function enumVarNames(): NonNullable<EnumVarNames> {
faker.seed(1)
return faker.helpers.arrayElement<any>([\`Pending\`, \`Received\`]);
}
",
]
`;
exports[`FakeGenerator enums > generate x-enumNames types 1`] = `
[
"
export function enumNames(): NonNullable<EnumNames> {
faker.seed(1)
return faker.helpers.arrayElement<any>([\`Pending\`, \`Received\`]);
}
",
]
`;
8 changes: 1 addition & 7 deletions packages/swagger-ts/src/TypeGenerator.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -314,7 +314,6 @@ describe('TypeGenerator with discriminators', async () => {
})
})


describe('TypeGenerator enums', async () => {
const schemaPath = path.resolve(__dirname, '../mocks/enums.yaml')
const oas = await new OasManager().parse(schemaPath)
Expand All @@ -332,10 +331,7 @@ describe('TypeGenerator enums', async () => {

const schemas = oas.getDefinition().components?.schemas


test('generate x-enum-varnames types', async () => {


const node = generator.build({ schema: schemas?.['enumVarNames.Type'] as OasTypes.SchemaObject, baseName: 'enumVarNames' })

const output = print(node, undefined)
Expand All @@ -346,8 +342,6 @@ describe('TypeGenerator enums', async () => {
})

test('generate x-enumNames types', async () => {


const node = generator.build({ schema: schemas?.['enumNames.Type'] as OasTypes.SchemaObject, baseName: 'enumNames' })

const output = print(node, undefined)
Expand All @@ -356,4 +350,4 @@ describe('TypeGenerator enums', async () => {

expect(await format(output)).toMatchSnapshot()
})
})
})
14 changes: 5 additions & 9 deletions packages/swagger-ts/src/TypeGenerator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -280,20 +280,16 @@ export class TypeGenerator extends Generator<PluginOptions['resolvedOptions'], C

let enums: [key: string, value: string | number][] = [...new Set(schema.enum)].map((key) => [key, key])

const extensionEnums : Array<typeof enums> = (['x-enumNames', 'x-enum-varnames'] as Array<keyof typeof schema>)
const extensionEnums: Array<typeof enums> = ['x-enumNames', 'x-enum-varnames']
.filter(extensionKey => extensionKey in schema)
.map((extensionKey) => {
return [...new Set(schema[extensionKey] as string[])].map((key, index) => {
return [key, schema.enum?.[index] as string] as const
})
})

.map((extensionKey) =>
[...new Set(schema[extensionKey as keyof typeof schema] as string[])].map((key, index) => [key, schema.enum?.[index] as string] as const)
)

if (extensionEnums.length > 0 && extensionEnums[0]) {
enums = extensionEnums[0]
}



this.extraNodes.push(
...factory.createEnumDeclaration({
name: transformers.camelCase(enumName),
Expand Down
5 changes: 1 addition & 4 deletions packages/swagger-zod/src/ZodGenerator.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -123,8 +123,6 @@ describe('ZodGenerator lazy import', async () => {
})
})



describe('ZodGenerator enums', async () => {
const schemaPath = path.resolve(__dirname, '../mocks/enums.yaml')
const oas = await new OasManager().parse(schemaPath)
Expand All @@ -140,7 +138,6 @@ describe('ZodGenerator enums', async () => {

const schemas = oas.getDefinition().components?.schemas


test('generate x-enum-varnames types', async () => {
const node = generator.build({ schema: schemas?.['enumVarNames.Type'] as OasTypes.SchemaObject, baseName: 'enumVarNames' })

Expand All @@ -152,4 +149,4 @@ describe('ZodGenerator enums', async () => {

expect(node).toMatchSnapshot()
})
})
})
19 changes: 9 additions & 10 deletions packages/swagger-zod/src/ZodGenerator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -249,23 +249,22 @@ export class ZodGenerator extends Generator<PluginOptions['resolvedOptions'], Co
}

if (schema.enum) {
const extensionEnums = (['x-enumNames', 'x-enum-varnames'] as Array<keyof typeof schema>)
const extensionEnums = ['x-enumNames', 'x-enum-varnames']
.filter(extensionKey => extensionKey in schema)
.map((extensionKey) => {
return [
{
keyword: zodKeywords.enum,
args: [...new Set(schema[extensionKey] as string[])].map((value: string) => `\`${value}\``),
},
...baseItems,
]
return [
{
keyword: zodKeywords.enum,
args: [...new Set(schema[extensionKey as keyof typeof schema] as string[])].map((value: string) => `\`${value}\``),
},
...baseItems,
]
})

if (extensionEnums.length > 0 && extensionEnums[0]) {
return extensionEnums[0]
}


if (schema.type === 'number' || schema.type === 'integer') {
// we cannot use z.enum when enum type is number/integer
return [
Expand Down

0 comments on commit d4587aa

Please sign in to comment.