IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 单元测试新手上路——个人实践总结 -> 正文阅读

[开发测试]单元测试新手上路——个人实践总结

最近在做安全生产专项,写了很多单测case。由于之前的工作中没有很强制要求写单元测试,一般是由测试人员去写自动化测试,因此对单测的写法不是很熟。在参考其他项目中的测试用例后,慢慢开始尝试写,这个过程中,也积累和总结了一些个人的经验,在此分享出来,欢迎大家指正和补充。

前言:为什么要写单测?

软件要易于修改

最近在看一本书《代码整洁之道:程序员的职业素养》,这本书里面说到,代码设计要遵循一个重要的原则-易于修改,并且要实现这个目标就应该经常修改它,而不是等到大量积累了臃肿代码之后再进行深度重构。

一套完善的测试用例是修改代码的安全保障

而如何保证在频繁修改优化代码之后,不影响其原本的功能呢?那就是要编写一套完善的测试用例,能覆盖到所有的链路场景,通过测试用例的执行结果来确保代码修改的正确性。
特别是我们做金融场景业务的开发,尤其要注意代码的正确性、安全性,那么写好单测是不可或缺的。

一、写单测前要做的准备

了解你的业务流程

写单测的基本前提是,你得足够熟悉你要测试的链路流程,正常执行的流程,以及异常及相应处理。
另外,还需要清楚,什么样的结果能代表代码流程按预期执行了,比如对方法返回结果的断言,对数据库生成记录的校验等。

梳理外部交互及数据变动点

如:

  • 对外RPC调用
  • MQ消息的发送、消费
  • 对数据库的插入、修改、删除

二、使用Mockito进行Mock

Mockito注解

Mockito提供了几个注解,包括@Mock、@Spy、@MockBean、@SpyBean,用于声明式地构造待Mock对象,只有被Mockito代理的对象才能进行后续的方法行为mock。

  • @Spy 和 @SpyBean的区别、@Mock 和 @MockBean的区别
    • @Spy 和 @Mock 生成的对象不受Spring管理,而 @SpyBean 和 @MockBean 会生成SpringBean,可进行自动注入
    • @Spy 调用真实方法时,其依赖的其它bean是无法通过Spring自动注入的,要使用注入,要使用 @SpyBean
  • @MockBean 和 @SpyBean 的区别
    • 默认行为的不同:对于未指定mock的方法,spy默认会调用真实的方法,有返回值的返回真实的返回值,而mock默认不执行,有返回值的,默认返回null
    • 对于某些待测类,如果我们只想Mock其某一个方法,而其他方法希望按原来正常调用,那么就应该使用@Spy或@SpyBean,而对于想要完全屏蔽原本行为的类,则使用@Mock或@MockBean来声明。


注意:使用@MockBean时,通过Mockito.when().thenReturn()来模拟方法返回,但是使用@SpyBean时,这样写会调到真实的方法,需要Mockito.doReturn().when().xxx()来声明模拟。


像我们目前在SpringBoot框架环境下开发的话,一般使用@MockBean和@SpyBean即可

Mock对象行为

  1. Mock方法返回值
// 声明userService在传入任意参数调用get()方法时,返回user
Mockito.when(userService.get(Mockito.any())).thenReturn(user);
Mockito.doReturn(user).when(userService).get(Mockito.any());	// Spy必须用这种
  1. Mock异常抛出
// 声明userService在传入任意参数调用get()方法时,抛出指定异常
Mockito.when(userService.get(Mockito.any())).thenThrow(new RuntimeException("mock error"));
Mockito.doThrow(new RuntimeException("mock error")).when(userService).get(Mockito.any()); // Spy必须用这种

其他的Mock编写可参考官方文档:MockitoDoc

三、写单测的注意点

每个用例聚焦测试方法的内部逻辑,不关注外部及上下游

  • 比如转账接口的单测,我应该主要关注同步接口中的受理过程,受理流程完成后的异步过程,最好不要在当前流程中提现,而应该另外再对异步实际调用方法写Case。
  • 消息消费和定时任务最好是针对最后实际调用的Service方法进行测试。

单测不能影响外部应用和数据

  • 对外请求的Rpc调用要Mock掉,如果业务流程会根据对外调用的结果有所变化,要在多个Case中分别Mock不同的返回结果
  • 避免对非测试数据和服务的影响
    • 关闭Mq消息生产和消费

      • 排除消息中间件配置类,这样Producer和Consumer都不会初始化:
      • 在这里插入图片描述
    • 关闭Dubbo服务注册

      • 在这里插入图片描述
    • 视情况关闭定时任务

  • Mock的数据要有标识性
    • 测试参数和数据库准备数据一定不要对实际数据产生影响,在一些关键属性,不如id、requestNo等唯一标示要能明确区分是测试数据,并且要易于清理。但注意要符合实际情况,能代表真实场景。
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-07-27 16:32:45  更:2021-07-27 16:33:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:44:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码