JUnit测试程式
上一篇 /
下一篇 2008-06-30 17:23:56
/ 个人分类:记录
| junit测试程式编写规范
一、 程式命名规范
1.测试类的命名
测试类的命名规则是:被测试类的类名+test
比如有一个类叫irgsrhdelegate,那么他的测试类的命名就是irgsrhdelegatetest
2.测试用例的命名
测试用例的命名规则是:test+用例方法名称
比如要测试的方法叫updatedata,那么测试用例的命名就是testupdatedata
(说明:“用例方法”就是指被测试的类中所包含的方法,而“测试用例”就是指测试类中所包含的方法)
比如irgsrhdelegate中有一个方法叫做findbyirgfindparam,那么在irgsrhdelegatetest中对应的测试用例名称就是testfindbyirgfindparam。
3.其他命名规范
本规范未说明的其他命名规范请参照《java语言编码规范》(eno-w063-java coding rule.doc)。
二、 测试程式的包名定义规范
为了保持测试程式的单独和稳定性,请按照下面的方式组织测试程式:
假如被测试类的包名是com.wistrons.util,那么测试类的包名就是test.com.wistrons.util。也就是说在被测试类的包名前加上“test.”,这就是测试类的包名。
三、 测试数据的准备方案
准备测试数据时有三种方案能够选择。
1.在程式中直接写入测试数据
在要输入的数据项不多的情况下能够采用这种方式
2.使用junitpack包中的inputdatautil工具类
(要使用这个工具,请在测试程式中加上import junitpack.inputdatautil)
这种方法需要把测试数据写在一个xml文档中,xml的格式如下所示:
<?xml version="1.0" encoding="utf-8"?>
<inputs>
<input>
<irgcd>h0001</irgcd>
<irgname></irgname>
<irgkname></irgkname>
</input>
<input>
…
</input>
…
</inputs>
在这个xml文档中的根节点为inputs,根节点下能够有多个input节点。每个input节点代表一个case中需要的任何数据。
使用这个工具类的操作步骤如下:
1) 获取xml的存放路径。
请把写好的xml存放在测试类所在的目录中,然后能够按如下方式取得xml的存放路径:
string xml = irgsrhdelegatetest.class.getresource(".").tostring() +"test.xml";
2) 创建inputdatautil的实例。
inputdatautil inpututil = new inputdatautil();
3) 在inputdatautil实例中配置接受数据的类名,inputdatautil将此类和xml进行数据绑定。
inpututil.setclassname("jp.co.liondor.common.fz25irgsrh. seekirgsrhopt");
4) 调用inputdatautil.parse()方法,从xml中采集数据
java.util.vector vector = (java.util.vector) inpututil.parse(xml);
5) 从vector中取出被绑定类的实例
for (int i = 0; i < vector.size(); i++) {
seekirgsrhopt ōpt = (seekirgsrhopt) vector.get(i);
…
}
现在对inputdatautil的工作原理进行说明。inputdatautil会根据input节点下的子节点名来配置被绑定的类中对应的set方法,然后把xml中的数据配置到被绑定类中。比如上例xml中,input节点下有三个子节点:irgcd、irgname、irgkname。那么在调用inputdatautil.parse()方法时,inputdatautil就会分别调用seekirgsrhopt类的setirgcd()、setirgname()、setirgkname()方法,把数据配置到seekirgsrhopt的实例类中,并返回包含这些实例类的vector对象。
3.使用digester
(要使用这个工具,请在测试程式中加上import org.apache.commons.digester.digester)
digester是apache提供的一个工具类,上面的inputdatautil也是从digester类继承的。当使用inputdatautil暂时无法解决的时候,能够直接使用digester。
使用digester的步骤如下:
1) 获取xml的存放路径。
获取方式和使用inputdatautil相同。
2) 创建digester的实例。
digester dig = new digester();
3) 设定和inputs节点绑定的类为vector
dig.addobjectcreate("inputs", "java.util.vector");
4) 设定和input节点绑定的类
dig.addobjectcreate("inputs/input",
" jp.co.liondor.common.fz25irgsrh. seekirgsrhopt ");
5) 根据input节点下的子节点,依次设定相应的set方法
dig.addcallmethod("inputs/input/ irgcd ", "setirgcd ", 1);
dig.addcallparam("inputs/input/ irgcd ", 0);
6) 设定向vector中加入数据的方法
dig.addsetnext("inputs/input", "add");
7) 调用digester.parse()方法,从xml中采集数据
java.util.vector vector = (java.util.vector) dig.parse(xml);
8) 从vector中取出被绑定类的实例
for (int i = 0; i < vector.size(); i++) {
seekirgsrhopt ōpt = (seekirgsrhopt) vector.get(i);
…
}
digester的用法很灵活,能够组织很复杂的数据。
关于digester的周详用法请参考http://jakarta.apache.org/commons/digester/。
四、 对ui测试的原则
对ui做单元测试必须做到不能牵涉到业务逻辑操作(比如数据库操作、和server的交互)。否则就是ui的设计不合理。对ui的单元测试应该很单纯,就只是测试界面的动作是否符合设计需要。
五、 测试数据的覆盖率
测试时所准备的测试数据要覆盖程式中任何可能出现的case。
六、 测试记录
记录测试的过程和结果,请使用log4j工具。
七、 测试粒度
选择测试粒度的原则:
1) 被测试类中任何public、protected方法都要测到。
2) 对于简单的set和get方法没有必要做测试。
|
收藏
举报
TAG:
记录