`

assertThat使用方法

阅读更多

assertThat使用方法,转载自:http://hi.baidu.com/shenhuanyu09/item/2bcfcb981aa3188e581461b4

 


 

一般匹配符
1、assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) );

 

注释: allOf匹配符表明如果接下来的所有条件必须都成立测试才通过,相当于“与”(&&)

 

2、assertThat( testedNumber, anyOf( greaterThan(16), lessThan(8) ) );

 

注释:anyOf匹配符表明如果接下来的所有条件只要有一个成立则测试通过,相当于“或”(||)
3、assertThat( testedNumber, anything() );

 

注释:anything匹配符表明无论什么条件,永远为true
4、assertThat( testedString, is( "developerWorks" ) );

 

注释: is匹配符表明如果前面待测的object等于后面给出的object,则测试通过
5、assertThat( testedString, not( "developerWorks" ) );

 

注释:not匹配符和is匹配符正好相反,表明如果前面待测的object不等于后面给出的object,则测试通过

字符串相关匹配符
1、assertThat( testedString, containsString( "developerWorks" ) );

 

注释:containsString匹配符表明如果测试的字符串testedString包含子字符串"developerWorks"则测试通过

 

2、assertThat( testedString, endsWith( "developerWorks" ) ); 

 

注释:endsWith匹配符表明如果测试的字符串testedString以子字符串"developerWorks"结尾则测试通过

 

3、assertThat( testedString, startsWith( "developerWorks" ) ); 

 

注释:startsWith匹配符表明如果测试的字符串testedString以子字符串"developerWorks"开始则测试通过

 

4、assertThat( testedValue, equalTo( expectedValue ) ); 

 

注释: equalTo匹配符表明如果测试的testedValue等于expectedValue则测试通过,equalTo可以测试数值之间,字
符串之间和对象之间是否相等,相当于Object的equals方法

 

5、assertThat( testedString, equalToIgnoringCase( "developerWorks" ) ); 

 

注释:equalToIgnoringCase匹配符表明如果测试的字符串testedString在忽略大小写的情况下等于"developerWorks"则测试通过

 

6、assertThat( testedString, equalToIgnoringWhiteSpace( "developerWorks" ) );

 

注释:equalToIgnoringWhiteSpace匹配符表明如果测试的字符串testedString在忽略头尾的任意个空格的情况下等

 

于"developerWorks"则测试通过,注意:字符串中的空格不能被忽略

 


数值相关匹配符

 

1、assertThat( testedDouble, closeTo( 20.0, 0.5 ) );

 

注释:closeTo匹配符表明如果所测试的浮点型数testedDouble在20.0±0.5范围之内则测试通过

 

2、assertThat( testedNumber, greaterThan(16.0) );

 

注释:greaterThan匹配符表明如果所测试的数值testedNumber大于16.0则测试通过

 

3、assertThat( testedNumber, lessThan (16.0) );

 

注释:lessThan匹配符表明如果所测试的数值testedNumber小于16.0则测试通过

 

4、assertThat( testedNumber, greaterThanOrEqualTo (16.0) );

 

注释: greaterThanOrEqualTo匹配符表明如果所测试的数值testedNumber大于等于16.0则测试通过

 

5、assertThat( testedNumber, lessThanOrEqualTo (16.0) );

 

注释:lessThanOrEqualTo匹配符表明如果所测试的数值testedNumber小于等于16.0则测试通过

 


collection相关匹配符

 

1、assertThat( mapObject, hasEntry( "key", "value" ) );

 

注释:hasEntry匹配符表明如果测试的Map对象mapObject含有一个键值为"key"对应元素值为"value"的Entry项则测试通过

 

2、assertThat( iterableObject, hasItem ( "element" ) );

 

注释:hasItem匹配符表明如果测试的迭代对象iterableObject含有元素“element”项则测试通过

 

3、assertThat( mapObject, hasKey ( "key" ) );

 

注释: hasKey匹配符表明如果测试的Map对象mapObject含有键值“key”则测试通过

 

4、assertThat( mapObject, hasValue ( "key" ) );

 

注释:hasValue匹配符表明如果测试的Map对象mapObject含有元素值“value”则测试通过

 


 

补充转载:转载务必注明出处Taobao QA Team,原文地址:http://qa.taobao.com/?p=3541

 

 

 

1. 引言
JUnit4提供的新断言语法具有很多优点且使用简单,这已经不再是新鲜事了,可发现在实际测试代码中仍未被普及应用,特发此文,以期更多的人能掌握运用。
2. assertThat基本语法
Hamcrest 是一个测试辅助工具,提供了一套通用的匹配符 Matcher,灵活使用这些匹配符定义的规则,程序员可以更加精确的表达自己的测试思想,指定所想设定的测试条件。
Junit4结合Hamcrest提供了新的断言语句-assertThat,只需一个assertThat语句,结合Hamcrest提供的匹配符,就可以表达全部的测试思想。
assertThat的基本语法如下:

 

assertThat(T actual, Matcher matcher)
assertThat(String reason, T actual, Matcher matcher)

 

actual 是接下来想要验证的值;
matcher是使用 Hamcrest 匹配符来表达的对前面变量所期望的值的声明,如果 actual值与 matcher 所表达的期望值相符,则断言成功,否则断言失败。
reason是自定义的断言失败时显示的信息。
一个简单的例子:
// 如果测试的字符串testedString包含子字符串"taobao"则断言成功
assertThat( testedString, containsString( "taobao" ) );
3. assertThat优点

 

统一

 

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

 

语法直观易懂

 

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

 

错误信息更具描述性

 

旧的断言语法如果断言失败,默认不会有额外的提示信息,如
assertTrue(testedString.indexOf(“taobao”) > -1);
如果该断言失败,只会抛出无用的错误信息,如java.lang.AssertionError: ,除此之外不会有更多的提示信息。
新的断言语法会默认自动提供一些可读的描述信息,如
assertThat(testedString, containsString(“taobao”));
如果该断言失败,抛出的错误提示信息如下:
java.lang.AssertionError:
Expected: a string containing “taobao”
got: “taoba”

 

n

 

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

 

Matcher提供了功能丰富的匹配符,assertThat结合这些匹配符使用可更灵活更准确的表达测试思想。
// 验证字符串 s是否含有子字符串 "taobao" 或 "qa" 中间的一个
// 旧的断言,不直观,需要分析代码逻辑明白验证意图
assertTrue(s.indexOf("taobao")>-1||s.indexOf("qa")>-1);
// 新的断言,直观易懂,准确表达测试思想
assertThat(s,anyOf(containsString("taobao"),containsString("qa")));
// anyOf满足条件之一即成立,containsString包含字符串则成立
4. assertThat使用
要想发挥assetThat的威力,必须跟Hamcrest联合使用,JUnit4本身包含了一些自带了一些 Hamcrest 的匹配符 Matcher,但是只有有限的几个。因此建议你将Hamcrest包加入项目。
在pom里加入Hamcrest依赖。
<dependency>
<groupId>org.hamcrest</groupId>
<artifactId>hamcrest-all</artifactId>
<version>1.1</version>
</dependency>
在测试类里导入包
import static org.junit.Assert.*;
import static org.hamcrest.Matchers.*;
通过例子学习是有效的学习方式之一,下面通过常用的示例演示如何使用assertThat,更详细的用法请参考Hamcrest相关文档。

 

  1. 字符相关匹配符  
  2. /**equalTo匹配符断言被测的testedValue等于expectedValue, 
  3. * equalTo可以断言数值之间,字符串之间和对象之间是否相等,相当于Object的equals方法 
  4. */  
  5. assertThat(testedValue, equalTo(expectedValue));  
  6. /**equalToIgnoringCase匹配符断言被测的字符串testedString 
  7. *在忽略大小写的情况下等于expectedString 
  8. */  
  9. assertThat(testedString, equalToIgnoringCase(expectedString));  
  10. /**equalToIgnoringWhiteSpace匹配符断言被测的字符串testedString 
  11. *在忽略头尾的任意个空格的情况下等于expectedString, 
  12. *注意:字符串中的空格不能被忽略 
  13. */  
  14. assertThat(testedString, equalToIgnoringWhiteSpace(expectedString);  
  15. /**containsString匹配符断言被测的字符串testedString包含子字符串subString**/  
  16. assertThat(testedString, containsString(subString) );  
  17. /**endsWith匹配符断言被测的字符串testedString以子字符串suffix结尾*/  
  18. assertThat(testedString, endsWith(suffix));  
  19. /**startsWith匹配符断言被测的字符串testedString以子字符串prefix开始*/  
  20. assertThat(testedString, startsWith(prefix));  
  21. 一般匹配符  
  22. /**nullValue()匹配符断言被测object的值为null*/  
  23. assertThat(object,nullValue());  
  24. /**notNullValue()匹配符断言被测object的值不为null*/  
  25. assertThat(object,notNullValue());  
  26. /**is匹配符断言被测的object等于后面给出匹配表达式*/  
  27. assertThat(testedString, is(equalTo(expectedValue)));  
  28. /**is匹配符简写应用之一,is(equalTo(x))的简写,断言testedValue等于expectedValue*/  
  29. assertThat(testedValue, is(expectedValue));  
  30. /**is匹配符简写应用之二,is(instanceOf(SomeClass.class))的简写, 
  31. *断言testedObject为Cheddar的实例 
  32. */  
  33. assertThat(testedObject, is(Cheddar.class));  
  34. /**not匹配符和is匹配符正好相反,断言被测的object不等于后面给出的object*/  
  35. assertThat(testedString, not(expectedString));  
  36. /**allOf匹配符断言符合所有条件,相当于“与”(&&)*/  
  37. assertThat(testedNumber, allOf( greaterThan(8), lessThan(16) ) );  
  38. /**anyOf匹配符断言符合条件之一,相当于“或”(||)*/  
  39. assertThat(testedNumber, anyOf( greaterThan(16), lessThan(8) ) );  
  40. 数值相关匹配符  
  41. /**closeTo匹配符断言被测的浮点型数testedDouble在20.0¡À0.5范围之内*/  
  42. assertThat(testedDouble, closeTo( 20.00.5 ));  
  43. /**greaterThan匹配符断言被测的数值testedNumber大于16.0*/  
  44. assertThat(testedNumber, greaterThan(16.0));  
  45. /** lessThan匹配符断言被测的数值testedNumber小于16.0*/  
  46. assertThat(testedNumber, lessThan (16.0));  
  47. /** greaterThanOrEqualTo匹配符断言被测的数值testedNumber大于等于16.0*/  
  48. assertThat(testedNumber, greaterThanOrEqualTo (16.0));  
  49. /** lessThanOrEqualTo匹配符断言被测的testedNumber小于等于16.0*/  
  50. assertThat(testedNumber, lessThanOrEqualTo (16.0));  
  51. 集合相关匹配符  
  52. /**hasEntry匹配符断言被测的Map对象mapObject含有一个键值为"key"对应元素值为"value"的Entry项*/  
  53. assertThat(mapObject, hasEntry("key""value" ) );  
  54. /**hasItem匹配符表明被测的迭代对象iterableObject含有元素element项则测试通过*/  
  55. assertThat(iterableObject, hasItem (element));  
  56. /** hasKey匹配符断言被测的Map对象mapObject含有键值“key”*/  
  57. assertThat(mapObject, hasKey ("key"));  
  58. /** hasValue匹配符断言被测的Map对象mapObject含有元素值value*/  
  59. assertThat(mapObject, hasValue(value));  


分享到:
评论

相关推荐

    junit测试源代码

    这个压缩包很可能包含了使用JUnit编写的测试类或者示例代码,比如`JuintDemo2`,这通常是一个具体的测试类文件,可能用来演示JUnit的基本用法或特定功能。 JUnit的核心概念包括: 1. **测试注解**:JUnit4引入了...

    对私有方法进行单元测试

    私有方法虽然在类内部使用,但它们的正确性同样影响着整个系统的稳定性和可靠性。 私有方法通常不直接暴露给外部调用,因此,常规的单元测试框架如JUnit或TestNG可能无法直接对它们进行测试。然而,这并不意味着...

    myEclipse下使用Junit

    Hamcrest断言语法使用assertThat方法,语法为assertThat(value, matcher statement)。value是要测试的变量值,matcher statement是使用Hamcrest匹配符来表达的对前面变量所期望的值的声明。 Hamcrest提供了多种匹配...

    Junit教程.pdf

    通过导入Hamcrest库,可以使用`assertThat`方法与多种匹配器进行复杂的断言。 例如: ```java import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.*; assertThat(1, is...

    Junit分享1

    JUnit 提供了一些增强测试体验的特性,例如`assertThat`方法,它结合了Hamcrest库的匹配器,使得断言更加直观和强大。使用`assertThat`,我们可以清晰地表达期望的结果,当断言失败时,会提供详细的失败信息,帮助...

    Java的注解包,在使用注解的时候导入的jjar包

    在JUnit中,可以使用`assertThat`方法配合Hamcrest匹配器进行更复杂的条件检查。例如,`assertThat(result, equalTo(expected))`会检查结果是否等于预期值。 在Java开发中,除了JUnit,Spring框架也广泛使用注解。`...

    hamcrest-core-1.3.ORC2.jar:hamcrest的核心包,使用hamcrest框架必须引入的包

    例如,你可以使用assertThat方法,配合hamcrest的Matcher来断言预期的结果,如下所示: ```java import static org.hamcrest.CoreMatchers.is; import static org.junit.Assert.assertThat; @Test public void ...

    junit4hamcrest jar包

    使用`@Test`注解标记测试方法,可以非常直观地定义测试用例。此外,`@Before`和`@After`注解分别用于在每个测试之前和之后执行的代码,确保测试环境的一致性。 接着,我们谈谈Hamcrest的匹配器。Hamcrest的核心理念...

    Spring Boot 单元测试和集成测试实现详解

    在上面的例子中,我们使用了 @Test 注解来标记测试方法,然后使用 assertThat 方法来验证数组是否相等。 集成测试 集成测试是软件测试的一个阶段,在这个阶段中,各个软件模块被组合在一起进行测试。在 Spring ...

    junit工具使用JUnit 是针对 Java 语言的一个单元测试框架,它被认为是迄今为止所开发的最重要的第三方 Java 库。 它已经成为Java语言事实上的标准单元测试库。

    JUnit3 使用 `public void test*()` 形式的命名规则来识别测试方法,而在 JUnit4 中,引入了注解机制,测试方法可以通过 `@Test` 注解来标识,使得代码更清晰,可读性更强。 3. Junit4 深入学习 3.1. Fixture 的...

    JUnit4基础文档

    要使用JUnit4进行单元测试,需要创建一个测试类和测试方法。测试类通常放在test包中,类名用XXXTest结尾。测试方法用testMethod命名。下面是一个简单的JUnit4 HelloWorld示例: 首先,创建一个测试类:...

    单元测试之道Java版使用JUnit

    除了基本的断言,JUnit还支持更复杂的断言,例如`assertArrayEquals()`用于数组比较,`assertThat()`则可以配合Hamcrest匹配器进行更灵活的断言。此外,`@Test`注解可以接收`expected`参数,指定期望抛出的异常类型...

    Junit4所需jar包

    在JUnit4中,我们常常会使用Hamcrest的匹配器来定义预期结果,比如`assertThat()`方法就是通过Hamcrest进行断言的。 以下是一些关于JUnit4和Hamcrest的知识点: 1. **JUnit4的特性**: - **注解驱动**:JUnit4...

    JUnit4利用反射机制测试类的私有成员

    可以使用断言库,如JUnit提供的`assertThat()`。 请注意,尽管反射可以让我们访问私有成员进行测试,但这并不是推荐的做法。因为私有成员通常是封装的一部分,直接访问可能破坏了封装原则。然而,如果私有方法或...

    junit4测试数据库源码

    在旧版本的Junit中,断言通常使用assertEquals、assertTrue等方法。然而,Junit4引入了assertThat,这是一个更加灵活和强大的断言方式。assertThat接受一个实际值和一个期望值,可以与各种比较器或匹配器配合使用,...

    Junit4所需要的jar包,里面包含了junit4-12 无需积分下载

    你可以使用`@Test`注解的`expected`属性来指定预期的异常,或者使用`timeout`属性设置方法的执行超时时间。 在JUnit4中,还引入了`@Before`和`@After`注解,它们分别用于在每个测试方法执行之前和之后运行一段代码...

    junit.jar + hamcrest-core.jar + hamcrest-library.jar

    3. **使用Hamcrest断言**:在测试方法中,通过`assertThat()`方法结合Hamcrest的匹配器进行断言,比如`assertThat(result, equalTo(expected))`来检查结果是否等于预期值。 4. **使用`@Before`和`@After`**:可以...

    junit-4.11.jar hamcrest-core-1.3.jar

    本文将深入探讨这两个库的使用方法、核心功能以及它们在实际开发中的价值。 首先,我们来看Junit。Junit是Java编程语言中最流行的单元测试框架之一,由Erich Gamma和Kent Beck共同创建。Junit 4.11版本引入了许多...

    SpringBoot使用Junit进行单元测试

    对于测试特定方法,Junit提供了`@Test`注解,其中可以设置`expected`属性来预期抛出的异常,或者使用`assertThat`等断言方法来验证方法的返回值。例如: ```java @Test(expected = IllegalArgumentException.class)...

    JUnit单元测试框架依赖包

    比如,我们可以使用`assertThat`方法配合Hamcrest的匹配器来编写更复杂的断言: ```java import org.junit.Test; import static org.hamcrest.CoreMatchers.*; import static org.junit.Assert.assertThat; public...

Global site tag (gtag.js) - Google Analytics