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(msw): simplify combine #1815

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

AllieJonsson
Copy link
Contributor

@AllieJonsson AllieJonsson commented Jan 13, 2025

Status

READY

Description

Rewrite combine.ts a bit to solve some nested all-of, any-of and one-of issues. (hide whitespace in diff view to get a better view of what changed)
Fixes #1807
Fixes #1526
Fixes #1692

Todos

  • Tests
  • Documentation
  • Changelog Entry (unreleased)

@AllieJonsson
Copy link
Contributor Author

I hope we had tests for all previously known cases. I also tried all specs in the linked issues, hope I didn't miss any edge case

melloware
melloware previously approved these changes Jan 13, 2025
@melloware
Copy link
Collaborator

@AllieJonsson this is great! I will let the others review but I know this has been a pain for MSW users.

@anymaniax
Copy link
Collaborator

To be honest I don’t remember all the cases neither 😅. Maybe it’s better to start with that and some tests for each cases that we know for now and build on it after?

@soartec-lab
Copy link
Member

I'll check the operation with several OpenAPIs I have on hand. Please give me a moment.

@soartec-lab soartec-lab self-assigned this Jan 15, 2025
@soartec-lab
Copy link
Member

I checked and there were some regressions. I will report the details again 👍

@soartec-lab
Copy link
Member

@AllieJonsson

The details of the error are below:

paths:
  /pets:
    get:
      operationId: get-pets
      responses:
        '200':
          content:
            application/json:
              schema:
                items:
                  $ref: '#/components/schemas/Pets'
                type: array
          description: OK
components:
  schemas:
    Pets:
      properties:
        petId:
          allOf:
            - $ref: '#/components/schemas/DogId'
            - $ref: '#/components/schemas/CatId'
          nullable: true 
    DogId:
      nullable: true
      type: string
    CatId:
      description: サービス申込者用コンテンツID
      type: string

It seems that an error occurs in the definition when referencing the schema with ref.
generated:

export const getGetPetsResponseMock = (): Pets[] => (Array.from({ length: faker.number.int({ min: 1, max: 10 }) }, (_, i) => i + 1).map(() => ({petId: faker.helpers.arrayElement([{faker.helpers.arrayElement([faker.string.alpha(20), null]),faker.string.alpha(20),}, undefined])})))

and occured error error TS1005: ',' expected.

@AllieJonsson
Copy link
Contributor Author

I checked and there were some regressions. I will report the details again 👍

Great, Ill check it out and try to solve this!

@soartec-lab
Copy link
Member

soartec-lab commented Jan 26, 2025

@AllieJonsson

Thank you. I have confirmed that this case has been fixed 👍
However, it seems that the case still remains. I found that allOf referenced from ref is an error.

/pet:
    get:
      operationId: get-pet
      responses:
        '200':
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Pet'
          description: OK
      tags:
        - Pet
components:
  schemas:
    Pet:
      type: object
      required:
        - id
        - detail
      properties:
        id:
          type: string
        detail:
          allOf:
            - $ref: '#/components/schemas/Name'
    Name:
      type: string

when i auto generated with the above definition, the following error will occur:

Property assignment expected.

18 export const getGetPetResponseMock = (overrideResponse: Partial< Pet > = {}): Pet => ({id: faker.string.alpha(20), detail: faker.string.alpha(20),, ...overrideResponse})

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
4 participants