兩種不同參數運行 TestCase
參數 1:
輸入:
Java代碼
>java junit.textui.TestRunner TestShoppingCart
輸出:
Up
testPay!
Down
Up
testPayWithDiscount!
Down
參數 2:
輸入:
Java代碼
> java junit.textui.TestRunner -m TestShoppingCart.testPayWithDiscount
輸出:
Up
testPayWithDiscount!
Down
參數 1:TestCase 名字,該類的所有的以 test 開頭的 public 方法都會執行。
參數 2:參數 -m,僅僅運行該類的該方法。
TestRunner 還提供了其他的參數 -wait:(大響應時間),-v:查看 JUnit 版本號。從輸出可以看出,參數一: testPay(),testPayWithDiscount() 都運行;參數二:僅僅運行參數中的 testPayWithDiscount()。對比兩個輸出結果,setUp() 在每個方法運行前運行一次,teardown() 在每個方法運行后執行一次。后面將會詳細介紹。
TestRunner 處理兩種不同的參數
TestRunner main() 方法中,生成一個 TestRunner 實例,調用 start(args) 方法。在 start 方法中,JUnit 對輸入參數進行處理,首先檢查 -m、-v、-wait 等參數,對他們分別進行處理。如果有 -m 參數,將會根據“.”的位置,分割得到 className 和 methodName.
參數一:
首先調用 getTest(),通過 Java 反射實例化 TestSuite:
Class testClass = Class.forName(suiteClassName).asSubclass(TestCase.class);
new TestSuite(testClass)
TestSuite 構造函數中,通過調用 Class.getDeclaredMethods(),得到這個類的所有 Public 的方法,當然也包括構造函數,test 開頭和非 test 開頭的 public 方法。對所有方法進行過濾,僅僅保留 public 并且以“test”開頭的方法,本例中為 testPay() 和 testPayWithDiscount()。然后分別調用 TestSuite 的 createTest() 為每個方法生成一個實例:
theClass.getConstructor(String.class).newInstance(new Object[0]);
并且都保存在 Vector<Test> fTests 中。
參數二:
與方法一不同的的是,并不通過反射獲得相應的方法,因為參數中指定了特定的方法。直接根據輸入參數調用 TestSuite 的 createTest(),通過反射直接生成 TestCase 實例。
TestCase 實例的運行
生成 TestCase 實例后,兩種參數都將調用 TestRunner 的 doRun() 方法。下面將對第二種參數進行詳細介紹,介紹一個 TestCase 實例是怎么運行的,并且怎樣與 TestResult 和 TestListener 結合。
在 doRun() 方法中,實例化 TestResult result, 為 result 加上 Listener (new ResultPrinter()),用來監聽 Test 運行中的事件。然后運行 TestResult.Run(test)。run() 方法中調用 TestCase 的 runBare()。runBare() 會把所有的異常都拋出來,result 將接受到所有的異常。runBare() 首先會運行 setup(),接著運行 runTest(), 后 tearDown()。回頭再看前面的 output,明白了為什么 setup() 和 tearDown() 會在每個方法運行前和后運行,對于參數二,運行了兩次。