【原】JUNIT 源码分析之TestSuite
??? Junit是如何使用適配器模式的呢?概念上可以理解,但是實際上看了代碼之后才更有意思。
?
?? TestCase有一個參數叫fname。TestSuit使用組合模式將多個TestCase包括進來,包括的方法有三:
?
??? 創建空的TestSuite,將需要的TestCase的實例通過addTest方法加入,這些TestCase需要指明testXXX的方法名。
??? 要么直接傳這個TestCase的class類型。
??? 最后是傳一個class類型的數組進來。
?
??? 不管哪種方法,最后其實都走的是第一種方法,后面的兩種方法只是類似重載構造方法罷了。在TestSuite里有個Vector,是用來存多個TestCase的實例的。
?
??? 當以第一種形式,創建空的TestSuite,再把包含testXXX方法名字的TestCase實例直接放放入Vector中。
?? 第二種形式,以class類型傳入,首先通過class的自帶方法getName解析class的類型,并把它賦給fName。然后解析class類型,得到所有的Junit認可的testXXX方法,將這些方法名,通過TestCase的帶fName參數的構造函數生成一個個的TestCase實例,將這些實例放入Vector。
? 可以看源碼,addTestMethod是加入TestMethod的方法,另外它調用createTest(),這個方法創建不同的實例。
?
private void addTestMethod(Method m, Vector names, Class theClass) {String name= m.getName();if (names.contains(name))return;if (! isPublicTestMethod(m)) {if (isTestMethod(m))addTest(warning("Test method isn't public: "+m.getName()));return;}names.addElement(name);addTest(createTest(theClass, name));}static public Test createTest(Class theClass, String name) {Constructor constructor;try {constructor= getTestConstructor(theClass);} catch (NoSuchMethodException e) {return warning("Class "+theClass.getName()+" has no public constructor TestCase(String name) or TestCase()");}Object test;try {if (constructor.getParameterTypes().length == 0) {test= constructor.newInstance(new Object[0]);if (test instanceof TestCase)((TestCase) test).setName(name);} else {test= constructor.newInstance(new Object[]{name});}} catch (InstantiationException e) {return(warning("Cannot instantiate test case: "+name+" ("+exceptionToString(e)+")"));} catch (InvocationTargetException e) {return(warning("Exception in constructor: "+name+" ("+exceptionToString(e.getTargetException())+")"));} catch (IllegalAccessException e) {return(warning("Cannot access test case: "+name+" ("+exceptionToString(e)+")"));}return (Test) test;}
?
?
?
?
???? 第三種形式,只是多次調用第二種形式的結果。
總結
以上是生活随笔為你收集整理的【原】JUNIT 源码分析之TestSuite的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: camera成像能力-清晰度(Resol
- 下一篇: Adobe Dreamweaver CS