JUnit与Mockito单元测试典型示例

本文探讨了单元测试的重要性,特别是在面临依赖问题时如何利用mock技术,特别是Mockito库,来简化测试。通过一个Dao层的mock示例,展示了如何设置Mockito以模拟方法的输入参数、返回值和异常,确保单元测试专注于被测试类的逻辑而不是其依赖。最后,强调了Mockito的API虽然初看独特,但熟悉后能发现其设计精巧。
摘要由CSDN通过智能技术生成

单元测试的重要性无需赘述,但单元测试也会遇到困难,其中之一就是如何创建依赖。试想我们常见的server端分层架构,数据访问层Dao,业务层,以及Web层,想要单元测试业务层,我们需要依赖Dao层提供数据支持,Dao层又依赖数据库,数据库需要shema以及data。为了测试业务逻辑,竟然需要准备那么多东西,想想就麻烦,单元测试的热情也减去大半。这个问题的解法就是mock技术,模拟被依赖的组件的行为

先聊聊单元测试

单元测试简单来说就是类的测试,测试对象是某一个类,测试内容是类逻辑的正确性,这里强调一下,测试内容只关注被测试类自身的逻辑,被测试类所依赖类的逻辑,理应由其它单元测试去cover。下图是一个简单的示意图:

单元测试示意图

单元测试只关注Target的逻辑。如果没有Target Dependency,那么当然更好,直接测试。万一有Target Dependency呢?有些时候构建Target Dependency很简单,new一个对象即可。如果向开头说的那种Dao依赖类呢?硬着头皮创建数据库,初始化表结构和数据,当然可以,但是这些与我们要测试的业务层的正确性没啥关系。

一个更经济环保的做法是mock Dao类。可是如何mock?mock什么内容呢?Java世界里面有很多优秀的mock工具,比如EasyMock、jMock以及Mockito,可以用来简化我们的mock工作。本文只讨论mockito。至于mock什么内容的问题,我的理解是mock类的行为,也就是类的Method,Value Object直接创建即可。类的Method大概分为以下几个内容:

  • Method名字
  • Method输入参数
  • Method输出返回值
  • Method异常
  • Method执行语句

Method名字当然无法改变,没有mock的说法。其它的都可以mock。

Dao mock示例

先准备entity以及Dao接口:

public class User {
    private Long id;
    private String name;

    public Long getId
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值