测试使用要求
我用的是Junit4,定义一个测试方法非常简单,只需要在方法前加上@Test就行了。据说在junit3中,是通过对测试类和测试方法的命名来确定是否是测试,且所有的测试类必须继承junit的测试基类。有兴趣的可以自己尝试下。
注意:
创建-个测试方法的要求是, 这个方法必须使用@Test注释,是公共的, 不带任何
参数, 并且返回void类型。 比如:
@Test
public void testCase() {
//....
}
常用注解
@Test
标记方法为测试用例,主要有两个参数:
@Test(excepted=RuntimeException.class)//期望的exception发生即该测试通过。
public void testCase() {
//....
}
time out,有时我们不止要求测试通过,还要在一定时间内给出结果。
@Test(timeout=3000) //以毫秒为单位的远行时间。
public void testCase() {
//....
}
@Ignore
从名字可以看出,用来跳过当前测试用例。@Ignore(value="ignore reason")//忽略本测试,value里面的是解释。
public void testCase() {
//....
}
@After与@Before
从名字即可看出,会在每个测试用例运行前后。@BeforeClass
当我们运行几个有关联的用例时,可能会在数据准备或其它前期准备中执行一些相同的命令,这个时候为了让代码更清晰,更少冗余,可以将公用的部分提取出来,放在一个方法里,并为这个方法注解@BeforeClass。意思是在测试类里所有用例运行之前,运行一次这个方法。例如创建数据库连接、读取文件等。注意:方法名可以随便起,但必须是public static void,即公开、静态、返回void类型。这个方法只会运行一次(看static就知道了)。
@AfterClass
跟@BeforeClass对应,在测试类里所有用例运行之后,运行一次。用于处理一些测试后续工作,例如清理数据,恢复现场。注意:同样必须是public static void,即公开、静态、返回void类型。这个方法也只会运行一次。
注意:加注解的运行顺序如下。
@BeforeClass –> @Before –> @Test –> @After –> @AfterClass;
同一种注解的多个函数直接,貌似是不确定运行顺序的。比如下面,并不能保证两个输出的顺序。
@After
public void tearDown() {
System.out.println("@After2");
}
@After
public void tearDown2() {
System.out.println("@After1");
}
运行原理:
涉及的类
1.Test接口代表一个测试。它是Junit中最大的一个接口了,如图。有两个方法:
int countTestCases();//返回所有测试用例的个数。
void run(TestResult result);//运行一个测试,并且收集运行结果到TestResult。
2.TestCase类
TestCase实现了Test接口,是框架提供的供我们继承的类,据说在JUnit 3 中,我们必须继承它。现在已经不需要了,直接加@Test即可。
一个TestCase实例代表一个具体的测试实例,也就是一个我们写的@Test函数。属性fName表示TestCase实例名字。
3.TestSuite类
TestSuite也实现了Test接口(根据代码看,发现是个装饰着模式)。一个TestSuite可以包含很多TestCase。TestSuite会自动收集TestCase中所有的@Test 方法加入TestSuite中。
4.TestResult类
主要通过runProtected方法运行测试并收集所有运行结果。
5.TestRunner类
Junit的主入口,包含public static void main (String[] args)函数启动测试的主类。
6.Assert类
用于断言,TestCase继承自该类,我们的测试方法通过这些断言判断程序功能是否通过测试。
7.TestListener接口
测试运行监听器,主要用于测试结果的收集。
8.ResultPrinter
从名字看就知道了。测试运行完,将测试结果进行打印。
调用关系
它们之间的调用关系如下:
测试有关的MVN命令
我们使用maven时,都是使用默认规范包名,src/main/java和src/test/java。maven美其名曰“分离但等同”。而我们想运行整个Project的测试时只需使用一下命令:
mvn test
其实我们在用maven build我们的Project时都会默认运行项目中的测试。此时可能需要在pom.xml中加个配置,如下:
<build>
<plugins>
<!-- avoid test failure lead to build fail -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.19</version>
<configuration>
<testFailureIgnore>true</testFailureIgnore>
<includes>
<include>**/*Test.java</include>
</includes>
<excludes>
<exclude>**/Abstract*.java</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
这样当build Project时遇到测试用例失败时可以跳过。就能避免下面的error。
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.10:test (default-test) on project web_nanchang: There are test failures.
当然也可以build的时候跳过测试
mvn install -Dmaven.test.skip=true
当然也可以运行指定的测试类,格式,mvn test -Dtest=[ClassName]
mvn test -Dtest=my.MyTest
支持通配符*,如
mvn test -Dtest=my.*
运行测试类中指定的方法:
mvn test -Dtest=my.MyTest#testCase
编译项目测试代码:
mvn test-compile