EasyMock让单元测试更"解耦"
1,概念:我们用EasyMock就是为了模拟程序中因为要进行单元测试而做的很多复杂的"事儿"~
比如我们程序中有一段程序需要操作IBM的MQ,结果我们为了测试这段逻辑包含操作MQ的代码,
通常我们要搭建一套MQ环境,然后进行单元测试,好吧,现在有了EasyMock我们就可以解决这个
问题了,MQTool类,我们就可以Mock它~
如果以上描述不清楚,那就看例子吧,自己举一反三吧~
2,使用:
(1)Mock 方法是单元测试中常见的一种技术,它的主要作用是模拟一些在应用中不容易构造或者
比较复杂的对象,从而把测试与测试边界以外的对象隔离开。同时也可以当调用别人的模块,
而该模块又没有实现时(只提供接口),我们可以在独立的环境中测试自己的模块逻辑。
(2)使用前的准备,下载所需的jar包:easymock-3.0.jar(或以上版本),
junit-4.4.jar,cglib-nodep-2.1_3.jar
(3)使用方法较简单,主要有以下步骤:
step1;使用 EasyMock 生成 Mock 对象;
step2;设定 Mock 对象的预期行为和输出;
step3;将 Mock 对象切换到 Replay 状态;
step4;调用 Mock 对象方法进行单元测试;
step5;对 Mock 对象的行为进行验证。
测试实例:假如我有一个IStudent接口类和StudentApplication类,StudentApplication类中用到了 IStudent中的没实现的方法,而我想测试StudentApplication,这时用EasyMock构造一个IStudent的Mock对象, 并给要用到的的未实现的方法设定已知返回值。
public interface IStudent { public String doMethod1(); public String doMethod2(); public String doMethod3(); }
public class StudentApplication { IStudent student=null; public StudentApplication(IStudent student) { this.student = student; } public String doMethod(){ String str1=student.doMethod1(); String str2=student.doMethod2(); String str3=student.doMethod3(); return str1+str2+str3; } public IStudent getStudent() { return student; } }
转自:http://wallimn.iteye.com/blog/2197884
import main.IStudent; import main.StudentApplication; import org.easymock.EasyMock; import org.junit.Assert; import org.junit.Test; public class testStudentApplication { IStudent student; StudentApplication application; @Test public void testdoMethod(){ //•使用 EasyMock 生成 Mock 对象; student=EasyMock.createMock(IStudent.class); //设定 Mock 对象的预期行为和输出 EasyMock.expect(student.doMethod1()).andReturn("a").times(1); EasyMock.expect(student.doMethod2()).andReturn("b").times(1); EasyMock.expect(student.doMethod3()).andReturn("c").times(1); //将 Mock 对象切换到 Replay 状态 EasyMock.replay(student); //调用 Mock 对象方法进行单元测试 application=new StudentApplication(); application.setStudent(student); String getStr=application.doMethod(); //对 Mock 对象的行为进行验证 String cstr="abc";//正确的字符串 Assert.assertEquals(getStr, cstr); EasyMock.verify(student); } }