EasyMock总览

下面,我将讲述如何使用JUnit和EasyMock框架来进行单元测试。

在现实情况下,我们通常是在一些类里使用另外的一些类。在进行真正的测试之前,你可能需要做很多的工作,比喻说安置大量的环境代码,启动一种大型的、复杂的系统,可能是数据库、功过刘或者是某一种类型的IDE环境,你的预设环境代码需要是系统进入某种特定的状态,以便按照测试所需要的方法进行响应。但是这种工作不大可能很快就能完成。

为了对一部分类进行单元测试,你需要建立和控制另外一些类。最好的办法就是为需要测试的类创建一个模拟对象。你可以自己手工的编写类,也可以使用EasyMock来产生这些对象。

模拟对象提供了一种经过证明是成功的解决方案。当我们很难或不可能为某种难以处理的资源创建需要的状态或者存取某种资源受限时,你就可以使用模拟对象。

模拟对象取代真实对象的位置,用于测试一些与真实对象进行交互或依赖于真实对象的功能。模拟对象背后的基本思想就是创建轻量级的、可控制的对象来代替为了编写测试为需要使用的对象。模拟对象还能够让你指定和测试你的代码与模拟对象本身之间的交互。

说的再直白一点,一个模拟对象就是一个简单的接口或者是类,在里面你可以定义一个特定的方法调用之后的简单的输出。

所需jar包

EasyMock的使用,需要两个jar包,Junit和EasyMock的jar包,

你可以自己从官网上分别下载它们,也可以从下面的地址下载:

Junit4.11:http://download.csdn.net/detail/zyh5540/5860807

EasyMock3.2:http://download.csdn.net/detail/zyh5540/5860785

其中使用Junit时可能提示缺少hamcrest的jar包,这时你需要导入该jar包,同时你可以去Junit的官网下载hamcrest的jar包,此时需要主义Junit和harmcrest之间的版本号对应关系,这个也可以从官网上查得到。如果是从我上边提供的链接下载的,不需要单独在下载了。

示例

package easymock.income;
/**
* Position类表示职位信息,总共有三类:老板,程序猿,管理员
*/
public enum Position {
BOSS,PROGRAMMER,MANAGER
}
package easymock.income.method;

import easymock.income.Position;

/**
* 定义的计算工资的接口
* 并有一个抽象方法:计算工资
*/
public interface ICalMethod {
public abstract double cal(Position position);
}
package easymock.income;
import easymock.income.Position;
import easymock.income.exception.CalMethodException;
import easymock.income.exception.PositionException;
import easymock.income.method.ICalMethod; /**
* 收入(工资)计算的实现类,该类根据计算方法和职员的职位
* 计算该职员的工资
*/
public class IncomeCaculator {
private ICalMethod method;
private Position position; public void setMethod(ICalMethod method) {
this.method = method;
}
public void setPosition(Position position) {
this.position = position;
} public double cal() {
//计算的方法类为空,抛计算方法空异常
if(null == method){
throw new CalMethodException("cal method is null");
}
//当职位为空时,抛职位为空异常
if(null == position) {
throw new PositionException("position is null");
}
//返回该职员的工资
return method.cal(position);
} }
package easymock.income;

import easymock.income.exception.CalMethodException;
import easymock.income.exception.PositionException;
import easymock.income.method.ICalMethod; /**
* 收入(工资)计算的实现类,该类根据计算方法和职员的职位
* 计算该职员的工资
*/
public class IncomeCaculator {
private ICalMethod method;
private Position position; public void setMethod(ICalMethod method) {
this.method = method;
}
public void setPosition(Position position) {
this.position = position;
} public double cal() {
//计算的方法类为空,抛计算方法空异常
if(null == method){
throw new CalMethodException("cal method is null");
}
//当职位为空时,抛职位为空异常
if(null == position) {
throw new PositionException("position is null");
}
//返回该职员的工资
return method.cal(position);
} }

以下是方法为空的异常类和职位为空的异常类:

package easymock.income.exception;

public class CalMethodException extends RuntimeException {

	private static final long serialVersionUID = 1L;

	public CalMethodException(String message) {
super(message);
}
}
package easymock.income.exception;

public class PositionException extends RuntimeException {

    private static final long serialVersionUID = 1L;

    public PositionException(String message) {
        super(message);
    }
}
package easymock;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail; import org.easymock.EasyMock;
import org.junit.Before;
import org.junit.Test; import easymock.income.IncomeCaculator;
import easymock.income.Position;
import easymock.income.exception.CalMethodException;
import easymock.income.exception.PositionException;
import easymock.income.method.ICalMethod; /**
* EasyMock的使用步骤:
* 使用 EasyMock 生成 Mock 对象
* 设定 Mock 对象的预期行为和输出;
* 将 Mock 对象切换到 Replay 状态;
* 调用 Mock对象方法进行单元测试; 对 Mock 对象的行为进行验证。
*
*/
public class EasyMockTest { private ICalMethod calMethod;
private IncomeCaculator caculator; @Before
public void setUpBeforeClass() throws Exception {
//第一步:生成Mock对象
calMethod = EasyMock.createMock(ICalMethod.class);
caculator = new IncomeCaculator();
} @Test
public void testCacl1() {
/**
* 设定 Mock 对象的预期行为和输出
*/
//计算方法的参数是Position.BOSS,
//andReturn(),期望calMethod方法返回的是7000.0
//times(),该方法执行次数为两次
EasyMock.expect(calMethod.cal(Position.BOSS)).andReturn(7000.0)
.times(2);
//默认执行次数为一次
EasyMock.expect(calMethod.cal(Position.PROGRAMMER)).andReturn(5000.0); //将 Mock 对象切换到 Replay 状态
EasyMock.replay(calMethod); /**
* 调用 Mock 对象方法进行单元测试
* 代码的参数设置及返回结果应参考上面预期行为的设定
* 方法的执行顺序应和上面的一致
*/
caculator.setMethod(calMethod);
try {
caculator.cal();
fail("exception is not occur");
} catch (PositionException e) {
System.out.println("position exception");
}
caculator.setPosition(Position.BOSS);
//判断结果是否和预期的一样
//第一次预期的执行
//这里应该让caculator.cal()方法执行两次,这个次数和上面设定的次数一致
assertEquals(caculator.cal(), 7000.0, 0);
assertEquals(caculator.cal(), 7000.0, 0); //第二次预期的执行
caculator.setPosition(Position.PROGRAMMER);
assertEquals(5000.0, caculator.cal(), 0); caculator.setPosition(Position.MANAGER); //对 Mock对象的行为进行验证,验证是否两次预期都已执行
EasyMock.verify(calMethod);
} //测试能否抛出计算方法为空的异常
@Test(expected = CalMethodException.class)
public void testNoCalc() {
caculator.setPosition(Position.MANAGER);
caculator.cal();
} @Test(expected = PositionException.class)
public void testNoPosition() {
EasyMock.expect(calMethod.cal(Position.BOSS)).andReturn(7000.0);
EasyMock.replay(calMethod);
caculator.setMethod(calMethod);
caculator.cal();
} @Test(expected = PositionException.class)
public void testCalc2() {
//andThrow(),预期抛出一个异常
EasyMock.expect(calMethod.cal(Position.MANAGER))
.andThrow(new PositionException("Don't know this guy"))
.times(1); EasyMock.replay(calMethod);
caculator.setPosition(Position.MANAGER);
caculator.setMethod(calMethod);
caculator.cal();
} }

[置顶] EasyMock的简单使用的更多相关文章

  1. [置顶] EasyMock构建单元测试

    1. 背景 单元测试作为程序的基本保障.很多时候构建测试场景是一件令人头疼的事.因为之前的单元测试都是内部代码引用的,环境自给自足.开发到了一定程度,你不得不到开始调用外部的接口来完成你的功能.而外部 ...

  2. PHPCMS实现文章置顶功能的方法

    我个人喜欢把PHPCMS当作博客来用,而作为一个博客,怎能少了文章置顶功能呢?其中用PHPCMS实现置顶功能非常简单,无非是修改下推荐位的名称为置顶,然后在文章列表中推送需要置顶的文章罢了. 不过博客 ...

  3. html简单响应式滚动条置顶

    简单响应式滚动条置顶 一般的,让页面出现滚动条的常见方法有: overflow:auto||overflow:scroll 或者overflow-x水平滚动条和overflow-y垂直滚动条 那么现在 ...

  4. ahk之路:利用ahk在window7下实现窗口置顶

    操作系统:win7 64位 ahk版本:autohotkey_L1.1.24.03 今天安装了AutoHotkey_1.1.24.03.SciTE.PuloversMacroCreator,重新开始我 ...

  5. 【搬运工】NOIP吧置顶贴

    目的是存置顶贴里的链接.. 原帖:http://tieba.baidu.com/p/1753284199 资源站:*C++资源:http://tieba.baidu.com/p/1239792581* ...

  6. [置顶]VC2013的一个bug

    [置顶]VC2013的一个bug 前段时间在尝试使用一个C++的GUI库nana.这个库最大的特点在于使用现代C++风格去编写GUI程序,而不需要使用大量的比较丑陋的代码(如MFC中的各种宏),或者其 ...

  7. [知了堂学习笔记]_css3特效第二篇--行走的线条&&置顶导航栏

    一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...

  8. jQuery实现表格行上移下移和置顶

    jQuery实现表格行上移下移和置顶 我们在操作列表数据的时候,需要将数据行排列顺序进行调整,如上移和下移行,将行数据置顶等,这些操作都可以在前端通过点击按钮来完成,并且伴随着简单的动态效果,轻松实现 ...

  9. 解析Delphi 窗口置顶,及非主窗口置顶

    方法一: procedure TForm1.Button2Click(Sender: TObject);begin Form2.Show; Application.NormalizeTopMosts; ...

随机推荐

  1. Bob大叔观OO原则

    Bob大叔观OO原则 上篇总结了经典的23种 设计模式,详细的解读后期会陆续的详细揭开.使用设计模式的根本原因就是为了增强代码的复用性和可维护性.而面向对象是实现代码复用的有效途径,所以这里有必要了解 ...

  2. X86在逻辑地址、线性地址、理解虚拟地址和物理地址

    参考:http://bbs.chinaunix.net/thread-2083672-1-1.html 本贴涉及的硬件平台是X86.假设是其他平台,不保证能一一对号入座.可是举一反三,我想是全然可行的 ...

  3. Android项目打包成APK文件

    第一步:右键单击该项目选择Export项目 显演示样例如以下界面:选择Exprot Android Application 第二步:输入项目名称,默认的情况下是原始的项目名称 下一步: 点击 Crea ...

  4. 微设计(www.weidesigner.com)介绍系列文章(三)

    微设计(www.weidesigner.com)是一个专门针对微信公众账号提供营销推广服务而打造的第三方平台. 3.1 优惠券 优惠券是用于微信上与顾客互动的一种营销方式,不仅能够展现自己的产品,更能 ...

  5. RAC下一个Fatal NI connect error 12170.错误处理

    原创作品,离 "深蓝blog" 博客,欢迎转载,请务必注明转载的来源.否则有权追究版权责任. 深蓝的blog:http://blog.csdn.net/huangyanlong/a ...

  6. JS数据绑定模板artTemplate试用

    之前写JS绑定数据曾经用过tmpl库,虽然功能比较强大但是感觉不是很轻量,对于相对简单的数据需求显得有些臃肿.而Ajax返回数据自己拼接html的方式又显得不够高端,因此今天看了一篇介绍artTemp ...

  7. 【核心研究】消息队列_MessageQueue

    消息队列排队过程中的消息.这第一条消息将首先被处理.但假设消息本身指定要处理的时间.我们必须等待,直到时间的消息处理能力.新闻MessageQueue正在使用Message类的表示,队列中的邮件保存结 ...

  8. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(11)-验证码实现和底层修改

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(11)-验证码实现和底层修改 ASP.NET MVC+EF框架+EasyUI实现权限管系列  (开篇)   (1):框架搭建    ...

  9. NYOJ 105 其余9个

    九的余数 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描写叙述 如今给你一个自然数n,它的位数小于等于一百万,如今你要做的就是求出这个数整除九之后的余数. 输入 第一行有一 ...

  10. HDU - 1394 Minimum Inversion Number (线段树求逆序数)

    Description The inversion number of a given number sequence a1, a2, ..., an is the number of pairs ( ...