Java开发网 Java开发网
注册 | 登录 | 帮助 | 搜索 | 排行榜 | 发帖统计  

您没有登录

» Java开发网 » Java程序分享区  

按打印兼容模式打印这个话题 打印话题    把这个话题寄给朋友 寄给朋友    该主题的所有更新都将Email到你的邮箱 订阅主题
reply to postflat modethreaded modego to previous topicgo to next topicgo to back
作者 使用jMock辅助单元测试
hellguyue





发贴: 2
于 2004-08-30 10:12 user profilesend a private message to userreply to postsearch all posts byselect and copy to clipboard. 
ie only, sorry for netscape users:-)add this post to my favorite list
jMock是Junit的一个增强库。源于http://www.jmock.org。

jMock简单易用,非常适合TDD中的Mock测试模式

首先我们来看一段简单测试代码

package name.nona.test.jmock;

import java.sql.SQLException;

import java.sql.Statement;

import org.jmock.Mock;

import org.jmock.MockObjectTestCase;

public class TestUsageOfJmock extends MockObjectTestCase {

public void testDatabaseUseage() throws SQLException{

Mock mockStmt = new Mock(Statement.class);

String sql = "select * from test";



mockStmt.expect(once()).method("execute")

.with(eq(sql)).will(returnValue(false));

Statement stmt = (Statement) mockStmt.proxy();

assertFalse(stmt.execute(sql));

}

}


可以看到,上面是制作了一个假的(Mock)的Statement对象,

通过对这个对象的execute操作,返回一个false值。



其中,关键的语句是

mockStmt.expect(once()).method("execute").with(eq(sql)).will(returnValue(false));

解释如下:

expect: 期待的执行次数,可以有 once,atLeastOnce(),notCalled()三种。

method 期待调用的方法名,这里是execute

with 方法需要的参数,如果没有的话就不用写with,直接will

will 返回值,没有就不写啦

其中的once, eq, returnValue都是继承自MockObjectTestCase的方法。



执行后,Green,成功。尝试两次调用 assertFalse(stmt.execute(sql)); 提示错误。



jMock是通过CGLIB的DynamicProxy来实现的mock功能。





注:本文仅是对jMock的一个简单介绍,没有太多内容。更多的东西需要你自己来探索,例如jMock的设计很有意思,使用了ValueObject模式等等。
如果对Jmock有兴趣,请访问http://www.jmock.org。 你可以下载最新的jMock包来使用,可能在接口上有些不同,但基本的调用已经定型不变(如上)。

1.0stable的版本正在开发中,帮助很少,通过看JavaDoc和testCase你可以了解到最新的用法。




话题树型展开
人气 标题 作者 字数 发贴时间
4814 使用jMock辅助单元测试 hellguyue 1553 2004-08-30 10:12

reply to postflat modethreaded modego to previous topicgo to next topicgo to back
  已读帖子
  新的帖子
  被删除的帖子
Jump to the top of page

   Powered by Jute Powerful Forum® Version Jute 1.5.6 Ent
Copyright © 2002-2021 Cjsdn Team. All Righits Reserved. 闽ICP备05005120号-1
客服电话 18559299278    客服信箱 714923@qq.com    客服QQ 714923