openapi-generator
openapi-generator copied to clipboard
[BUG][typescript-angular] `anyOf` generates empty `interface` model
Bug Report Checklist
- [x] Have you provided a full/minimal spec to reproduce the issue?
- [x] Have you validated the input using an OpenAPI validator (example)?
- [ ] Have you tested with the latest master to confirm the issue still exists?
- [x] Have you searched for related issues/PRs?
- [x] What's the actual output vs expected output?
- [ ] [Optional] Sponsorship to speed up the bug fix or feature request (example)
Description
anyOf
schema definitions generates an empty interface model.
{
"components": {
"schemas": {
"foo": {
"type": "object",
"properties": {
"bar": {
"anyOf": [{ "type": "number" }, { "type": "string" }] // <------- this
}
}
}
}
}
}
Generates this model
export interface FooBar { // <--- this doesn't represent type `number | string`
}
import { FooBar } from './fooBar';
export interface Foo {
bar?: FooBar;
}
openapi-generator version
This is a regression starting from v6.0.0, it worked in v5.4.0
OpenAPI declaration file content or url
https://github.com/snebjorn/openapi-gen-bug/blob/master/anyof-bug.json
{
"openapi": "3.0.0",
"info": {
"title": "",
"version": ""
},
"paths": {
"/Foos": {
"get": {
"responses": {
"200": {
"description": "",
"content": {
"application/json": {
"schema": {
"$ref": "#/components/schemas/foo"
}
}
}
}
}
}
}
},
"components": {
"schemas": {
"foo": {
"type": "object",
"properties": {
"bar": {
"anyOf": [{ "type": "number" }, { "type": "string" }],
"description": "This is the description for bar"
}
}
}
}
}
}
Generation Details
Generated using only default values, see https://github.com/snebjorn/openapi-gen-bug/blob/59eb4ba55e91f8444add450016fbd5666c04e2ee/openapitools.json#L25-L29
Steps to reproduce
- Clone https://github.com/snebjorn/openapi-gen-bug
- Run yarn install
- Run yarn gen
- Observe empty interface in https://github.com/snebjorn/openapi-gen-bug/blob/master/output-6.1.0/anyof-bug/model/fooBar.ts
Related issues/PRs
Couldn't find any related to empty interfaces but a lot of issues popped up regarding anyOf
, allOf
and oneOf
---- UPDATED ---- This issue was just reported:
- #13538
Suggest a fix
Not exactly sure why bar?: number | string | null;
was changed to bar?: FooBar;
. Interfaces can't extend primitive types.
// An interface cannot extend a primitive type like 'string'; an interface can only extend named types and classes ts(2840)
interface FooBar extends string, number {}
It could be turned into a type
export type FooBar = string | number;
However there is also the issue of the description
. The description is moved to the FooBar interface/type, but the description is describing the property bar
which now looks like this
export interface Foo {
bar?: FooBar; // <--- note the missing description. The description is on `FooBar` which I believe is incorrect.
}
It should look like this
export interface Foo {
/**
* This is the description for bar
*/
bar?: FooBar;
}
@wing328 I've tracked down the issue to being related to the flattening of components which you implemented in #12175
As described in the issue. Flattening of types that use primitive types is troublesome as it cannot be turned into an interface
. This is the case for TypeScript, Java and C# (I assume many others as well).
TL;DR;
"anyOf": [{ "type": "number" }, { "type": "string" }],
cannot be turned into interface FooBar extends string, number
.
Why is the components flattened? What problem does it solve? What is the intended behavior in a generator when a flattened component contains primitive types?
Any fix for this issue? We are facing this exact problem. And this is on the latest version 7.3.0
.
@snebjorn
Hello, any updates? Experiencing the same issue with 7.5.0
Sorry, I stopped working on this a while ago. Feel free to pick it up