关于easymock的典型使用方式,在easymock的官网文档中,有非常详尽的讲解,文档地址为 http://easymock.org/EasyMock3_0_Documentation.html,文档的开头一部分内容都是easymock中最基本的使用介绍,虽然是英文,但是非常容易看懂,适用新学者入门。
这里只罗列一些简单的常用功能,依然以前面教程中使用到的测试案例为例:
@Test
public void testQuery() {
User expectedUser = new User();
user.set.;
UserDao userDao = Easymock.createMock(UserDao.class);
Easymock.expect(userDao.getById("1001")).andReturn(expectedUser);
Easymock.replay(userDao);
UserServiceImpl service = new UserServiceImpl();
service.setUserDao(userDao);
user user = service.query("1001");
assertNotNull(user);
assertEquals(); //veify return user
Easymock.verify(userDao);
}
}
这段简短的代码中包含以下easymock的功能:
1. 创建mock对象
UserDao userDao = Easymock.createMock(UserDao.class);
2. 记录mock对象期望的行为
Easymock.expect(userDao.getById("1001")).andReturn(expectedUser);
这里记录了mock对象的行为:getById()方法被调用,调用次数为1(easymock之中如果没有明确指出调用次数,默认为1),参数为"1001",expectedUser将作为返回值。
3. 进入replay阶段
Easymock.replay(userDao);
4. 对mock对象执行验证
Easymock.verify(userDao);
对上面上面的代码稍加改动以展示easymock的其他基本功能:
1. 指定期望的调用次数
Easymock.expect(userDao.getById("1001")).andReturn(expectedUser).times(3);
2. 指定抛出期望的异常
Easymock.expect(userDao.getById("1001")).andThrow(new RuntimeException("no user exist"));
3. 记录void 方法的行为
Easymock.expect(userDao.getById("1001")) 这样的用法只能使用与mock对象的有返回值的方法,如果mock对象的方法是void,则需要使用expectLastCall():
userDao.someVoidMethod();
Easymock.expectLastCall();
和Easymock.expect(***)一样,同样支持指定调用次数,抛出异常等:
Easymock.expectLastCall().times(3);
Easymock.expectLastCall().andThrow(new RuntimeException("some error"));
4. 灵活的参数匹配
Easymock.expect(userDao.getById(Easymock.isA(String.class))).andReturn(expectedUser);
类似的还有anyInt(),anyObject(), isNull() , same(), startsWith()等诸多实现。具体细节请参考本教程中的"参数匹配"一文。