接口测试从零开始系列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
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
相关文章推荐
- 接口测试从零开始系列4_junit断言介绍2
- 接口测试从零开始系列4_junit断言介绍3
- 接口测试从零开始系列4_junit断言介绍
- 接口测试从零开始系列6_简简单单Spring1
- 接口测试从零开始系列6_简简单单Spring2
- 接口测试从零开始系列_mock技术使用
- 接口测试从零开始系列1
- 接口测试从零开始系列1_如何针对接口方法设计测试用例
- python nose测试框架全面介绍八---接口测试中非法参数的断言
- 接口测试从零开始系列_mock技术使用
- 51Testing系列丛书连载:性能测试从零开始——LoadRunner入门(七)
- 初探接口测试框架--python系列2
- 接口测试-工作心得记录七(使用assertpy库断言和利用assertpy库改写接口response的check方法)
- 关于java的测试工具junit的使用的介绍
- WebService系列博客{四}[基于接口的发布服务和测试客户端]
- NodeJS学习系列课程笔记(NodeJs Assert断言测试)
- 从零开始自动化测试框架设计:自动化测试环境搭建一:eclipse+svn+selenium+Junit+maven
- Junit 测试基础介绍!
- Jmeter测试接口稳定性BUG:Software caused connection abort: recv failed 错误介绍
- 【学习笔记】系列九:接口测试