Junit 详解

测试使用要求 

我用的是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    


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值