目录                                                                                             

1. 开胃示例

2. 固件测试

3. 忽略测试用例

4. 异常测试

5. 超时测试

6. 测试运行器

7. 参数化测试

8. 套件测试

9. JUnit4.4assertThat断言

10. assumeThat断言

11. 参考

一、开胃示例                            

被测试类——获取学生数据:

/**
* 学生信息实体
*/
public class EStudent{
String name;
int age;
// 一堆getter、setter /**
* 注意:自定义类时要重写equals方法,否则默认equals方法会使用==方式来比较对象的内存地址是否相同,而不是内容是否相同。
*/
@Override
public boolean equals(Object obj){
if (obj == null || obl.getClass() != this.getClass()) return false; EStudent other = (EStudent)obj;
if (!this.getName().equals(other.getName())
|| this.getAge() != other.getAge()) return false;
return true;
}
} /**
* 学生数据操作接口
*/
public interface StudentDao{
public EStudent getStudent(int id);
} /**
* 真实的数据操作类
*/
public class StudentDaoImpl
implements StudentDao{ public EStudent getStudent(int id){
EStudent ret = new EStudent();
ret.setName("fsjohnhuang");
ret.setAge(); return ret;
}
} /**
* 模拟的数据操作类
*/
public class MockStudentDaoImpl
implements StudentDao{ public EStudent getStudent(int id){
EStudent ret = new EStudent();
ret.setName("fsjohnhuang");
ret.setAge(); return ret;
}
}

测试用例:

/**
* 由于下面采用参数化测试,因此将测试运行器更换为Parameterized
*/
@RunWith(Parameterized.class)
public class TestStudentDao{
static StudentDao dao, mockDao; /**
* 执行测试类中所有测试前执行一次
* 用于前提条件的初始化
*/
@BeforeClass
public static void init(){
dao = new StudentDaoImpl();
mockDao = new MockStudentDaoImpl();
} /**
* 接收测试用数据
*/
int id;
public TestStudentDao(int id){
this.id = id;
} /**
* 测试用例
*/
@Test
public void testGetStudent(){
assertEquals("获取学生信息", mockDao.getStudent(id), dao.getStudent(id));
} /**
* 测试用数据提供方法
*/
@Parameters
public Collection dataFeed(){
return Arrays.asList(new Object[][]{{},{},{}});
}
}

第一次接触时可能不能理解上面的代码片段到底发生了什么事,ctrl+c到eclipse那执行一下吧!下面我们详细了解JUnit4吧!

二、固件测试                                

就是每个测试方法执行前和后都执行的方法,用于自动初始化和回收资源等工作。通过 @Before 注解标注测试方法执行前调用的固件测试,通过 @After 注解标注测试方法执行后调用的固件测试。

父类的固件测试会在子类的固件测试前被调用。

另外可通过注解 @BeforeClass 和 @AfterClass 标注某些static方法为测试开始前和结束后被调用,用于自动初始化和回收资源等工作。注意通过注解 @BeforeClass 和 @AfterClass 标注的方法一次测试过程仅被调用一次而已。示例如下:

public class MyUT{
int i, j;
@BeforeClass public void static init(){
System.out.println("init");
i = ;
j = ;
} @Before public void invokeBefore(){
System.out.println("invokeBefore" + ++i);
} @Test public void testMyMethod1(){
System.out.println("testMyMethod1");
} @Test public void testMyMethod2(){
System.out.println("testMyMethod2");
} @After public void invokeAfter(){
System.out.println("invokeAfter" + ++j);
} @AfterClass public void static destroy(){
System.out.println("destroy");
i = ;
j = ;
}
} // 输出结果
init
invokeBefore1
testMyMethod1
invokeAfter1
invokeBefore2
testMyMethod2
invokeAfter2
destroy

三、忽略测试用例                              

通过注解 @Ignore() 可以标注不参与测试的测试方法。当然也可以通过去除注解 @Test 来达到这个目的,但去除注解 @Test 会令到eclipse的JUnit View中无法显示该测试方法。

四、异常测试                                

通过注解 @Test(expected=Class类型) 来标注期待测试方法执行时抛出哪种异常对象,若测试方法不抛出异常或异常对象与期待的异常对象不相同则测试失败。

@Test(expected=ArithmeticException.class)
public void calc(){
int i = /;
}

五、超时测试                                

通过注解 @Test(timeout=毫秒数) 来标注期待执行测试方法的最大耗时,若超时则测试失败。

@Test(timeout=)
public void wait(){
while(true){}
}

六、测试运行器                               

用于执行JUnit中所有的测试方法。JUnit为单元测试提供默认的测试运行器,但我们可以自定义,自定义的测试运行器必须继承 org.junit.runner.Runner 。然后通过类注解 @RunWith(CustomTestRunner.class) 来指定该测试的测试运行器。

常用的内置测试运行器:

1.  org.junit.runners.Suite ,套件测试时使用。

2.  org.junit.runners.Parameterized ,参数化测试时使用。

七、参数化测试                               

就是第一节中的测试类型,用于模拟以不同的参数组合来对方法进行多次测试。若不使用参数化测试,该测试方法有N个不同的参数组合,则需要写N个测试方法来测试。

// 需要使用Parameterized测试运行器才可以
@RunWith(Parameterized.class)
public class MyUT{
// 成员变量,用于存放测试用数据和测试期望值
int orig;
int expected;
public MyUT(int orig, int expected){
this.orig = orig;
this.expected = expected;
} @Test public void testMyMethod(){
assertEquals(expected, orig + );
} /**
* 测试数据和测试期望值的提供方法
* 必须用注解@Parameters标注
* 必须返回Collection类型数据
*/
@Parameters public Collection dataFeed(){
return Arrays.asList(new Object[][]{
{, },
{, },
{, }
});
}
}

八、套件测试                              

JUnit4去除JUnit3中套件测试注解,而是通过另一形式提供套件测试。

套件测试就是按业务逻辑将测试类进行分组,并以组为单位执行单元测试。

// 测试类1
public class MyUT1{
@Test public void testMyMehthod1(){
assertEquals(,);
}
}
// 测试类2
public class MyUT2{
@Test public void testMyMehthod2(){
assertEquals(,);
}
}
// 套件测试类
@RunWith(Suite.class)
@SuiteClass({MyUT1.class, MyUT2.class})
public class SuiteTest{
// 必须有一个public,无参数的构造函数。使用默认的构造函数也可以
public SuiteTest(){}
}

九、JUnit4.4的 assertThat断言                       

JUnit4.4内置Hamcrest测试组件的部分内容,而 assertThat断言 就是配置Hamcrest测试组件的匹配符来实现所有测试工作。由于Hamcrest的匹配符贴近自然语言,因此意思表达更明确。(JUnit4.4前的版本则需要引入hamcrest-core.jar和hamcrest-library.jar了)。

/* assertThat语法
* assertThat(T actual, Matcher<T> matcher);
* assertThat(String reason, T actual, Matcher<T> matcher);
* 入参actual为实际值,入参matcher为期待值的匹配符
*/ //测试变量是否大于指定值
assertThat(, greaterThan());
//测试变量是否小于指定值
assertThat(, lessThan());
//测试变量是否大于等于指定值
assertThat(, greaterThanOrEqualTo());
//测试变量是否小于等于指定值
assertThat(, lessThanOrEqualTo()); //测试所有条件必须成立
assertThat(, allOf(greaterThan(),lessThan()));
//测试只要有一个条件成立
assertThat(, anyOf(greaterThanOrEqualTo(), lessThanOrEqualTo()));
//测试无论什么条件成立(还没明白这个到底是什么意思)
assertThat(, anything());
//测试变量值等于指定值
assertThat(, is());
//测试变量不等于指定值
assertThat(, not()); /**字符串**/
String url = "http://www.taobao.com";
//测试变量是否包含指定字符
assertThat(url, containsString("taobao"));
//测试变量是否已指定字符串开头
assertThat(url, startsWith("http://"));
//测试变量是否以指定字符串结尾
assertThat(url, endsWith(".com"));
//测试变量是否等于指定字符串
assertThat(url, equalTo("http://www.taobao.com"));
//测试变量再忽略大小写的情况下是否等于指定字符串
assertThat(url, equalToIgnoringCase("http://www.taobao.com"));
//测试变量再忽略头尾任意空格的情况下是否等于指定字符串
assertThat(url, equalToIgnoringWhiteSpace("http://www.taobao.com")); /**集合**/
List<User> user = new ArrayList<User>();
user.add(test1);
user.add(test2); //测试集合中是否还有指定元素
assertThat(user, hasItem(test1));
assertThat(user, hasItem(test2)); /**Map匹配**/
Map<String,User> userMap = new HashMap<String,User>();
userMap.put(test1.getUsername(), test1);
userMap.put(test2.getUsername(), test2); //测试map中是否还有指定键值对
assertThat(userMap, hasEntry(test1.getUsername(), test1));
//测试map中是否还有指定键
assertThat(userMap, hasKey(test2.getUsername()));
//测试map中是否还有指定值
assertThat(userMap, hasValue(test2));

十、 assumeThat假设断言                             

位于 org.junit.Assume类 下,同样是属于Hamcrest组件的。用于假设当条件成立时才会执行后续的代码,条件不成立时是不会影响测试结果。

assumeThat(, is());
System.out.println("I'm here"); // 这句不会被执

尊重原创,转载请注明来自:http://www.cnblogs.com/fsjohnhuang/p/4061902.html  ^_^肥仔John

十一、参考                                

http://blog.csdn.net/skyie53101517/article/details/8739126

Java魔法堂:JUnit4使用详解的更多相关文章

  1. Java魔法堂:内部类详解

    一.前言 对于内部类平时编码时使用的场景不多,比较常用的地方应该就是绑定事件处理程序的时候了(从C#.JS转向Java阵营的孩子总不不习惯用匿名内部类来做事件订阅:().本文将结合Bytecode对四 ...

  2. MyBatis魔法堂:ResultMap详解

    一.前言   MyBatis是基于“数据库结构不可控”的思想建立的,也就是我们希望数据库遵循第三范式或BCNF,但实际事与愿违,那么结果集映射就是MyBatis为我们提供这种理想与现实间转换的手段了, ...

  3. .Net魔法堂:log4net详解

    一.作用 提供一个记录日志的框架,可以将日志信息记录到文件.控制台.Windows事件日志和数据库(MSSQL.Acess.Oracle.DB2和SQLite等). 二.先看看示例,感受一下吧   c ...

  4. 【转】Java魔法堂:String.format详解

    Java魔法堂:String.format详解     目录     一.前言    二.重载方法     三.占位符     四.对字符.字符串进行格式化     五.对整数进行格式化     六. ...

  5. Java魔法堂:打包知识点之jar

    一.前言    通过eclipse导出jar包十分方便快捷,但作为码农岂能满足GUI的便捷呢?所以一起来CLI吧! 二.JAR包 JAR包是基于ZIP文件格式,用于将多个.java文件和各种资源文件, ...

  6. Java魔法堂:类加载器入了个门

    一.前言 <Java魔法堂:类加载机制入了个门>中提及整个类加载流程中只有加载阶段作为码农的我们可以入手干预,其余均由JVM处理.本文将记录加载阶段的核心组件——类加载器的相关信息,以便日 ...

  7. java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET

    java中的io系统详解 - ilibaba的专栏 - 博客频道 - CSDN.NET 亲,“社区之星”已经一周岁了!      社区福利快来领取免费参加MDCC大会机会哦    Tag功能介绍—我们 ...

  8. Java开发利器Myeclipse全面详解

    Java开发利器Myeclipse全面详解: Ctrl+1:修改代码错误 Alt+Shift+S:Source命令 Ctrl+7:单行注释 Ctrl+Shift+/ :多行注释 Ctrl+I :缩进( ...

  9. Java中的main()方法详解

    在Java中,main()方法是Java应用程序的入口方法,也就是说,程序在运行的时候,第一个执行的方法就是main()方法,这个方法和其他的方法有很大的不同,比如方法的名字必须是main,方法必须是 ...

  10. [译]Java Thread join示例与详解

    Java Thread join示例与详解 Java Thread join方法用来暂停当前线程直到join操作上的线程结束.java中有三个重载的join方法: public final void ...

随机推荐

  1. 关于iis7短日期后面带有星期的解决办法

    以下方法试验无效: 在“控制面板”,在“区域和语言选项”中找到了“格式”设置,然后把短日期改成yyyy-M-D. 正确方法是修改注册表: /HKEY_USERS/.DEFAULT/Control Pa ...

  2. Eclipse中web项目缓存路径

    eclipse运行web项目后, 默认保存到 workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps ecli ...

  3. Scala 具体的并行集合库【翻译】

    原文地址 本文内容 并行数组(Parallel Array) 并行向量(Parallel Vector) 并行范围(Parallel Range) 并行哈希表(Parallel Hash Tables ...

  4. Cocos2d中使用颜色混合:加算,减算

    转自http://blog.sina.com.cn/s/blog_7a2ffd5c0100xtid.html CCSprite有一个ccBlendFunc类型的blendFunc_结构体成员,可以用来 ...

  5. MongoDB副本集配置系列十一:MongoDB 数据同步原理和自动故障转移的原理

    1:数据同步的原理: 当Primary节点完成数据操作后,Secondary会做出一系列的动作保证数据的同步: 1:检查自己local库的oplog.rs集合找出最近的时间戳. 2:检查Primary ...

  6. log4j总结

    log4j介绍 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接口服务 器.NT的事件记录器.UNIX Sysl ...

  7. HashSet HashTable HashMap的区别 及其Java集合介绍

    (1)HashSet是set的一个实现类,hashMap是Map的一个实现类,同时hashMap是hashTable的替代品(为什么后面会讲到). (2)HashSet以对象作为元素,而HashMap ...

  8. Azure SoftEther VPN

    装个vs2015,想装全组建还得爬墙… 曾经的 Azure OpenVPN 项目 (http://azure-openvpn.github.io/) 好几年木有更新 改用 SoftEther VPN ...

  9. cocos2d-x-3.0 的改变,由于变得太多,一点点累积吧!

    1.cpp  改成  Point 2.setIsRelativeAnchorPoint() 改成  ignoreAnchorPointForPosition() 3.Layer::create   图 ...

  10. Digg Reader 登录不了,原来如此

    cdnjs.cloudflare.com 不能访问,你懂的,给 https://cdnjs.cloudflare.com 跟 http://cdnjs.cloudflare.com 架个梯子就可以了, ...