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