Skip to content

Commit

Permalink
fix(plugin): Fix nullable enum not having a proper enum type
Browse files Browse the repository at this point in the history
  • Loading branch information
Spissable committed Aug 5, 2023
1 parent 6555285 commit b304148
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 2 deletions.
3 changes: 2 additions & 1 deletion lib/plugin/utils/plugin-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -294,7 +294,8 @@ export function isAutoGeneratedTypeUnion(type: ts.Type): boolean {
return false;
}
const undefinedTypeIndex = type.types.findIndex(
(type: any) => type.intrinsicName === 'undefined'
(type: any) =>
type.intrinsicName === 'undefined' || type.intrinsicName === 'null'
);

// "strict" mode for non-enum properties
Expand Down
25 changes: 24 additions & 1 deletion test/plugin/fixtures/nullable.dto.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
export const nullableDtoText = `
enum OneValueEnum {
ONE
}
export class NullableDto {
@ApiProperty()
stringValue: string | null;
Expand All @@ -8,13 +12,23 @@ export class NullableDto {
optionalString?: string;
@ApiProperty()
undefinedString: string | undefined;
@ApiProperty()
nullableEnumValue: OneValueEnum | null;
@ApiProperty()
optionalEnumValue?: OneValueEnum;
@ApiProperty()
undefinedEnumValue: OneValueEnum | undefined;
}
`;

export const nullableDtoTextTranspiled = `import * as openapi from "@nestjs/swagger";
var OneValueEnum;
(function (OneValueEnum) {
OneValueEnum[OneValueEnum["ONE"] = 0] = "ONE";
})(OneValueEnum || (OneValueEnum = {}));
export class NullableDto {
static _OPENAPI_METADATA_FACTORY() {
return { stringValue: { required: true, type: () => String, nullable: true }, stringArr: { required: true, type: () => [String], nullable: true }, optionalString: { required: false, type: () => String }, undefinedString: { required: true, type: () => String } };
return { stringValue: { required: true, type: () => String, nullable: true }, stringArr: { required: true, type: () => [String], nullable: true }, optionalString: { required: false, type: () => String }, undefinedString: { required: true, type: () => String }, nullableEnumValue: { required: true, nullable: true, enum: OneValueEnum }, optionalEnumValue: { required: false, enum: OneValueEnum }, undefinedEnumValue: { required: true, enum: OneValueEnum } };
}
}
__decorate([
Expand All @@ -29,4 +43,13 @@ __decorate([
__decorate([
ApiProperty()
], NullableDto.prototype, "undefinedString", void 0);
__decorate([
ApiProperty()
], NullableDto.prototype, "nullableEnumValue", void 0);
__decorate([
ApiProperty()
], NullableDto.prototype, "optionalEnumValue", void 0);
__decorate([
ApiProperty()
], NullableDto.prototype, "undefinedEnumValue", void 0);
`;

0 comments on commit b304148

Please sign in to comment.