maven-surefire-plugin
   ·  
 maven-surefire-plugin Surefire 插件在test构建生命周期阶段用于执行应用程序的单元测试。

maven-surefire-plugin官网 (opens new window)
# 一、介绍
如果你执行过mvn test或者执行其他maven命令时跑了测试用例,你就已经用过maven-surefire-plugin了。 maven-surefire-plugin是maven里执行测试用例的插件,不显示配置就会用默认配置。 这个插件的surefire:test命令会默认绑定maven执行的test阶段。
如果你自己声明了,那么可以指定自己的版本,并且可以配置自定义的参数。
# 二、实践
# 2.1 用法
<build>
    <pluginManagement>
      <plugins>
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>3.0.0-M5</version>
        </plugin>
      </plugins>
    </pluginManagement>
  </build>
   1 2 3 4 5 6 7 8 9 10 11
  
 # 2.2 使用方法
mvn test
# 三、源码分析
# 3.1 学习目标
相关信息
框架整体比较复杂,但是对于我们有学习价值的东西不多,我们没必要太深入研究。在此只提几个关键的知识点学习。
- maven-surefire-plugin的常用参数及作用
- maven-surefire-plugin实现单测的原理
# 3.2 学习搭建环境
<!-- 先声明插件版本 -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-surefire-plugin</artifactId>
                <!-- JUnit 5 requires Surefire version 2.22.0 or higher -->
                <version>2.22.0</version>
            </plugin>
        </plugins>
    </build>
    <!-- 然后引入依赖,方便debug跟进源码-->
      <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>4.13.2</version>
          <scope>test</scope>
      </dependency>
      <dependency>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>3.0.0-M5</version>
      </dependency>
      <dependency>
          <groupId>org.apache.maven</groupId>
          <artifactId>maven-core</artifactId>
          <version>3.8.4</version>
      </dependency>
      <dependency>
          <groupId>org.apache.maven.surefire</groupId>
          <artifactId>surefire-junit4</artifactId>
          <version>3.0.0-M5</version>
      </dependency>
      <dependency>
          <groupId>org.apache.maven</groupId>
          <artifactId>maven-plugin-api</artifactId>
          <version>${dep.maven-api.version}</version>
      </dependency>
      <dependency>
          <groupId>org.apache.maven</groupId>
          <artifactId>maven-model</artifactId>
          <version>${dep.maven-api.version}</version>
      </dependency>
      <dependency>
          <groupId>org.apache.maven.plugin-tools</groupId>
          <artifactId>maven-plugin-annotations</artifactId>
          <version>${dep.maven-api.version}</version>
      </dependency>
      <dependency>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-plugin-plugin</artifactId>
          <version>${dep.maven-api.version}</version>
      </dependency>
   1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
  
 # 3.3 找到插件入口

前面通过学习知道Mojo是运行的核心类,而SurefirePlugin就是Mojo的子类。 由此可知,如果要学习这个 maven-surefire-plugin,入口就是在SurefirePlugin类。


# 四、 带着问题来学习
# 4.1 常用的参数都有那些
大多数为不常用的
| 是否常用 | 参数名 | 使用方法 | 解释 | 
|---|---|---|---|
| 常用 | skipTests | -D,或者xml配置标签 | 用于跳过单测 | 
| 常用 | maven.test.skip.exec | -D,或者xml配置标签 | 用于跳过单测 | 
| 常用 | maven.test.skip | -D,或者xml配置标签 | 用于跳过单测 | 
| 不常用 | testClassesDirectory | xml配置标签 | 指定测试模块目录编译后目录 | 
| 不常用 | maven.test.dependency.excludes | -D,或者xml配置标签 | 要排除的依赖,格式:groupId:artifactId | 
| 不常用 | maven.test.additionalClasspath | -D,或者xml配置标签 | 追加classpath | 
| 不常用 | project.build.testSourceDirectory | xml配置标签 | 指定测试模块目录源码目录 | 
| 不常用 | excludes | xml配置 | 指定规则的类不需要被单测,eg: **/*Test.java | 
| 不常用 | surefire.reportNameSuffix | -D,或者xml配置标签 | test报表后缀 | 
| 不常用 | maven.test.redirectTestOutputToFile | -D,或者xml配置标签 | 运行的单侧输出重定向到report目录中 | 
| 不常用 | failIfNoTests | -D,或者xml配置标签 | 如果没有单测就报错 | 
| 不常用 | forkMode | -D,或者xml配置标签 | 运行模式 | 
| 不常用 | jvm | -D,或者xml配置标签 | 指定jvm目录,如果不指定会读取系统 | 
| 不常用 | argLine | -D,或者xml配置标签 | Jvm运行参数 | 
| 不常用 | threadCount | -D,或者xml配置标签 | 线程数 | 
| 不常用 | forkCount | -D,或者xml配置标签 | 指定启用多少个vm,1.5C 以数字结尾,数字乘以cpu核心数 | 
| 不常用 | reuseForks | -D,或者xml配置标签 | 是否可重新使用forks进程 | 
| 不常用 | disableXmlReport | -D,或者xml配置标签 | 禁用xml报告 | 
| 不常用 | enableassertions | -D,或者xml配置标签 | 启用断言assert语句 | 
forkMode 可设置值有 “never”, “once”, “always” 和 “pertest”。
- pretest: 每一个测试创建一个新进程,为每个测试创建新的JVM是单独测试的最彻底方式,但也是最慢的,不适合hudson上持续回归。
- once:在一个进程中进行所有测试。once为默认设置,在Hudson上持续回归时建议使用默认设置。
- always:在一个进程中并行的运行脚本,Junit4.7以上版本才可以使用,surefire的版本要在2.6以上提供这个功能,
# 4.2 知识点
// 大于等于2.0.0,小于2.1.2
VersionRange range = VersionRange.createFromVersionSpec("[2.0.0,2.1.2)");
System.out.println(range.containsVersion(new DefaultArtifactVersion("1.0")));
System.out.println(range.containsVersion(new DefaultArtifactVersion("2.0.0")));
System.out.println(range.containsVersion(new DefaultArtifactVersion("2.1.1")));
System.out.println(range.containsVersion(new DefaultArtifactVersion("2.1.2")));
System.out.println("------------");
VersionRange range2 = VersionRange.createFromVersionSpec("[2.0.0-M1SN,2.1.2)");
System.out.println(range2.containsVersion(new DefaultArtifactVersion("2.1.1-M2")));
   1 2 3 4 5 6 7 8 9
  
  
 新一代开源开发者平台 GitCode,通过集成代码托管服务、代码仓库以及可信赖的开源组件库,让开发者可以在云端进行代码托管和开发。旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。
更多推荐



所有评论(0)