在 JVM 中使用 JUnit 测试代码 – 教程
本教程将向你展示如何在 Kotlin/JVM 项目中编写一个简单的单元测试,并使用 Gradle 构建工具运行它。
在此项目中,你将使用 kotlin.test 库,并使用 JUnit 运行测试。 如果你正在开发多平台应用,请参阅 Kotlin 多平台教程。
首先,下载并安装最新版 IntelliJ IDEA 以开始。
添加依赖项
在 IntelliJ IDEA 中打开一个 Kotlin 项目。如果你没有项目,创建一个。
打开
build.gradle(.kts)文件,并检测testImplementation依赖项是否存在。此依赖项允许你使用kotlin.test和JUnit:kotlindependencies { // Other dependencies. testImplementation(kotlin("test")) }groovydependencies { // Other dependencies. testImplementation 'org.jetbrains.kotlin:kotlin-test' }将
test任务添加到build.gradle(.kts)文件:kotlintasks.test { useJUnitPlatform() }groovytest { useJUnitPlatform() }如果你在构建脚本中使用
useJUnitPlatform()函数,kotlin-test库会自动将 JUnit 5 作为依赖项包含进来。此设置允许在仅 JVM 项目和 Kotlin 多平台 (KMP) 项目的 JVM 测试中访问所有 JUnit 5 API 以及kotlin-testAPI。
以下是 build.gradle.kts 的完整代码:
plugins {
kotlin("jvm") version "2.2.21"
}
group = "org.example"
version = "1.0-SNAPSHOT"
repositories {
mavenCentral()
}
dependencies {
testImplementation(kotlin("test"))
}
tasks.test {
useJUnitPlatform()
}添加代码进行测试
打开
src/main/kotlin中的Main.kt文件。src目录包含 Kotlin 源文件和资源。Main.kt文件包含打印Hello, World!的示例代码。创建
Sample类,其中包含用于将两个整型相加的sum()函数:kotlinclass Sample() { fun sum(a: Int, b: Int): Int { return a + b } }
创建测试
在 IntelliJ IDEA 中,为
Sample类选择 Code | Generate | Test...:
指定测试类的名称。例如,
SampleTest:
IntelliJ IDEA 会在
test目录中创建SampleTest.kt文件。此目录包含 Kotlin 测试源文件和资源。你也可以在
src/test/kotlin中手动创建用于测试的*.kt文件。在
SampleTest.kt中为sum()函数添加测试代码:- 使用
@Test注解 定义测试testSum()函数。 - 使用
assertEquals()函数检测sum()函数是否返回预期值。
kotlinimport org.example.Sample import org.junit.jupiter.api.Assertions.* import kotlin.test.Test class SampleTest { private val testSample: Sample = Sample() @Test fun testSum() { val expected = 42 assertEquals(expected, testSample.sum(40, 2)) } }- 使用
运行测试
使用边栏图标运行测试:

你也可以通过命令行界面使用
./gradlew check命令运行所有项目测试。在 Run 工具窗口中检测结果:

测试函数已成功执行。
将
expected变量值更改为 43,以确保测试正常工作:kotlin@Test fun testSum() { val expected = 43 assertEquals(expected, classForTesting.sum(40, 2)) }再次运行测试并检测结果:

测试执行失败。
接下来
完成首次测试后,你可以:
- 使用其他
kotlin.test函数编写更多测试。例如,使用assertNotEquals()函数。 - 使用 Kotlin Power-assert 编译器插件 改进测试输出。该插件通过上下文信息丰富了测试输出。
- 使用 Kotlin 和 Spring Boot 创建你的第一个服务器端应用程序。
