티스토리 뷰

저희 회사에서는 openapi 스펙으로 api 스펙을 정의하여 백엔드와 프론트엔드간에 api 스펙을 공유하고 있습니다.

프론트엔드에서는 openapi generator에서 제공하는 typescript-axios를 사용하여 타입스크립트로 코드젠을하여 api에 대한 타입 정의를 자동적으로 생성하고 있습니다.

openapi generator에 대한 간단한 소개와 사용하면서 부딪친 버그들을 소개하겠습니다.

openapi generator란

openapi-generator는 위에서 설명한 것 처럼 openapi 스펙으로 정의된 문서를 다양한 코드로 코드젠을 해주는 도구입니다.

 

 install

설치 방법은 공식문서를 참고 하시는 것이 제일 좋습니다. 예시는 brew를 사용하여 설치하는 방법입니다.

brew install openapi-generator

brew tap AdoptOpenJDK/openjdk
brew install --cask adoptopenjdk11
export JAVA_HOME=`/usr/libexec/java_home -v 1.11`

 

npm을 사용하여 설치도 가능합니다

사용방법

간단한 예시: https://github.com/jch1223/openapi-generator/tree/main

 

openapi spec에서 문법을 살펴볼 수 있습니다. 아래처럼 yml파일에 스펙을 정의 한 후

openapi: 3.0.3
info:
  title: test api
  version: 0.0.1
servers:
- url: https://localhost:3000
  description: 로컬호스트
paths:
  /data:
    get:
      summary: 데이터 조희
      description: |-
        데이터 조희
      parameters:
      - name: exampleQueryStirng
        in: query
        schema:
          type: object
          properties:
            nullableSting:
              type: string
              nullable: true
            nullalbeArray:
              type: array
              items:
                type: string
                nullable: true
      responses:
        '200':
          description: 성공 응답으로 데이터를 반환합니다.
          content:
            application/json:
              schema: 
                type: array
                items:
                  type: string
                  nullable: true
                  description: 데이터

 

openapi-generator-cli generate -g typescript-axios -i ./src/schema/openapi.yml -o ./src/api

 

사용한 명령어는 아래와 같은 의미를 지닙니다

-g: 사용할 제너레이터

-i : 스펙 파일 폴더 위치

-o: output 폴더

 

쉘에서 실행을 시키면 타입스크립트 코드를 생성해 주어서 이를 기반으로 api 요청 함수에 대한 타입 정의를 자동화 시킬 수 있습니다.

버그 수정기

생성된 setFlattenedQueryParams 함수에서 null에 대한 처리가 안되는 버그

코드젠을 하면 setFlattenedQueryParams 함수가 생성이 되고 이 함수를 통해서 param을 query string으로 변환해 주는 동작을 합니다. 

생성된 api 함수를 통해서 null이 포함된 param을 넘겨주었을 때 에러가 터지는 문제가 생겼습니다. 그래서 살펴보니 저희 회사에서는 6.2.1(22년 11월 1일 배포) 버전을 사용하고 있었는데, null에 대한 처리가 22년 12월에 수정이되어서 버전을 올리는 것으로 해결하였습니다.

코드젠에서 Array<string | null> 로 안뽑히는 버그

openapi 스펙에서 null에 대한 처리가 되는 것은 3.0.x이상부터 정직적으로 지원되기 시작하였습니다.(관련 내용)

저희는 3.0.x 버전을 사용하고 있었고, 아래와 같이 yml 파일에 스펙을 정의 하였을 때,

paths:
  /data:
    get:
      summary: 데이터 조희
      description: |-
        데이터 조희
      parameters:
      - name: exampleQueryStirng
        in: query
        schema:
          type: object
          properties:
            nullableSting:
              type: string
              nullable: true
            nullalbeArray:
              type: array
              items:
                type: string
                nullable: true

 

export interface DataGetExampleQueryStirngParameter {
    /**
     * 
     * @type {string}
     * @memberof DataGetExampleQueryStirngParameter
     */
    'nullableSting'?: string | null;
    /**
     * 
     * @type {Array<string>}
     * @memberof DataGetExampleQueryStirngParameter
     */
    'nullalbeArray'?: Array<string | null>;
}

 

nullalbeArray의 타입이 Array<string | null> 로 나타나기를 기대하였지만, 결과는 

export interface DataGetExampleQueryStirngParameter {
    /**
     * 
     * @type {string}
     * @memberof DataGetExampleQueryStirngParameter
     */
    'nullableSting'?: string | null;
    /**
     * 
     * @type {Array<string>}
     * @memberof DataGetExampleQueryStirngParameter
     */
    'nullalbeArray'?: Array<string>;
}

 

 Array<string | null> 이 아닌 Array<stiring>으로 코드젠이 되었습니다. string의 경우에는 nullable하게 타입이 잘 나타났지만 array에서는 나타나지 않아서 조사를 해보니 array에 대한 nullable이 버그가 있다는 것을 알게 되었습니다.

issue: https://github.com/OpenAPITools/openapi-generator/issues/13445

 

[BUG] [typescript-axios] Nullable addtional properites are generated as not nullable · Issue #13445 · OpenAPITools/openapi-gen

Bug Report Checklist Have you provided a full/minimal spec to reproduce the issue? Have you validated the input using an OpenAPI validator (example)? Have you tested with the latest master to confi...

github.com

array에 대한 nullable 처리를 타입 캐스팅이나 null 대신 ""(빈문자열)을 보내는 것을 고려했었는데, 이런 버그가 있다는 것을 프론트엔드 팀에 공유하니 구성원께서 버그 픽스 기여를 해주셔서 nullable 타입을 사용할 수 있게 되었습니다.

 

아직 정식 배포는 되지 않아서(정식배포는 24년 8월 예정) openapi-generator를 클론 받아서 실행 할 수 있는 방법을 간략히 정리하자면

클론을 받은 후에 해당 레포 위치에서 아래 shell 스크립트를 실행합니다

./mvnw clean install

 

설치까지 꽤나 오랜 시간이 소요됩니다. 그 후 해당 레포 위치에서 아래 shell 스크립트를 실행하면 array도 nullable하게 코드젠이 잘 작동 합니다.

java -jar modules/openapi-generator-cli/target/openapi-generator-cli.jar generate \
  -i samples/client/openapi.yml \
  -g typescript-axios\
  -o samples/client/typescript

 

반응형
댓글