用 Gradle 实现自动化测试:集成 JUnit、TestNG,生成测试报告
我将为你创建一个使用 Gradle 实现自动化测试的配置,集成 JUnit 和 TestNG 并生成测试报告。
首先,我们需要创建一个 build.gradle
文件,这是 Gradle 项目的核心配置文件:
plugins {// 应用 Java 插件,提供基本的 Java 构建功能id 'java'// 应用 TestNG 插件id 'org.unbroken-dome.testng' version '4.0.0'
}repositories {// 使用 Maven 中央仓库获取依赖mavenCentral()
}dependencies {// JUnit 5 依赖testImplementation 'org.junit.jupiter:junit-jupiter-api:5.9.2'testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.9.2'// TestNG 依赖testImplementation 'org.testng:testng:7.5'// 可选:添加断言库testImplementation 'org.assertj:assertj-core:3.24.2'
}test {// 启用 JUnit 平台useJUnitPlatform()// 配置测试报告reports {junitXml {// 启用 XML 报告enabled = true// 报告输出目录destination = file("$buildDir/test-results/junit")}html {// 启用 HTML 报告enabled = true// 报告输出目录destination = file("$buildDir/reports/tests/junit")}}// 测试执行时的日志级别testLogging {events 'PASSED', 'SKIPPED', 'FAILED'}// 允许并行执行测试maxParallelForks = Runtime.runtime.availableProcessors()
}testNG {// 配置 TestNG 测试useTestNG()// 测试报告配置reports {junitXml {enabled = truedestination = file("$buildDir/test-results/testng")}html {enabled = truedestination = file("$buildDir/reports/tests/testng")}}// TestNG 特定配置options {// 可以指定测试套件 XML 文件// suiteXmlFiles = files('src/test/resources/testng.xml')// 启用详细日志verbose = 2// 允许并行执行parallel = 'methods'threadCount = 4}
}// 任务:运行所有测试(JUnit 和 TestNG)
task runAllTests(type: Test) {dependsOn test, testNGgroup = 'Verification'description = 'Runs all tests (JUnit and TestNG)'
}// 配置测试源目录
sourceSets {test {java {srcDirs = ['src/test/java']}resources {srcDirs = ['src/test/resources']}}
}
为了更好地组织测试,我们可以创建一个 TestNG 测试套件配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "https://testng.org/testng-1.0.dtd">
<suite name="All Tests Suite" parallel="methods" thread-count="4"><test name="TestNG Tests"><packages><package name="com.example.testng"/></packages></test>
</suite>
项目结构说明
建议的项目结构如下:
project-root/
├── build.gradle
├── src/
│ ├── main/
│ │ └── java/
│ │ └── com/
│ │ └── example/
│ │ └── 你的业务代码
│ └── test/
│ ├── java/
│ │ ├── com/
│ │ │ └── example/
│ │ │ ├── junit/ # JUnit 测试类
│ │ │ └── testng/ # TestNG 测试类
│ └── resources/
│ └── testng.xml # TestNG 配置文件
使用方法
- 将上述配置文件添加到你的项目中
- 在相应的目录下编写 JUnit 和 TestNG 测试用例
- 运行以下 Gradle 命令:
- 运行所有测试(JUnit 和 TestNG):
./gradlew runAllTests
- 只运行 JUnit 测试:
./gradlew test
- 只运行 TestNG 测试:
./gradlew testNG
- 生成测试报告:测试执行后自动生成,无需额外命令
测试报告位置
- JUnit 测试报告:
build/reports/tests/junit/index.html
- TestNG 测试报告:
build/reports/tests/testng/index.html
这些报告包含了详细的测试结果,包括通过的测试、失败的测试、跳过的测试以及执行时间等信息,方便你分析测试结果。