토리맘의 한글라이즈 프로젝트 logo 토리맘의 한글라이즈 프로젝트

스프링 부트 공식 레퍼런스를 한글로 번역한 문서입니다.

전체 목차는 여기에 있습니다.

목차


7.30. Kotlin support

코틀린은 JVM(혹은 다른 플랫폼)을 위한 정적 타입 언어statically-typed language로, 간결하고 우아한 코드를 작성할 수 있으며 기존에 자바로 작성된 라이브러리와도 뛰어난 상호 운용성을 자랑하는 언어다.

스프링 부트에서도 코틀린을 사용할 수 있으며, 스프링 프레임워크, 스프링 데이터, 리액터 같은 다른 스프링 프로젝트에서 지원하는 코틀린 지원 기능을 그대로 활용한다. 자세한 내용은 스프링 프레임워크의 코틀린 지원 문서를 참고해라.

여기 있는 포괄적인 튜토리얼을 따라하면 스프링 부트와 코틀린을 가장 쉽게 시작해볼 수 있다. 코틀린 프로젝트를 새로 만들 때는 start.spring.io를 활용해도 된다. Kotlin Slack의 #spring 채널에는 자유롭게 참여할 수 있으며, 지원이 필요하다면 Stack Overflowspring, kotlin 태그를 달아 질문을 올려도 좋다.

7.30.1. Requirements

스프링 부트에선 최소한 코틀린 1.3.x가 필요하며, dependency management를 통해 코틀린 버전을 적절히 관리한다. 코틀린을 사용하려면 클래스패스에 반드시 org.jetbrains.kotlin:kotlin-stdliborg.jetbrains.kotlin:kotlin-reflect가 있어야 한다. kotlin-stdlib의 다른 버전인 kotlin-stdlib-jdk7kotlin-stdlib-jdk8을 사용해도 된다.

코틀린 클래스는 기본이 final이기 때문에, 스프링 어노테이션을 선언한 클래스를 프록시 처리하려면 자동으로 open으로 변경할 수 있도록 kotlin-spring 플러그인을 설정해야 할 거다.

Jackson의 코틀린 모듈은 코틀린에서 JSON 데이터를 직렬화/역직렬화할 때 필요하다. 클래스패스에서 발견되면 자동으로 등록한다. Jackson과 코틀린은 있지만 Jackson 코틀린 모듈이 없을 땐 경고 메세지를 출력한다.

start.spring.io에서 코틀린 프로젝트를 부트스트랩하면 이런 의존성과 플러그인들을 기본으로 제공한다.

7.30.2. Null-safety

코틀린의 핵심 기능 중 하나를 꼽자면 null safety다. 런타임까지 문제를 미루다가 NullPointerException을 만나는 대신, 컴파일 타임에 null 값을 핸들링할 수 있다. 덕분에 Optional같은 래퍼를 감수하지 않고도 흔한 버그의 원인을 제거할 수 있다. 게다가 코틀린은, 코트린의 null-safety 종합 가이드에서도 설명하고 있지만, 함수형 구조에서도 nullable 값을 활용할 수 있다.

자바의 타입 시스템에서는 null을 안전하게 표현할 수 있는 방법이 없지만, 스프링 프레임워크, 스프링 데이터, 리액터는 이제 사용하기 편한 어노테이션들을 통해 null-safety를 지원한다. 코틀린에서 사용하는 자바 API 타입은 기본적으로 null 체크를 완화시키는 플랫폼 타입으로 인지한다. 코틀린은 JSR 305 어노테이션을 지원하는데, nullability 어노테이션과 결합하면 코틀린을 사용하는 관련 스프링 API에 null-safety를 제공할 수 있다.

-Xjsr305={strict|warn|ignore} 옵션과 함께 컴파일러 플래그에 -Xjsr305를 사용하면 JSR 305를 체크할 수 있다. 기본 동작은 -Xjsr305=warn과 동일하다. 스프링 API에서 코틀린 타입을 추론할 때 null-safety를 고려하려면 strict를 사용해야 하지만, 스프링 API nullability 선언은 마이너 릴리즈에서도 더 추가될 수 있고, 향후엔 더 많은 검사가 추가될 수도 있다는 점을 유념하고 사용해야 한다.

제네릭 타입 인자, 가변 인자, 배열 요소는 아직 nullability를 지원하지 않는다. 최신 정보는 SPR-15942를 참고해라. 스프링 부트의 자체 API에는 아직 어노테이션이 없다는 점도 알아둬라.

7.30.3. Kotlin API

스프링 부트는 다음 예제와 같이 좀 더 자연스럽게 애플리케이션을 실행시킬 수 있는 runApplication<MyApplication>(*args)를 제공한다:

import org.springframework.boot.autoconfigure.SpringBootApplication
import org.springframework.boot.runApplication

@SpringBootApplication
class MyApplication

fun main(args: Array<String>) {
    runApplication<MyApplication>(*args)
}

이 코드로는 아무런 사이드 이팩트 없이 SpringApplication.run(MyApplication::class.java, *args)를 대체할 수 있다drop-in replacement. 아래처럼 애플리케이션을 커스텀할 수도 있다:

runApplication<MyApplication>(*args) {
    setBannerMode(OFF)
}

Extensions

코틀린 익스텐션을 사용하면 기존에 있는 클래스를 확장해서 추가 기능을 넣을 수 있다. 스프링 부트 코틀린 API는 기존 API에 이 익스텐션을 적용해서, 코틀린 전용 API들을 추가로 활용할 수 있게 해준다.

스프링 프레임워크가 RestOperations를 위한 익스텐션을 제공하는 것처럼, 스프링 부트도 이와 유사한 TestRestTemplate 익스텐션을 제공한다. 무엇보다 이 익스텐션을 사용하면 Kotlin reified type parameters를 활용할 수 있다.

7.30.4. Dependency management

클래스패스에 버전이 서로 다른 코틀린 의존성이 섞이지 않도록, 스프링 부트는 코틀린 BOM을 임포트한다.

메이븐에선 kotlin.version 프로퍼티를 통해 코틀린 버전을 커스텀할 수 있으며, kotlin-maven-plugin을 위한 plugin management를 제공한다. 그래들에선 스프링 부트 플러그인이 자동으로 kotlin.version을 코틀린 플러그인 버전과 맞춰준다.

스프링 부트는 코틀린 코루틴 BOM을 임포트해서 코루틴 의존성 버전도 관리하고 있다. 이 버전은 kotlin-coroutines.version 프로퍼티를 통해 커스텀할 수 있다.

start.spring.io에서 프로젝트를 부트스트랩할 땐 리액티브 의존성이 최소 하나라도 있으면 기본으로 org.jetbrains.kotlinx:kotlinx-coroutines-reactor 의존성을 제공한다.

7.30.5. @ConfigurationProperties

@ConfigurationProperties@ConstructorBinding과 함께 사용하면 다음 예제처럼 클래스에 불변immutable val 프로퍼티를 선언할 수 있다:

@ConstructorBinding
@ConfigurationProperties("example.kotlin")
data class KotlinExampleProperties(
        val name: String,
        val description: String,
        val myService: MyService) {

    data class MyService(
            val apiToken: String,
            val uri: URI
    )
}

어노테이션 프로세서를 사용해 자체 메타데이터를 생성하려면 spring-boot-configuration-processor 의존성을 통해 kapt를 설정해줘야 한다. kapt에서 제공하는 모델의 제약으로 인해 일부 기능(ex. 기본값이나 deprecated된 항목 감지)은 동작하지 않는다는 점에 주의해라.

7.30.6. Testing

코틀린 코드는 JUnit 4로도 테스트할 수 있지만, 기본적으론 JUnit 5를 제공하며 권장하는 버전이기도 하다. JUnit 5를 사용하면 테스트 클래스 인스턴스를 한 번만 만들고 그 클래스에 있는 모든 테스트에 재사용할 수 있다. 덕분에 non-static 메소드에 @BeforeAll@AfterAll 어노테이션을 사용할 수 있으며, 코틀린에서 사용하기에도 적합하다.

코틀린 클래스를 모킹할 때는 MockK를 권장한다. Mockito 전용 @MockBean, @SpyBean 어노테이션을 대신할 수 있는 Mockk를 찾고 있다면, 유사한 @MockkBean, @SpykBean 어노테이션을 제공하는 SpringMockK를 사용할 수 있다.

7.30.7. Resources

읽을 거리

예제


전체 목차는 여기에 있습니다.

<< >>

TOP