JUnit源码分析(二)

    在上面我们已经提到了junit.extentions包中的内容TestSetup。来看看整个包的结构吧。

JUnit源码分析(二)_第1张图片

    先简要的介绍下包中各个类的功能。ActiveTestSuiteTestSuite进行了改进,使得每个test运行在一个单独的线程里面,并且只到所有的线程都结束了才会结束整个测试。ExceptionTestCase是对TestCase进行的改进,可以方便的判断测试类是否抛出了期望的异常。而剩下的三个类,大概你看的出来是使用了装饰模式来设计的。其中TestDecorator为具体装饰类制定好了使用规则,RepeatedTestTestSetup则是具体实现的装饰类。

那为什么extentions包中ActiveTestSuiteExceptionTestCase没有使用装饰模式呢?原因在于装饰模式在结构上要求存在类似于组合模式的递归。而对于已有的TestCaseTestSuite来说,直接继承它们要比构建一个新的递归结构要来得快得多而且简单;并且这些增强功能都只是针对TestCase或者TestSuite。使用了装饰模式来扩展的类与以上不同的是,它们功能的增强是针对任何Test实现的。如果不采用装饰模式同样的功能要为TestCaseTestSuite以及以后的其他Test实现分别写出子类。因此使用装饰模式能够很巧妙的解决这个问题。 

下面来介绍下junit.runner包。上面已经提到,对于JUnit使用者来说,它可说是完全透明的,这个包里面提供了JUnit自己的测试类加载。下面就是包中所有类的关系图。

JUnit源码分析(二)_第2张图片

没有什么好讲的,都是使用反射机制来将测试类加载进来,还有读取properties文件的操作。如果想学习下反射机制的应用以及尝试写自己的类加载器可以阅读这部分的源码。 

剩下的三个包这里也不作介绍,大部分的内容都是GUI的绘制(当然junit.textui包除外)。 

JUnit中还使用了观察者模式来完成单元测试结果的自动更新(详细内容请见我关于观察者模式的文章)。

       这样,对 JUnit 的整体框架有了全面的认识。总体来说各个包分工明确,设计上采用了必要的设计模式来增强了扩展性和重用性,很值得学习和借鉴。

你可能感兴趣的:(设计模式,properties,单元测试,测试,JUnit,扩展)