您的位置:首页 > 移动开发 > Objective-C

接口测试从零开始系列4_junit断言介绍

2012-03-19 13:51 399 查看
一.Junit4断言

assertEquals(a, b)
assertFalse(a)
assertTrue(a)       
assertNotNull(a)
assertNull(a)
assertNotSame(a, b)
assertSame(a, b)  
   @Test
   publicvoidtestAssert()throwsException {
       intexpectNum = 123;
       intactuNum = 123;
       String storeId ="123456";     
       // assertEquals(expect,actual),测试expect是否等于actual(expect和actual是原始类型数值(primitive value)或者必须为实现比较而具有equal方法)
       assertEquals(expectNum, actuNum);//运行成功
       assertEquals(storeId,"12345");//运行失败
       //assertFalse(condition)测试是否为false(假),condition是一个Boolean数值
       assertFalse(expectNum==100);//运行成功
       // assertTrue(condition)    测试是否为true(真),condition是一个Boolean数值
       assertTrue(expectNum==123);//运行成功      
       //assertNotNull(object),测试object是否非空,object是一个对象或者null。
       PingJia pingjia=null;
       assertNotNull(pingjia);//运行失败
       //assertNull(object),测试object是否非空,object是一个对象或者null。
       assertNull(pingjia);//运行成功
       // assertNotSame(unexpected, actual)测试unexpected和actual是否没有都引用同一个对象。
       String storeId1 = storeId;
       assertNotSame(storeId, storeId1);//运行失败
       // assertSame(unexpected, actual)测试unexpected和actual是否没有都引用同一个对象。
       assertSame(storeId, storeId1);//运行成功 
   }

二.[b]junit新断言[/b]

1.       JUnit4.4引入了Hamcrest框架,使用全新的断言语法:assertThat,结合Hamcest提供的匹配符,只用这一个方法,就可以实现所有的测试,Hamcest提供了一套匹配符Matcher,这些匹配符更接近自然语言,可读性高,更加灵活;

2.       assertThat语法如下:

 assertThat(T actual, Matcher<T> matcher);

assertThat(String reason, T actual, Matcher<T> matcher);

actual是接下来想要验证的值;

matcher是使用Hamcrest匹配符来表达的对前面变量所期望的值的声明,如果actual值与matcher所表达的期望值相符,则断言成功,否则断言失败。

reason是自定义的断言失败时显示的信息。

3.       注意事项:

    a. JUnit4.4之后的版本才能使用assertThat方法;

4.       优点

1.       统一:只需一条assertThat语句即可替代旧有的其他语句(如assertEquals,assertNotSame,assertFalse,assertTrue,assertNotNull,assertNull等),使断言变得简单、代码风格统一,增强测试代码的可读性和可维护性。

2.       直观:assertThat不再像assertEquals那样,使用比较难懂的“谓宾主”语法模式(如:assertEquals(3, x);)。相反,assertThat使用了类似于“主谓宾”的易读语法模式(如:assertThat(x,is(3));),使得代码更加直观、易读,符合人类思维习惯。

3.       错误信息更具描述性

旧的断言语法如果断言失败,默认不会有额外的提示信息,如assertTrue(testedString.indexOf(”taobao”) > -1);如果该断言失败,只会抛出无用的错误信息,如java.lang.AssertionError:,除此之外不会有更多的提示信息。

新的断言语法会默认自动提供一些可读的描述信息,如

assertThat(testedString, containsString(”taobao”));

如果该断言失败,抛出的错误提示信息如下:

java.lang.AssertionError:

Expected: a string containing “taobao”

got: “taoba”

4.       跟Matcher匹配符联合使用更灵活强大

 

原文:http://www.51testing.com/?uid-128005-action-viewspace-itemid-804268
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息