spring boot
[IntelliJ] Kotlin based 프로젝트에서 KDoc 주석 자동완성
IntelliJ Kotlin based 프로젝트에서 Java based 프로젝트와 같이 KDoc 주석을 시도할 시 자동완성이 되지 않습니다. IntelliJ에서 플러그인 설치로 해결할 수 있습니다. + 참고로 Kotlin에서는 HTML기반의 JavaDoc이 아닌 Markdown 기반 KDoc이라는 것을 사용하며, JavaDoc의 문법을 지원합니다. KDoc 자동완성을 사용하기 하기 위해 새로운 플러그인을 설치합니다. Preferences (⌘ + ,) > Plugins > Marketplace 탭 이동 검색창에 KDoc-er 을 검색해 Install을 눌러 설치합니다. KDoc을 작성하고 싶은 함수 위에서 /** 입력 후 엔터를 누르면 함수의 파라미터를 참조하여 KDoc이 자동완성이 됩니다.
[IntelliJ] 기본 Testing Framework 설정
IntelliJ의 프로젝트를 Gradle로 생성하면 기본 테스트를 Gradle로 돌리게 됩니다. JUnit5로 테스트 하기 위해 Global 설정에서 Gradle 설정을 변경합니다. Preferences (⌘ + ,) > Build, Execution, Deployment > Build Tools > Gradle 탭 이동 Gradle projects 내 Run tests using을 Gradle에서 IntelliJ IDEA로 변경하면 JUnit5로 실행이 가능합니다.
[JPA] ORM #1
ORM(Object Relational Mapping) 정의 객체로 연결을 해준다 라는 의미 SQL언어가 아닌 Application 개발 언어로 DB에 접근 가능하게 하는 툴 Persistence (영속성) API 데이터를 생성한 프로그램이 종료되더라도 사라지지 않는 데이터의 특성 영속성을 갖지 않는 데이터는 단지 메모리 상에서만 존재하기 때문에 프로그램 종료 후 모두 자동 소멸 Persistence Framework 기존의 JDBC 프로그래밍의 복잡함과 번거로움 없이 간단한 작업만으로 DB와 연동되는 시스템을 빠르게 개발할 수 있으며 안정적 구동 보장 SQL Mapper와 ORM으로 구분 SQL Mapper: MyBatis, iBatis ORM: JPA(인터페이스), Hibernate(JPA 구현체) ..
Jackson에서 Boolean 직렬화 시 is가 사라지는 문제
Swagger에서 JSON Request Body를 보는데 DTO랑 이름이 달라요! 발단 여느때와 다름없이 조용히 회사에서 개발을 하고 있는 도중, Swagger로 API 테스트를 위해 요청을 보내는데 debug에서 객체를 보았을 때, 특정 변수만 null로 들어오는 상황이 발생했습니다. 처음에는 JSON key가 잘못됐나 싶어서 다시 작성해보지만 마찬가지였습니다. JSON Body를 다시 한번 봐 보니 Boolean으로 선언한 'isUsing'이라는 변수가 직렬화 시 Swagger 내에서 제가 예상한 isUsing이라는 key와 달리 using으로 표시되는 것이였습니다. 일단 평소와 같이 @JsonProperty 어노테이션을 사용하여 JSON key를 임의로 지정을 했고, Swagger에서는 isUsi..