Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: allow to override only root mock #1338

Merged

Conversation

karlismelderis-mckinsey
Copy link
Contributor

@karlismelderis-mckinsey karlismelderis-mckinsey commented Apr 30, 2024

Status

READY

Description

Allow to override only root of mocked data and type overrideResponse argument as Partial<Type> instead of any

I also regenerated all react hook samples and rerun format for all repo hence there are quite some unrelated diff

Fix #1335

I'll try to find time to do two more follow up PRs:

  • move to yarn 4.x
    • it took me a while to get project working 😵‍💫
  • have only one petstore.yaml for all samples
    • there is a lot of code duplication going on

@melloware melloware added this to the 6.28.0 milestone Apr 30, 2024
@melloware melloware added the mock Related to mock generation label Apr 30, 2024
@melloware
Copy link
Collaborator

I love your ideas of Yarn 4 and cleaning up the tests as I do find it quite overwhelming. Right now it looks like there is a test failure though?

Copy link
Collaborator

@melloware melloware left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed tests

@karlismelderis-mckinsey
Copy link
Contributor Author

I tried failing test in main and it also fails there

break doesn't feel related to my changes 🤔

@karlismelderis-mckinsey
Copy link
Contributor Author

Feels like tests/specifications/polymorphic.yaml is generating impossible type

@melloware
Copy link
Collaborator

You could be right it might not be related to your change.

@karlismelderis-mckinsey
Copy link
Contributor Author

I added a fix for polymorphic.yaml
unless you want to cherrypick in another PR

melloware
melloware previously approved these changes Apr 30, 2024
Copy link
Member

@soartec-lab soartec-lab left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please check some comments. Also, there seem to be some conflicts, so please check those as well.

src/Main.java Outdated Show resolved Hide resolved
@@ -37,8 +37,6 @@ components:
ParentType:
type: object
properties:
value:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you please definition in more detail why this description is no longer necessary?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So in main generated code looks like this:
Notice multiple ...overrideResponse and overrideResponse is of type any

export const getGetPolymorphicResponseResponseMock = (
  overrideResponse: any = {},
): GetPolymorphicResponse200 =>
  faker.helpers.arrayElement([
    {
      key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
      type: faker.helpers.arrayElement([
        faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
        undefined,
      ]),
      value: faker.helpers.arrayElement([{}, undefined]),
      ...overrideResponse,
      ...overrideResponse,
    },
    {
      key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
      type: faker.helpers.arrayElement([
        faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
        undefined,
      ]),
      value: faker.helpers.arrayElement([{}, undefined]),
      ...overrideResponse,
      ...overrideResponse,
    },
  ]);

as this PR stoped overriding nested data in generated code same part looks like this:

export const getGetPolymorphicResponseResponseMock =
  (): GetPolymorphicResponse200 =>
    faker.helpers.arrayElement([
      {
        key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
        type: faker.helpers.arrayElement([
          faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
          undefined,
        ]),
        value: faker.helpers.arrayElement([{}, undefined]),
      },
      {
        key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
        type: faker.helpers.arrayElement([
          faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
          undefined,
        ]),
        value: faker.helpers.arrayElement([{}, undefined]),
      },
    ]);

as spread of any is gone TS starts to complain because GetPolymorphicResponse200 is impossible type

here is a link to TS playground
https://www.typescriptlang.org/play/?#code/C4TwDgpgBACghgJwgO2AFXBDkoF4qiQD2AZrIiupthANoDWEIpBmL8SqNNAugNwAoAQGMiyAM7BynKpBp4oAbwFQoAIQDyGgDIBRAIIA5AFxQA5Jp0HDZgDQqoAZTQAlAJKGA4qbPP3XuwEAXyg4cShRCWBBAQgADzAiBCkAS1QIBBI4YWgOSnllVUYQAH5TSQQ0gHNBVUIIMul86kxaqAA3OAAbAFcG00UoBiZy4ErkKp5TOGQQKCDBIKF6qAARCHEc5AATGeANZGh8PK5MKAAyJQdO3v6oACMiIi6IGcXBeMTk1hx1zZRdlwAO5EBQnWTQS6FDrdPqNCrVd7LM6eCDAGDPEAAWySYAAFilhC4NokJBAAEwABkpCj+W0B+0OUAAPmsNvS9mgQTFIpIoGIIKZUejMTiEPjCcTxKTxBTqQpoUURuYBYFVHVMD5LHojGr1Tc+qYxn17EsRGI+cAQUK0RiutjcQSiSSLXKafhFVBij4rUQ9RrID4-B5PP6YbcfDM5giJoEzbypFGDkcruqvcqzKr7Gn6lqtDqbNn9bDBQQECaHKoAHQ1xQhMKhWamoA

I don't know at which point things got broken because looking at original polymorphic.yaml in swagger editor
value key should be ignored from ParentType

Would make sense to do a followup PR rather than try to fix things in this PR

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for letting me know so politely.
In other words, the mock was originally broken, and by expanding overrideResponse, the error was suppressed and it worked, right?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As you said, the actual failure occurred at a different time, but it is true that what was previously working will no longer work as a result of taking this action.
This will result in the bug being included in the next release unless you follow up after merging this PR.
It doesn't necessarily have to be the same PR, and I think it's better to separate them, but is it possible to follow up at the same time?

Copy link
Contributor

@AllieJonsson AllieJonsson May 3, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One possible solution could be to type the different possibilities, like this:

// GetPolymorphicResponse200 = DescendantOne | DescendantTwo
faker.helpers.arrayElement([
  {
    key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
    type: faker.helpers.arrayElement([
      faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
      undefined,
    ]),
    value: faker.helpers.arrayElement([{}, undefined]),
  } as DescendantOne,
  {
    key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
    type: faker.helpers.arrayElement([
      faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
      undefined,
    ]),
    value: faker.helpers.arrayElement([{}, undefined]),
  } as DescendantTwo,
]);

One improvement here could maybe also be to add the "overridden" type to the array as well? Something like

faker.helpers.arrayElement([
  {
    key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
    type: faker.helpers.arrayElement([
      faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
      undefined,
    ]),
    value: faker.helpers.arrayElement([{}, faker.datatype.boolean(), undefined]),
  } as DescendantOne,
  {
    key: faker.helpers.arrayElement([faker.word.sample(), undefined]),
    type: faker.helpers.arrayElement([
      faker.helpers.arrayElement(['BOOLEAN', 'STRING'] as const),
      undefined,
    ]),
    value: faker.helpers.arrayElement([{}, faker.word.sample(), undefined]),
  } as DescendantTwo,
]);

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

feels like I opened can of worms 😅

Issue is not in faker code, it's GetPolymorphicResponse200 that's broken.
that type cannot be used even outside of faker.

I don't mind to investigate the case but let's consider this

generated types are broken already.
as no-one reported broken types probably it means no-one has such use case in their project.

hence I would argue that we're not actually breaking anyones code.

I'm on vacation next week so any update from my side will arrive with delay if I don't dig up anything today.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So I traveled back to commit where polymorphic.yaml was added

faker code were not typed at that time and generated types behave as shown here

export const getGetPolymorphicResponseMock = () =>
  faker.helpers.arrayElement([
    {
      value: faker.helpers.arrayElement([{}, undefined]),
      key: faker.helpers.arrayElement([faker.random.word(), undefined]),
      type: faker.helpers.arrayElement([
        faker.helpers.arrayElement(['BOOLEAN', 'STRING']),
        undefined,
      ]),
    },
    {
      value: faker.helpers.arrayElement([{}, undefined]),
      key: faker.helpers.arrayElement([faker.random.word(), undefined]),
      type: faker.helpers.arrayElement([
        faker.helpers.arrayElement(['BOOLEAN', 'STRING']),
        undefined,
      ]),
    },
  ]);

I suspect Orval never really supported situation that was created in polymorphic.yaml

According to Official Swagger docs Orval is generating correct types and polymorphic.yaml is broken.

There is no hierarchy in allOf hence data should comply with all schemas thus I don't think ignoring value: Record from ParentType is a way forward.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@karlismelderis-mckinsey

Thank you for investigating.
I understand that Polymorphic is not working and the types being generated are flawed, and the problem manifests itself not only in mocks. What I was concerned about was breaking a working state in an unintentional way.
However, even if we only take care of the mock with this PR, the fundamental problem will not be resolved and it is not essential, so we agree to treat it as a separate issue in favor of the original purpose of this PR.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@soartec-lab generated types are not flawed.
Quite contrary, they show just what polymorphic.yaml intends to.

But polymorphic.yaml is flawed as a test example.
value key should not be part of ParentType schema

Hence if we agree to my change (removal of value from ParentType) I would consider test data fixed and case closed

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@karlismelderis-mckinsey

I see, I understood that there is no problem with the generated type, but the problem is with the OpenAPI definition. If this change causes problems for some users, they will need to modify their own OpenAPI definitions.

I was able to understand correctly. And I think that's correct.

package.json Outdated Show resolved Hide resolved
Copy link
Member

@soartec-lab soartec-lab left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@karlismelderis-mckinsey
I commented, could you please check it?

@soartec-lab
Copy link
Member

@karlismelderis-mckinsey

There is no problem with the source code so far, but since it conflicts with #1199, is it okay to wait a little longer for the response in #1199? And I would like to check the source code again and then merge this. Is it OK?

@melloware
Copy link
Collaborator

Yes that is ok

@soartec-lab
Copy link
Member

@karlismelderis-mckinsey
Yes, I'll merge it. thank you for nice update!

soartec-lab
soartec-lab previously approved these changes May 13, 2024
@soartec-lab
Copy link
Member

Hi @Maxim-Mazurok, I wanna merge this but you are in "request change" status. Could you please check this again?

@Maxim-Mazurok Maxim-Mazurok dismissed their stale review May 13, 2024 11:00

I guess it was fixed

@Maxim-Mazurok
Copy link
Contributor

Hi @Maxim-Mazurok, I wanna merge this but you are in "request change" status. Could you please check this again?

I had a very brief look and dismissed my review, unfortunately don't have a capacity for a full review now

@karlismelderis-mckinsey
Copy link
Contributor Author

@karlismelderis-mckinsey Yes, I'll merge it. thank you for nice update!

Let's merge it before any new conflicts arrive 😉

@soartec-lab soartec-lab merged commit dc18a87 into orval-labs:master May 14, 2024
2 checks passed
@soartec-lab
Copy link
Member

@karlismelderis-mckinsey
OK, I merged it. Let's look forward to the next release together!

@karlismelderis-mckinsey karlismelderis-mckinsey deleted the fix/faker-overrides branch May 14, 2024 11:30
@karlismelderis-mckinsey
Copy link
Contributor Author

@karlismelderis-mckinsey OK, I merged it. Let's look forward to the next release together!

So I know how to plan our time, when do we expect to have next release?

@soartec-lab
Copy link
Member

I think it will be soon.

@anymaniax

Do you have plan to next release soon?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
mock Related to mock generation
Projects
None yet
Development

Successfully merging this pull request may close these issues.

faker override to much for nested object
5 participants