Junit 4

本系列是Java demo系列,所以有很多情况下笔者会用到单元测试来演示demo。在此笔者先对单元测试做一个简单的介绍和使用说明,并给出单元测试的demo供大家参考和学习(本文以demo的形式做一个简单的介绍和使用说明,目的是教会新手朋友快速上手,将不做深入研究,有兴趣做更深入研究的童鞋请自行查阅相关资料)。
单元测试是验证代码行为是否满足预期的有效手段之一,单元测试工具 JUnit 使这一切变得简单艺术起来。JUnit 是 Java 社区中知名度最高的单元测试工具。JUnit 设计的非常小巧,但是功能却非常强大。Martin Fowler 如此评价 JUnit:在软件开发领域,从来就没有如此少的代码起到了如此重要的作用。它大大简化了开发人员执行单元测试的难度,特别是 JUnit 4 使用 Java 5 中的注解(annotation)使测试变得更加简单。
直接贴出代码方便大家直观的参考和学习,笔者将在后面的文字中给出分析和讲解。
public class TestJunit {
@Test(timeout = 2000)
public void test(){
try {
Thread.sleep(1999);
System.out.println("Test timeout!");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
@Test
public void testOne(){
System.out.println("Test testOne!");
}
@Test
public void testTwo(){
System.out.println("Test testTwo!");
}
@After
public void testAfter(){
System.out.println("Test After!");
}
@Before
public void testBefore(){
System.out.println("Test Before!");
}
@AfterClass
public static void testAfterClass(){
System.out.println("Test AfterClass!");
}
@BeforeClass
public static void testBeforeClass(){
System.out.println("Test BeforeClass!");
}
}

以下是控制台输出结果:
Test BeforeClass!
Test Before!
Test testOne!
Test After!
Test Before!
Test testTwo!
Test After!
Test Before!
Test timeout!
Test After!
Test AfterClass!
由此可以看出这几种注解方式的测试方法的执行顺序为:@BeforeClass –> @Before –> @Test –> @After –> @AfterClass
其中:
@BeforeClass:针对所有测试,将会在所有测试方法(@Test)执行开始前只执行一次,且必须为public static void;
@AfterClass:针对所有测试,将会在所有测试方法(@Test)执行结束后只执行一次,且必须为public static void;
@Before:在每个@Test被执行前均执行一次;
@After:在每个@Test被执行后均执行一次;
@Test(timeout = 2000):@Test注解可以提供可选参数:包括timeout、expected等等,timeout时间单位是毫秒,如果执行时间超过给出的timeout的时间则会抛出异常。expected参数后面跟的是异常类型,例如@Test(expected = RuntimeException.class),在此不做过多说明。
原文永久地址:[url]http://jsonliangyoujun.iteye.com/blog/2347099[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值