Junit4中的新断言assertThat的使用方法

简介: Junit4中的新断言assertThat的使用方法


  • 引入junit4的jar包
import static org.hamcrest.MatcherAssert.*;  
  import static org.hamcrest.CoreMatchers.*;     
  import java.util.ArrayList;
  import java.util.HashMap;
  import java.util.List;
  import java.util.Map;
  import org.junit.Before;
  import org.junit.Test;
  import com.lyh.share.model.User;
  public class UserDaoTest {
          private User test1;
          private User test2;
          @Before
          public void init(){
                  test1 = new User();
                  test1.setUsername("tt1");
                  test1.setPassword("123");
                  test1.setShares(50);
                  test2 = new User();
                  test2.setUsername("tt2");
                  test2.setPassword("321");
                  test2.setShares(20);
          }
          @Test
          public void findUser(){
                  /**数值匹配**/
                  //测试变量是否大于指定值
                  assertThat(test1.getShares(), greaterThan(50));
                  //测试变量是否小于指定值
                  assertThat(test1.getShares(), lessThan(100));
                  //测试变量是否大于等于指定值
                  assertThat(test1.getShares(), greaterThanOrEqualTo(50));
                  //测试变量是否小于等于指定值
                  assertThat(test1.getShares(), lessThanOrEqualTo(100));
                  //测试所有条件必须成立
                  assertThat(test1.getShares(), allOf(greaterThan(50),lessThan(100)));
                  //测试只要有一个条件成立
                  assertThat(test1.getShares(), anyOf(greaterThanOrEqualTo(50), lessThanOrEqualTo(100)));
                  //测试无论什么条件成立(还没明白这个到底是什么意思)
                  assertThat(test1.getShares(), anything());
                  //测试变量值等于指定值
                  assertThat(test1.getShares(), is(100));
                  //测试变量不等于指定值
                  assertThat(test1.getShares(), not(50));
                  /**字符串匹配**/
                  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));
          }
  }

一般匹配符

  1. allOf
    匹配符表明如果接下来的所有条件必须都成立测试才通过,相当于“与”(&&)
    assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) );
  2. anyOf
    匹配符表明如果接下来的所有条件只要有一个成立则测试通过,相当于“或”(||)
    assertThat( testedNumber, anyOf( greaterThan(16), lessThan(8) ) );
  3. anything
    匹配符表明无论什么条件,永远为true
    assertThat( testedNumber, anything() );
  4. is
    匹配符表明如果前面待测的object等于后面给出的object,则测试通过
    assertThat( testedString, is( “developerWorks” ) );
  5. not
    匹配符和is匹配符正好相反,表明如果前面待测的object不等于后面给出的object,则测试通过
    assertThat( testedString, not( “developerWorks” ) );

字符串相关匹配符

  1. containsString
    匹配符表明如果测试的字符串testedString 包含 子字符串"developerWorks"则测试通过
    assertThat( testedString, containsString( “developerWorks” ) );
  2. endsWith
    匹配符表明如果测试的字符串testedString以子字符串"developerWorks"结尾则测试通过
    assertThat( testedString, endsWith( “developerWorks” ) );
  3. startsWith
    匹配符表明如果测试的字符串testedString以子字符串"developerWorks"开始则测试通过
    assertThat( testedString, startsWith( “developerWorks” ) );
  4. equalTo
    匹配符表明如果测试的testedValue等于expectedValue则测试通过,equalTo可以测试数值之间,字符串
    之间和对象之间是否相等,相当于Object的equals方法
    assertThat( testedValue, equalTo( expectedValue ) );
  5. equalToIgnoringCase
    匹配符表明如果测试的字符串testedString在忽略大小写的情况下等于"developerWorks"则测试通过
    assertThat( testedString, equalToIgnoringCase( “developerWorks” ) );
  6. equalToIgnoringWhiteSpace
    匹配符表明如果测试的字符串testedString在忽略头尾的任意个空格的情况下等于"developerWorks"则
    测试通过,注意:字符串中的空格不能被忽略
    assertThat( testedString, equalToIgnoringWhiteSpace( “developerWorks” ) );

数值相关匹配符

  1. closeTo
    匹配符表明如果所测试的浮点型数testedDouble在20.0±0.5范围之内则测试通过
    assertThat( testedDouble, closeTo( 20.0, 0.5 ) );
  2. greaterThan
    匹配符表明如果所测试的数值testedNumber大于16.0则测试通过
    assertThat( testedNumber, greaterThan(16.0) );
  3. lessThan
    匹配符表明如果所测试的数值testedNumber小于16.0则测试通过
    assertThat( testedNumber, lessThan (16.0) );
  4. greaterThanOrEqualTo
    匹配符表明如果所测试的数值testedNumber大于等于16.0则测试通过
    assertThat( testedNumber, greaterThanOrEqualTo (16.0) );
  5. lessThanOrEqualTo
    匹配符表明如果所测试的数值testedNumber小于等于16.0则测试通过
    assertThat( testedNumber, lessThanOrEqualTo (16.0) );

collection相关匹配符

  1. hasEntry
    匹配符表明如果测试的Map对象mapObject含有一个键值为"key"对应元素值为"value"的Entry项则测试通过
    assertThat( mapObject, hasEntry( “key”, “value” ) );
  2. hasItem
    匹配符表明如果测试的迭代对象iterableObject含有元素“element”项则测试通过
    assertThat( iterableObject, hasItem ( “element” ) );
  3. hasKey
    匹配符表明如果测试的Map对象mapObject含有键值“key”则测试通过
    assertThat( mapObject, hasKey ( “key” ) );
  4. hasValue
    匹配符表明如果测试的Map对象mapObject含有元素值“value”则测试通过
    assertThat( mapObject, hasValue ( “key” ) );


相关文章
|
6月前
|
Java 程序员 Android开发
老程序员分享:JUnit——assertThat(acture,matcher)
老程序员分享:JUnit——assertThat(acture,matcher)
46 0
|
XML 设计模式 Java
Spring——整合junit4、junit5使用方法
Spring——整合junit4、junit5使用方法
|
Java 测试技术
JUnit使用方法
JUnit是一个开源的Java单元测试框架。 1.为什么要使用JUnit 以前,开发人员写一个方法,如下代码所示: //******* AddAndSub.
1050 0
|
4月前
|
XML Java 测试技术
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
这篇文章介绍了Spring5框架的三个新特性:支持@Nullable注解以明确方法返回、参数和属性值可以为空;引入函数式风格的GenericApplicationContext进行对象注册和管理;以及如何整合JUnit5进行单元测试,同时讨论了JUnit4与JUnit5的整合方法,并提出了关于配置文件加载的疑问。
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
|
2月前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
35 5
|
3月前
|
SQL JavaScript 前端开发
基于Java访问Hive的JUnit5测试代码实现
根据《用Java、Python来开发Hive应用》一文,建立了使用Java、来开发Hive应用的方法,产生的代码如下
82 6
|
4月前
|
测试技术
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
62 2
|
4月前
|
测试技术
如何使用 JUnit 测试方法是否存在异常
【8月更文挑战第22天】
96 0
|
4月前
|
Java 测试技术 Maven
Junit单元测试 @Test的使用教程
这篇文章是一个关于Junit单元测试中`@Test`注解使用的教程,包括在Maven项目中添加Junit依赖、编写带有@Test注解的测试方法,以及解决@Test注解不生效的常见问题。
|
6月前
|
运维 Java 测试技术
Spring运维之boo项目表现层测试加载测试的专用配置属性以及在JUnit中启动web服务器发送虚拟请求
Spring运维之boo项目表现层测试加载测试的专用配置属性以及在JUnit中启动web服务器发送虚拟请求
57 3