SpringBoot2零基础到精通之JUnit 5与指标监控

网友投稿 835 2022-10-18

SpringBoot2零基础到精通之JUnit 5与指标监控

SpringBoot2零基础到精通之JUnit 5与指标监控

目录1 单元测试JUnit 51.1JUnit 5简介以及使用1.2 常用的测试注解1.3 断言(assertions)1.4 前置条件(assumptions)1.5 嵌套测试1.6 参数化测试2 指标监控2.1 使用url实现监控2.2 可视化的监控平台

1 单元测试JUnit 5

1.1JUnit 5简介以及使用

JUnit5作为最新版本的JUnit框架与之前版本的Junit框架有很大的不同。JUnit5主要由三个不同子项目的几个不同模块组成:JUnit Platform、JUnit Jupiter、JUnit Vintage。

JUnit Platform: 它是在JVM上启动测试框架的基础,不仅支持Junit自制的测试引擎,其他测试引擎也都可以接入。

JUnit Jupiter: 提供了JUnit5的新的编程模型,是JUnit5新特性的核心。内部 包含了一个测试引擎,用于在Junit Platform上运行。

JUnit Vintage: 由于JUint已经发展多年,为了照顾老的项目,JUnit Vintage提供了兼容JUnit4.x,Junit3.x的测试引擎。

在这里我们需要了解的是:SpringBoot 2.4 以上版本移除了默认对JUnit Vintage的依赖。如果需要兼容junit4需要自行引入,不引入的话就不能使用junit4的功能@Test,但是JUnit5也有一个@Test注解能够完成同样的功能

使用: 由上面的JUnit5分析可知:要想使用JUnit5并兼容JUnit以前的版本的话,必须引用以下两个依赖

org.springframework.boot

spring-boot-starter-test

test

org.junit.vintage

junit-vintage-engine

test

org.hamcrest

hamcrest-core

然后使用@SpringBootTest注解标注测试类,使用@Test标注测试方法

1.2 常用的测试注解

官方文档中已经定义并解释了所有的注解,可以通过这个链接进行查看官方文档的链接地址接下来会选取常用的几个注解进行讲解学习

@SpringBootTest和@Test不再赘述

@DisplayName注解:控制台砖展示名

@BeforeEach注解:每个方法执行之前执行@AfterEach注解:每个方法执行之后执行

@BeforeAll注解:所有方法执行之前执行@AfterAll注解:所有方法执行之后执行 值得注意的是,这两个注解的修饰的方法都必须使用static修饰

@Disable注解:在运行测试类的时候禁用这个方法,可以单独执行@Timeout注解:设置测试方法的执行时间,超过这个时间则抛异常

@ExtendWith注解:设置测试类的测试驱动,@SpringBootTest注解是个复合注解,其中底层就有

@ExtendWith注解指定了测试类使用的是SpringBoot的测试驱动

@RepeatedTest注解:指定方法重复次数

1.3 断言(assertions)

断言是测试方法中的核心部分,用来对测试需要满足的条件进行验证。所谓断言就是检查业务逻辑返回的数据是否合理,在所有的测试运行结束以后,会产生一个详细的测试报告。值得注意的是:当出现一个断言失败之后,从那个断言开始后面的所有代码都不会执行 JUnit 5 内置的断言可以分成如下几个类别:

简单断言

以上方法的用法如下(以assertEquals方法为例):

数组断言

组合断言 组合断言需要zWudaelXCE所有的参数都满足的情况下才会通过,否则会返回出错的断言,可以以用来一个方法进行多个简单断言

异常断言 当结果不抛出定义的异常时断言失败

超时断言 当超出定义的超时时间就会返回断言

快速断言 当符合逻辑的时候就会返回断言

使用断言的好处就是:可以使用以下图片中的方法将测试类的所有方法跑一遍,如果断言都通过则正常运行。否则就会返回所有的断言失败的信息

1.4 前置条件(assumptions)

JUnit 5 中的前置条件(又叫假设)类似于断言,不同之处在于不满足的断言会使得测试方法失败,而不满足的前置条件只http://会使得测试方法的执行终止。前置条件可以看成是测试方法执行的前提,当该前提不满足时,就没有继续执行的必要。

由上图可知,前置条件与断言最大的区别就是前置条件不满足的情况下,跳过该方法继续执行别的方法,而不满足断言的话后面的代码都将不会执行

1.5 嵌套测试

嵌套测试即是测试类中还有测试类,在这种情况下,外层的test不能驱动内层的Before(After)All(Each)方法,但是内层的test可以驱动外层的Before(After)All(Each)方法。

1.6 参数化测试

@ValueSource: 为参数化测试指定入参来源,支持八大基础类以及String类型,Class类型

@NullSource: 为测试方法提供参数为null

@EnumSource: 为测试方法提供枚举参数

@CsvFileSource: 读取指定CSV文件内容作为参数化测试入参

@MethodSource: 读取指定方法的返回值作为参数化测试入参(但是该方法的返回必须是一个Stream流)

2 指标监控

2.1 使用url实现监控

引用Actuator启动器

org.springframework.boot

spring-boot-starter-actuator

使用配置文件开启想要的端点

management:

endpoints:

enabled-by-default: false # 默认开启所有的监控端点,定制化的话就需要关闭

web:

exposure:

include: '*' # 以web的方式暴露所有的端点

endpoint:

beans:

enabled: true

health:

enabled: true

show-details: always

info:

enabled: true

metrics:

enabled: true

使用url查看监控信息

2.2 可视化的监控平台

使用Spring Initializr快速创建一个SpringBoot项目,项目的pom文件加入服务监控平台的依赖,并在该项目的主程序类上加入@EnableAdminServer注解

de.codecentric

spring-boot-admin-starter-server

2.3.1

为了防止与需要监控的服务产生端口冲突,需要在配置文件中修改监控的端口号

server:

port: 8888

将其他的服务注册进监控

第一步: 被监控的服务中导入依赖

de.codecentric

spring-boot-admin-starter-client

http://2.3.1

第二步: 被监控的服务中配置文件配置监控项目的url

spring:

boot:

admin:

client:

url: http://localhost:8888

instance:

prefer-ip: true

application:

name: Project-admin_manage

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:adaptiveThreshold自适应二值化源码分析
下一篇:c++如何将文件复制到其他地方
相关文章

 发表评论

暂时没有评论,来抢沙发吧~