1. Jmockit简介

JMockit 是用以帮助开发人员编写测试程序的一组工具和API,它完全基于 Java 5 SE 的 java.lang.instrument 包开发,内部使用 ASM 库来修改Java的Bytecode。正是由于基于instrument,可以修改字节码。所以这也是它强大的原因。

Jmockit可以mock的种类包含了:

1. class(abstract, final, static)

2. interface

3. enum

4. annotation

5. native

Jmockit 有两种mock的方式:

1. Behavior-oriented(Expectations & Verifications)

2. State-oriented(MockUp<GenericType>)

通俗点讲,Behavior-oriented是基于行为的mock,对mock目标代码的行为进行模仿,更像黑盒测试。State-oriented 是基于状态的mock,是站在目标测试代码内部的。可以对传入的参数进行检查、匹配,才返回某些结果,类似白盒。而State-oriented的 new MockUp基本上可以mock任何代码或逻辑。非常强大。

(这段介绍来自网络转载)

2. Jmockit实践

使用jMockit首先要引用相关的jar包,pom文件引用如下.

<dependency>

<groupId>org.jmockit</groupId>

<artifactId>jmockit</artifactId>

<version>1.20</version>

<scope>test</scope>

</dependency>

<dependency>

<groupId>org.jmockit</groupId>

<artifactId>jmockit-coverage</artifactId>

<version>1.20</version>

<scope>test</scope>

</dependency>

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>4.11</version>

<scope>test</scope>

</dependency> 

2.1 示例1:模拟类

被测试方法如下:

其中NegativeTransDos的insert方法是插入数据库。

为了测试process()方法的逻辑,希望能够模拟dao.insert方法的返回结果,参考测试代码如下:

可以看到使用jmockit基本有三个步骤:

(1)打桩。指定要打桩类和函数,模拟返回结果。这里是new Mockup(NegativeTransDos)。

(2)调用被测方法。被测逻辑执行过程中,之前的打桩数据生效。

(3)判断测试结果是否符合预期。

通过以下方法来模拟类和方法。

new Mockup(类) {

模拟方法{

          控制该方法返回结果

}

}

2.2 示例2:模拟静态方法

被测试方法如下。其中红框是需要Mock的两个静态方法。通过Jmockit模拟这两个静态方法的返回,只关注EdaStartup方法的自身逻辑。

参考测试代码如下:

2.3 示例3:模拟非静态方法

被测试方法:

这里包括两种方法的模拟:

McEventManager.getReceiver(),这个是静态方法调用的模拟,参考2.1章节。

receiver.getEvent(),这个是普通对象方法调用。本节关注这种方法的模拟。

参考测试代码如下:

首先需要通过 @Injectable 声明要插桩的对象:

private McEventReceiver receiver;

之后使用以下方式来插桩:

new NonStrictExpectations() {

    要模拟的方法(参数1,参数2,…)

    result = 返回结果

}

Jmockit提供了很彪悍的万能入参,这一点非常方便。包括:

2.4 示例4:模拟private静态方法

被测代码如下:

publicMethod()是被测试方法,其中调用了静态成员方法privateMethod。为了摒除privateMethod的影响,需要模拟它的返回结果。

参考测试代码如下:

test1和test2的输出结果分别是:

2.5 示例5:模拟private非静态方法

被测代码如下:

publicMethod()是被测试方法,其中调用了私有非静态成员方法privateMethod。为了摒除privateMethod的影响,需要模拟它的返回结果。

参考测试代码如下:

对比2.5私有静态方法的模拟可以看到略有区别。

new Expectations(XXX) 中,之前指定的是MockClass.class,这里指定的是被测试的MockClass对象。

test1和test2的输出结果分别是:

2.6 示例6:模拟private非静态成员变量

被测方法如下:

其中field是MockField的私有变量。我们目的是能够模拟该私有变量的值,来关注publicMethod方法的测试。

参考测试代码如下:

test1和test2的输出结果分别是:

最新文章

  1. 20145315&amp;20145307《信息安全系统设计基础》实验五
  2. python easy_install pip django
  3. 文件泄露&amp;php代码审计
  4. Codeforces Round #113 (Div. 2)
  5. Slony-I的 RemoteWorker重试调查
  6. Mac修改用户名
  7. PHP字符串操作常用函数
  8. 第一篇:K-近邻分类算法原理分析与代码实现
  9. 实现类似QQ自拍头像的功能(demo源码)
  10. std::cin&gt;&gt;
  11. OJ2237第k小数题解
  12. HTML - form (转)
  13. nginx如何安装第三方模块
  14. 数组去重--ES5和ES6
  15. SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版)
  16. 走近SpringBoot
  17. HttpTool.java 【暂保留】
  18. sea.js与require.js的区别
  19. 如果忘记了mysql密码怎么办?
  20. python中的__new__、__init__和__del__

热门文章

  1. Python常用数据类型简介
  2. HTML简介 页面标记
  3. 【Eureka篇三】Eureka常用配置说明(7)
  4. 2019 SDN阅读作业
  5. Paper | Deep Residual Learning for Image Recognition
  6. 【Java语言特性学习之六】扩展知识点
  7. antdmobile组件思维导图
  8. linux部署java命令
  9. kali渗透综合靶机(六)--FristiLeaks靶机
  10. 【JS】---4用JS获取地址栏参数方法