zoukankan      html  css  js  c++  java
  • 模拟对象测试——EasyMock

    一、EasyMock 使用动态代理实现模拟对象创建,一般可以满足以下测试需求

    1、要测试的模块依赖于其它自己控制不了的模块,如第三方服务,其它组员在开发的服务等,它们都没办法配合你来测试;

    2、涉及到数据库操作,但当时条件连接不了数据库或你不想将自己的测试结果改动到数据库;

    3、模块依赖于spring容器注入其它服务实例,但你又不想启动spring容器。

    总之,EasyMock能帮我们模拟出任何我们想要的支持对象,并且我们可以使用这些对象进行逻辑操作

    二、具体使用方法

    1、模拟成员变量

    EasyMock.createMock(要模拟的成员变量类型);

    2、设定模拟成员的函数行为

    1)有返回值

    Easymock.expect(模拟成员的某个要模拟的函数).andReturn(期待的返回值)

    2)没返回值

    首先模拟成员调用要模拟的函数,然后在后面跟上一句:EasyMock.expectLastCall(),如果希望为该函数加上一个返回,可以用:

    EasyMock.expectLastCall().andAnswer(new IAnswer<任何类型>(){
      public String answer() throws Throwable {
        log.info(EasyMock.getCurrentArguments()[0]);//打印参数,以确定传参是否准确([0]表示第一个参数)
        return 作何类型;
      }
    });

    因为完全没返回又没日志输出的时候,你可能很难确定这个函数的操作结果是什么

    3、模糊参数

    有时候要模拟的函数的参数是在程序运行过程中调用的,参数值来自于程序执行结果,这时可以用模糊参数来解决,模糊参数有:

    isA、isNull、anyInt等

    4、开始测试

    EasyMock.replay(模拟成员);

    三、实例

    1、要测试的类

    public class UserServiceImpl{
      private UserDao dao;
      public List<String> queryNames(String[] ids) throws Exception{
        try{
          return dao.getNames(ids);
        }catch(Exception e){
          throw e;
        }
        return null;
      }
    }

    该类依赖UserDao,但UserDao可能还没实现,或要靠spring容器来注入

    2、测试代码

    @Test
    public void test() {

      String[] ids = {'1','2','3'};

      List<String> returnNams = Arrays.asList("a,b,c".split(","));

      UserDao userDaoMock = EasyMock.createMock(UserDao.class);//创建模拟成员

      EasyMock.expect(userDaoMock.getNames(ids )).andReturn(returnNams);

          EasyMock.replay(userDaoMock );//重放Mock对象     

      UserServiceImpl userServiceImpl = new UserServiceImpl();

      userServiceImpl .queryNames(ids);//目标类调用目标方法

      EasyMock.verify(userDaoMock );//验证Mock对象       

    }

  • 相关阅读:
    CF 335A(Banana-贪心-priority_queue是大根堆)
    Oracle shutdown immediate无法关闭数据库解决方法
    ORA-02266: unique/primary keys in table referenced by enabled foreign keys
    Linux命令学习总结:date命令
    Linux命令学习总结:pwd命令
    Linux命令学习总结:cd命令
    ORACLE表空间管理维护
    ORACLE 12C新特性——CDB与PDB
    [翻译]当分发数据库增长到25G时如何解决
    The process could not execute 'sp_repldone/sp_replcounters' on 'ServerName'
  • 原文地址:https://www.cnblogs.com/ptw-share/p/6962131.html
Copyright © 2011-2022 走看看