跳到主要内容

在 JVM 中使用 JUnit 测试代码 – 教程

本教程将向你展示如何在 Kotlin/JVM 项目中编写一个简单的单元测试,并使用 Gradle 构建工具运行它。

在本教程中,你将使用 kotlin.test 库,并使用 JUnit 运行测试。 如果你正在开发一个多平台应用,请参阅 Kotlin Multiplatform 教程

首先,下载并安装最新版本的 IntelliJ IDEA 以开始。

添加依赖

  1. 在 IntelliJ IDEA 中打开一个 Kotlin 项目。如果你没有项目,请创建一个

  2. 打开 build.gradle(.kts) 文件,并检查是否存在 testImplementation 依赖项。 此依赖项允许你使用 kotlin.test 和 JUnit:

    dependencies {
    // Other dependencies.
    testImplementation(kotlin("test"))
    }
  3. test 任务添加到 build.gradle(.kts) 文件中:

    tasks.test {
    useJUnitPlatform()
    }

    如果你在构建脚本中使用 useJUnitPlatform() 函数,则 kotlin-test 库会自动包含 JUnit 5 作为依赖项。 这种设置可以在 JVM-only 项目和 Kotlin Multiplatform (KMP) 项目的 JVM 测试中访问所有 JUnit 5 API 以及 kotlin-test API。

这是 build.gradle.kts 的完整代码:

plugins {
kotlin("jvm") version "2.1.20"
}

group = "org.example"
version = "1.0-SNAPSHOT"

repositories {
mavenCentral()
}

dependencies {
testImplementation(kotlin("test"))
}

tasks.test {
useJUnitPlatform()
}

添加代码进行测试

  1. src/main/kotlin 中打开 Main.kt 文件。

    src 目录包含 Kotlin 源代码文件和资源文件。 Main.kt 文件包含打印 Hello, World! 的示例代码。

  2. 创建包含 sum() 函数的 Sample 类,该函数将两个整数相加:

    class Sample() {

    fun sum(a: Int, b: Int): Int {
    return a + b
    }
    }

创建一个测试

  1. 在 IntelliJ IDEA 中,为 Sample 类选择 Code | Generate | Test...

    Create a test
  2. 指定测试类的名称。例如,SampleTest

    Create a test

    IntelliJ IDEA 将在 test 目录中创建 SampleTest.kt 文件。 此目录包含 Kotlin 测试源代码文件和资源文件。

    你也可以在 src/test/kotlin 中手动创建一个用于测试的 *.kt 文件。

  3. SampleTest.kt 中为 sum() 函数添加测试代码:

    • 使用 @Test 注解 定义测试函数 testSum()
    • 通过使用 assertEquals() 函数检查 sum() 函数是否返回预期值。
    import 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))
    }
    }

运行测试

  1. 使用代码槽图标运行测试:

    Run the test

    你也可以使用 ./gradlew check 命令通过命令行界面运行所有项目测试。

  2. Run 工具窗口中检查结果:

    Check the test result. The test passed successfully

    测试函数已成功执行。

  3. 通过将 expected 变量值更改为 43,确保测试正常工作:

    @Test
    fun testSum() {
    val expected = 43
    assertEquals(expected, classForTesting.sum(40, 2))
    }
  4. 再次运行测试并检查结果:

    Check the test result. The test has failed

    测试执行失败。

接下来做什么

完成第一个测试后,你可以: