转载

[深入JUnit] 测试运行的入口

阅读前提

  • 了解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**的方法,其中 runMainrunClasses(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这些函数我觉得挺神奇的。

原文  https://segmentfault.com/a/1190000004818762
正文到此结束
Loading...