JUnit与Mockito单元测试典型示例

单元测试的重要性无需赘述,但单元测试也会遇到困难,其中之一就是如何创建依赖。试想我们常见的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
  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值