Skip to content

Commit

Permalink
fix: wrong discriminator mapping when bundling with derefernce
Browse files Browse the repository at this point in the history
  • Loading branch information
tatomyr committed Aug 15, 2024
1 parent d6580ea commit 2342376
Show file tree
Hide file tree
Showing 8 changed files with 139 additions and 9 deletions.
6 changes: 6 additions & 0 deletions __tests__/bundle/dereferenced-discriminator-mapping/bar.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
type: object
properties:
discriminatedProp:
type: string
bar:
type: boolean
6 changes: 6 additions & 0 deletions __tests__/bundle/dereferenced-discriminator-mapping/foo.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
type: object
properties:
discriminatedProp:
type: string
foo:
type: string
19 changes: 19 additions & 0 deletions __tests__/bundle/dereferenced-discriminator-mapping/main.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
openapi: 3.1.0
info: {}
paths:
/test:
get:
responses:
default:
content:
application/json:
schema:
type: object
discriminator:
propertyName: discriminatedProp
mapping:
Foo: ./foo.yaml
Bar: ./bar.yaml
oneOf:
- $ref: ./foo.yaml
- $ref: ./bar.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
apis:
main:
root: ./main.yaml
87 changes: 87 additions & 0 deletions __tests__/bundle/dereferenced-discriminator-mapping/snapshot.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`E2E bundle dereferenced-discriminator-mapping 1`] = `
openapi: 3.1.0
info: {}
paths:
/test:
get:
responses:
default:
content:
application/json:
schema:
type: object
discriminator:
propertyName: discriminatedProp
mapping:
Foo: '#/components/schemas/foo'
Bar: '#/components/schemas/bar'
oneOf:
- $ref: '#/components/schemas/foo'
- $ref: '#/components/schemas/bar'
components:
schemas:
foo:
type: object
properties:
discriminatedProp:
type: string
foo:
type: string
bar:
type: object
properties:
discriminatedProp:
type: string
bar:
type: boolean
bundling ./main.yaml...
📦 Created a bundle for ./main.yaml at stdout <test>ms.
`;

exports[`E2E bundle with option: dereferenced discriminator mapping should be replaced with correct references to components 1`] = `
openapi: 3.1.0
info: {}
paths:
/test:
get:
responses:
default:
content:
application/json:
schema:
type: object
discriminator:
propertyName: discriminatedProp
mapping:
Foo: '#/components/schemas/foo'
Bar: '#/components/schemas/bar'
oneOf:
- type: object
properties: &ref_0
discriminatedProp:
type: string
foo:
type: string
- type: object
properties: &ref_1
discriminatedProp:
type: string
bar:
type: boolean
components:
schemas:
foo:
type: object
properties: *ref_0
bar:
type: object
properties: *ref_1
bundling main.yaml...
📦 Created a bundle for main.yaml at stdout <test>ms.
`;
11 changes: 11 additions & 0 deletions __tests__/commands.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -523,6 +523,17 @@ describe('E2E', () => {
const result = getCommandOutput(args, folderPath);
(<any>expect(cleanupOutput(result))).toMatchSpecificSnapshot(join(folderPath, 'snapshot.js'));
});

it('discriminator mapping should be replaced with correct references to components', () => {
const folderPath = join(__dirname, `bundle/dereferenced-discriminator-mapping`);
const args = getParams('../../../packages/cli/src/index.ts', 'bundle', [
'main.yaml',
'--dereferenced',
]);

const result = getCommandOutput(args, folderPath);
(<any>expect(cleanupOutput(result))).toMatchSpecificSnapshot(join(folderPath, 'snapshot.js'));
});
});

describe('bundle with long description', () => {
Expand Down
2 changes: 1 addition & 1 deletion jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ module.exports = {
coverageThreshold: {
'packages/core/': {
statements: 80,
branches: 72,
branches: 71,
functions: 74,
lines: 80,
},
Expand Down
14 changes: 6 additions & 8 deletions packages/core/src/bundle.ts
Original file line number Diff line number Diff line change
Expand Up @@ -409,11 +409,7 @@ function makeBundleVisitor(
}

const componentType = mapTypeToComponent('Schema', version)!;
if (dereference) {
saveComponent(componentType, resolved, ctx);
} else {
mapping[name] = saveComponent(componentType, resolved, ctx);
}
mapping[name] = saveComponent(componentType, resolved, ctx);
}
},
};
Expand All @@ -438,9 +434,11 @@ function makeBundleVisitor(
components[componentType] = components[componentType] || {};
const name = getComponentName(target, componentType, ctx);
components[componentType][name] = target.node;
if (version === SpecMajorVersion.OAS3) {
return `#/components/${componentType}/${name}`;
} else if (version === SpecMajorVersion.Async2 || version === SpecMajorVersion.Async3) {
if (
version === SpecMajorVersion.OAS3 ||
version === SpecMajorVersion.Async2 ||
version === SpecMajorVersion.Async3
) {
return `#/components/${componentType}/${name}`;
} else {
return `#/${componentType}/${name}`;
Expand Down

0 comments on commit 2342376

Please sign in to comment.