阅读前提
-
了解JUnit
-
对JUnit的内部实现有兴趣
-
不妨看看[深入JUnit] @Before, @After, @Test的秘密]
代码版本: junit 4.12
代码搜索工具: http://grepcode.com/
常用符号
-
_
: 用来略去代码段中无关紧要的parameter -
...
: 用来略去无关紧要的代码实现
本文的展开方式:连续提出问题,通过阅读JUnit源代码回答。
剧透
如果您看了[深入JUnit] @Before, @After, @Test的秘密], 里面的BlockJUnit4ClassRunner
是通过本文涉及到的,一个叫AllDefaultPossibilitiesBuilder
的类,与JUnitCore
连接到一起的。JUnitCore是今天的主角!
Q&A
Q1: 比如说我们有一个SampleTest
类,如何调用JUnit来运行测试?
A: JUnit有一个JUnitCode的类,他的描述是
JUnitCore is a facade for running tests.
所以,这个是运行测试的一个入口。Facade模式就是把错综复杂的子模块隐藏起来,暴露几个简单的API给用户使用。
source code:
http://grepcode.com/file/repo1.maven.org...
Q2: 哪该使用JUnitCore的那个函数?
A: 瞄一眼JUnitCore,有一个main函数。大喜
public static void main(String... args) {Result result = new JUnitCore().runMain(new RealSystem(), args);System.exit(result.wasSuccessful() ? 0 : 1); }
Q3: JUnitCore#runMain
内部有什么有意思的要看的东西?
A: JUnitCore#runMain
最终落脚到org.junit.runner.Runner#run这个函数。runner是如何决定的?请看org.junit.internal.builders.AllDefaultPossibilitiesBuilder
内部。
http://grepcode.com/file/repo1.maven.org...
Q4: JUnitCore
这个类有什么瑕疵么?
A: 这个类所有的methods都是public的,有好几个method的生命让人感觉很费解。作为一个facade类,应该提供尽可能少的,封装良好的方法。但JUnit
提供了8个run**的方法,其中runMain
,runClasses(Computer, classes)
,runRequest
都应该是protected(package private),因为其中泄露了很多子系统的model概念,例如Request
, Computer
之类。
Summary
-
JUnitCore是一个facade类,他提供了几个测试入口
::main
,runClass
啥的。 -
AllDefaultPossibilitiesBuilder
这个类存了几个默认的Test Runner。常用的BlockJUnit4ClassRunner
就在其中
References
-
JUnitCore
http://grepcode.com/file/repo1.maven.org...
http://grepcode.com/file/repo1.maven.org... -
AllDefaultPossibilitiesBuilder
http://grepcode.com/file/repo1.maven.org...
下期内容
泛泛地了解了JUnit的code path,暂时没兴趣继续深挖了。
接下来,打算转战倡导Mockito。Mockito::mock, Mockito::doReturn这些函数我觉得挺神奇的。