maven
几年前,我写了一篇博客文章,介绍如何在SonarQube中生成测试报告,该报告独立于单元测试和集成测试的测试报告中。 从SonarQube 6.2开始,测试报告不再在这些类别中分开(请参阅SonarQube的博客文章)。 SonarQube将所有测试报告合并为一份涵盖整体的测试报告。 因此,如果您在Maven项目中将单元测试(由Maven Surefire插件运行)和集成测试(由Maven Failsafe插件运行)分开进行测试,那么如何配置JaCoCo Maven插件。
在以下各节中,提出了满足以下条件的解决方案:
- Maven被用作构建工具。
- 该项目可以是多模块项目。
- 单元测试和集成测试是每个模块的一部分。
- 测试覆盖率是通过JaCoCo Maven插件来衡量的。
下一部分的路线图是,首先显示了Maven项目结构,用于单元测试和集成测试的分离。 然后显示了Maven项目配置,其中包含单独的单元测试运行和集成测试运行。 之后,我们来看看Maven项目配置以生成涵盖单元测试和集成测试的测试报告。 最后,SonarQube的仪表板中显示了SonarQube的配置,用于测试报告的可视化。
Maven项目结构
首先,我们看一下默认的Maven项目结构在单个模块项目中的样子。
my-app
├── pom.xml
├── src
│ ├── main
│ │ └── java
│ └── test
│ └── java
目录src / main / java包含生产源代码,目录src / test / java包含测试源代码。 我们可以将单元测试和集成测试放到这个目录中。 但是我们想将这两种类型的测试放在单独的目录中。 因此,我们添加了一个名为src / it / java的新目录。 然后将单元测试放在src / test / java目录中,并将集成测试放在src / it / java目录中,因此新的项目结构如下图所示。
my-app
├── pom.xml
├── src
│ ├── it
│ │ └── java
│ ├── main
│ │ └── java
│ └── test
│ └── java
单元和集成测试运行
幸运的是,单元测试运行配置是Maven默认项目配置的一部分。 如果满足以下条件,Maven将自动运行这些测试:
- 测试位于目录src / test / java和
- 测试类名称以Test开头或以Test或TestCase结尾。
Maven在Maven的构建生命周期阶段测试中运行这些测试。
集成测试运行配置必须手动完成。 它存在可以提供帮助的Maven插件。 我们希望满足以下条件:
- 集成测试存储在目录src / it / java和
- 集成测试类名称要么以IT开头,要么以IT或ITCase结尾,
- 集成测试在Maven的构建生命周期阶段进行集成测试。
首先,Maven必须知道它必须在其测试类路径中包含目录src / it / java 。 在这里,Build Helper Maven插件可以提供帮助。 它将目录src / it / java添加到测试类路径。
< plugin >
< groupId >org.codehaus.mojo</ groupId >
< artifactId >build-helper-maven-plugin</ artifactId >
< version >3.1.0</ version >
< executions >
< execution >
< goals >
< goal >add-test-source</ goal >
< goal >add-test-resource</ goal >
</ goals >
< configuration >
< sources >
< source >src/it/java</ source >
</ sources >
< resources >
< resource >
< directory >src/it/resources</ directory >
</ resource >
</ resources >
</ configuration >
</ execution >
</ executions >
</ plugin >
上面的代码段必须插入到项目根pom中的<project> <build> <plugins>部分。
Maven的构建生命周期包含一个称为集成测试的阶段。 在此阶段,我们要运行集成测试。 幸运的是,当在POM中设置Maven故障安全插件的目标集成测试时,它会自动绑定到此阶段。 如果您希望在集成测试失败时构建失败,那么还必须将目标验证添加到POM中:
< plugin >
< groupId >org.apache.maven.plugins</ groupId >
< artifactId >maven-failsafe-plugin</ artifactId >
< version >3.0.0-M4</ version >
< configuration >
< encoding >${project.build.sourceEncoding}</ encoding >
</ configuration >
< executions >
< execution >
< goals >
< goal >integration-test</ goal >
< goal >verify</ goal >
</ goals >
</ execution >
</ executions >
</ plugin >
同样,以上代码片段也必须插入到项目根pom中的<project> <build> <plugins>部分。 然后,当Maven故障保护插件的类名称以IT开头或以IT或ITCase结尾时,它们会自动运行集成测试。
测试报告生成
我们想使用JaCoCo Maven插件生成测试报告。 它应该为单元测试和集成测试生成测试报告。 因此,该插件必须要准备两个单独的代理。 然后他们在测试运行期间生成报告。 Maven的构建生命周期包含自己的阶段,可以在测试阶段之前进行准备(测试和集成测试)。 测试阶段的准备阶段称为“过程测试类”,集成测试阶段的准备阶段称为“预集成测试” 。 当在POM中设置了目标prepare-agent和prepare-agent-integration时,JaCoCo会将其代理自动绑定到这些阶段。 但这还不够。 JaCoCo还必须创建一个报告,以便SonarQube可以读取报告以进行可视化。 因此,我们必须在POM中添加目标报告和报告集成:
< plugin >
< groupId >org.jacoco</ groupId >
< artifactId >jacoco-maven-plugin</ artifactId >
< version >0.8.5</ version >
< executions >
< execution >
< goals >
< goal >prepare-agent</ goal >
< goal >prepare-agent-integration</ goal >
< goal >report</ goal >
< goal >report-integration</ goal >
</ goals >
</ execution >
</ executions >
</ plugin >
同样,它是<project> <build> <plugins>部分的一部分。
现在,我们可以运行目标mvn验证,并且我们的项目已构建为包含单元和集成测试,并生成两个测试报告。
SonarQube测试报告可视化
现在,我们想在SonarQube中可视化我们的测试报告。 因此,成功构建后,我们必须在我们的项目中运行Sonar Maven 3插件(命令mvn sonar:sonar )。 因此,Sonar Maven插件知道将报告上传到哪里,我们必须在〜/ .m2 / setting.xml中配置SonarQube实例:
< profile >
< id >sonar</ id >
< activation >
< activeByDefault >true</ activeByDefault >
</ activation >
< properties >
<!-- Optional URL to server. Default value is http://localhost:9000 -->
< sonar.host.url > http://localhost:9000 </ sonar.host.url >
</ properties >
</ profile >
在SonarQube仪表板中打开项目时,我们会看到总体测试覆盖率报告。
概要
该博客描述了如果单元测试和集成测试分别运行,如何为Maven构建生成测试报告。 在GitHub上,我托管了一个示例项目,演示了所有配置步骤。 作为技术环境,我使用
- Maven 3.6.3
- Maven Surefire插件
- SonarQube 8.3.1
- Java 11
链接
- Jacoco Maven插件项目站点
- Maven故障安全插件项目站点
- 构建助手Maven插件项目站点
- SonarQube有关通用测试覆盖率的文档
- GitHub上的示例Maven项目
翻译自: https://www.javacodegeeks.com/2020/06/test-coverage-reports-for-maven-projects-in-sonarqube-8-3-x.html
maven