之前我们看到了Test接口里面的run方法有个TestResult的参数,不错,这个类就是用来收集测试结果的,是收集TestSuite的运行结果,所以一般情况下,一个TestSuite对应一个TestResult. TestResult存储了所有测试的详细情况,是通过还是失败。
a g6Uu O(T+y
T~(MA0如果是失败:Junit会创建一个TestFailure对象,并保存在TestResult中。请看下图:51Testing软件测试网X$w [KA J7S-EWA]
V
Yv%H9Sz/b0 这里知道了TestResult的作用,这种做法也会引入另外一个设计模式。
$\8x8Z%w~Y/{.Dg8P0Java设计模式:Collecting Parameter模式51Testing软件测试网6Z,r7_}*xS\7t
定义:当你需要从几个方法中收集结果时,你应当给方法增加一个参数,并传递一个会替你收集参数的对象。
:c2oQ qK*h0这里TestResult类就是起到了这个作用。但是我们知道TestResult是收集很多运行的Test的运行结果,这里就需要对于这些运行结果进行管理,则TestResult类定义了如下相关的方法:
W!Qm,y$@'v0e0public synchronized void addError(Test test, Throwable t) 新增一个错误到ArrayList<TestFailure>。
~}7{3s`}-Qhj0public synchronized void addFailure(Test test, AssertionFailedError t) 新增一个失败到ArrayList<TestFailure>。51Testing软件测试网 QJP$o8K5Z
public synchronized void addListener(TestListener listener) 在一个test中注册一个监听器到ArrayList<TestListener>,这个监听器就是TestListener,实现类是TestRunner。
|9p3W)y K[F0public synchronized void removeListener(TestListener listener) 从一个test中取消这个监听器。51Testing软件测试网+szWQUzs
private synchronized List<TestListener> cloneListeners() 克隆一批监听器。51Testing软件测试网 D0fE9JaE
我们已经知道了TestResult的作用,那么TestListener的作用又是什么呢?在Run一个测试用例的时候有很多的结果,这时就由TestListener去观察这个运行的结果,并且负责报告这些运行信息。51Testing软件测试网,x;|8zC9DP
TestListener是个接口,一般由Test Runner,很多特定的Junit扩展也实现了这个接口,我们来看下这个接口里面定义了哪些方法:
xk!XRC#I&o"[0public void addError(Test test, Throwable t); 发送错误的时候才被调用。
!e.Gw1{a
^;IC0public void addFailure(Test test, AssertionFailedError t); 失败的时候才被调用。
4b.]-]jB&O'M0public void endTest(Test test); 测试结束时被调用。51Testing软件测试网
Z7}7R;t)I cFv\
public void startTest(Test test); 测试开始时被调用。
@z zO/n~^0 由于定义了这个TestListener接口和实现类TestRunner的作用都看到了,特别是给扩展Junit提供了新的实现类的方式,这样的做法就引出了一个设计模式。51Testing软件测试网rJ
Z!e5g'f!je2d-J
Java设计模式:Observer模式
h9C/q6o0`0 定义:在对象之间定义了一个一对多的依赖关系,这样当一个对象改变了状态,那么所有依赖于它的对象都会自动收到通知且更新。目前Junit框架的TestRunner就以TestListener的身份注册到TestResult。
*r#R d?ff?0 我们在写testcase的时候,都会用到Assert方法去check运行结果,这时候的Assert方法是继承了Junit的TestCase类,但是你如果还记得TestCase类的声明的话,那就是TestCase不仅仅实现了Test接口,而且也继承了Assert类,其实这些Assert方法就是Assert类中实现的。51Testing软件测试网@i8a(|#c&Uz:n/K
Junit的Assert类中总共有38个Assert方法,但很多都是不停的重载,其实就只有8个核心方法:51Testing软件测试网JcdL+cd*D
assertTure; assertFalse; assertEquals; assertNotEquals; assertNull; assertSame; assertNotSame; fail(让测试失败,并给出指定的信息)51Testing软件测试网4vK7p:op(qYI
一般要用到抛出message的都会用到fail方法。
4E#W?$_rf,`+_0