比JUnit4更酷的Annotation @Test checkMethod Annotation

上一篇文章中,我们已经看到如何测试Vector#add(Object)是线程安全的,如果你觉得check_testAdd不符合你的编程风格的话,现在你可以使用Annotation来表示check方法了,这就是@checkMethod Annotation, 上一篇文中的例子将写成:
public class VectorTest extends TestCase {
    public static void main() {
       ConcurrentRunner runner = new ConcurrentRunner();
       runner.setMethodFilter(new AnnotationMethodFilter());
       runner.run(VectorTest.class);
    }
    private Vector _vector = new Vector();
   
    @Test(checkMethod = "checkAdd")
    public void testAdd() {
        _vector.add(new Object());
    }

    public void checkAdd() {
        assertEquals(10, _vector.size());
    }
}
上面例子中@Test表示该方法为测试案例,checkMethod表示该方法对应的检查方法,这在某种程度上帮助你将测试逻辑和断言(assert部分)分离。 p-unit 核心部分支持jdk >= 1.3 因此内建标准的method filter还是根据test的命名规则,test开头以及check_前缀做为该test的check方法。 为了使用Annotation,只需加入下面一行代码:
       runner.setMethodFilter(new AnnotationMethodFilter());
这也使得你可以定制自己的命名规则,嵌入p-unit内核。体会到p-unit酷的部分了吗?

另外,p-unit支持@Test(expected=Throwable.class),这点和JUnit 4完全一样。
该功能不包含在p-unit-0.10 release中,将在下一个版本中包含该功能,或者你可以check out svn最新代码来抢先体验该功能。

p-unit 主页: http://p-unit.sourceforge.net
p-unit 下载: p-unit-0.10 release
已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页