第2章 探索JUnit的核心
JUnit核心类:测试类、测试集、测试运行器
org.junit
.
Assert
@see 查看JDK的assert用法:
http://neilduan.iteye.com/blog/432125
设置VM argument -ea开启断言 -da关闭断言
JUnit
断言方法示例

JUnit核心对象
测试类、测试用例(Test class 或 TestCase 或 test case)一个包含一个或者多个测试的类,而这些测试就是指那些用@Test注释的方法。其中的一个测试方法能够被称做是一个“测试”。
测试集(Suite 或者 test suite),是一种把多个相关测试(测试用例)纳入一组的便捷方式。若是你没有为测试类定义一个测试集,那么JUnit会自动提供一个测试集。一般,一个测试集会将同一个包中的测试类纳入一个组。
测试运行器(Runner 或 test runner)执行测试集的程序。
参数化测试Paramterized
Parameterized的测试运行器容许使用不一样的参数屡次运行同一个测试。
代码例子:
JUnit的测试运行器
JUnit4的测试用例和JUnit3.x编写的测试用例使用的测试运行器是不一样的:
JUnit4用例使用org.junit.runners.JUnit4
JUnit3.x用例使用org.junit.internal.runners.JUnit38ClassRunner,示例以下:
package
org.neilside.examples.demo2;
import
org.junit.Test;
import
org.junit.runner.RunWith;
@RunWith
(value = org.junit.internal.runners.JUnit38ClassRunner.
class
)
public
class
TestWithJUnit38
extends
junit.framework.TestCase {
@Test
public
void
test() {
fail(
"Not yet implemented"
);
}
}
|
JUnitCore facade
facade模式(外观模式、门面模式),这种设计模式
提供一个统一的接口去访问多个子系统的多个不一样的接口,它为子系统中的一组接口提供一个统一的高层接口。使子系统更容易使用。


自定义测试运行器
能够经过扩展org.junit.runner.Runner的方式,定义你本身的测试运行器。
用Suite来组合测试
若是你在src/test/java 节点上运行JUnit,其实是默认的Suite在工做,它会扫描你全部的测试类。你能够经过JUnit的console来查看各用例的执行状况。
你也能够写一个Suite,把相关联的一组测试用例集合到一块儿。以下:
Eclipse能够新建一个TestSuite

选择要包含的测试用例(
不一样包的用例能够放在一个测试集里)

代码以下:
package
org.neilside.examples.demo2;
import
org.junit.runner.RunWith;
import
org.junit.runners.Suite;
import
org.junit.runners.Suite.SuiteClasses;
@RunWith
(Suite.
class
)
//1.指定运行器
@SuiteClasses
({ ParameterizedTest.
class
, TestWithJUnit38.
class
})
//2.指定测试类
public
class
Demo2TestSuite {
//命名以TestSuite结尾
}
|
如何组合一组测试集,其实跟上边同样
package
org.neilside.examples.demo2;
import
org.junit.Test;
import
org.junit.runner.RunWith;
import
org.junit.runners.Suite;
import
org.junit.runners.Suite.SuiteClasses;
import
org.neilside.examples.demo1.CalculatorTest3;
import
org.neilside.examples.demo1.Demo1TestSuite;
@RunWith
(Suite.
class
)
@SuiteClasses
({ Demo2TestSuite.
class
, Demo1TestSuite.
class
,
// 测试集 或 测试用例 均可以
CalculatorTest3.
class
})
public
class
MasterTestSuite {
@Test
// 这个测试用例不会被执行
public
void
test1() {
// fail("Not yet implemented");
}
}
|
在测试集里,一个用例出现屡次会执行屡次。