• junit学习笔记(二):hamcrest和TestSuit


    1. hamcrest

    hamcrest可以有效增加junit的测试能力,用一些对通俗语言来进行测试.
    Hamcrest 是一个测试的框架,它提供了一套通用的匹配符 Matcher,灵活使用这些匹配符定义的规则,程序员可以更加精确的表达自己的测试思想,指定所想设定的测试条件。比如,有时候定义的测试数据范围太精 确,往往是若干个固定的确定值,这时会导致测试非常脆弱,因为接下来的测试数据只要稍稍有变化,就可能导致测试失败(比如 assertEquals( x, 10 ); 只能判断 x 是否等于 10,如果 x 不等于 10, 测试失败);有时候指定的测试数据范围又不够太精确,这时有可能会造成某些本该会导致测试不通过的数据,仍然会通过接下来的测试,这样就会降低测试的价 值。 Hamcrest 的出现,给程序员编写测试用例提供了一套规则和方法,使用其可以更加精确的表达程序员所期望的测试的行为。

    hamcrest常用的匹配器:
    • 核心
      • anything - 总是匹配,如果你不关心测试下的对象是什么是有用的
      • describedAs - 添加一个定制的失败表述装饰器
      • is - 改进可读性装饰器 - 见下 “Sugar”
    • 逻辑
      • allOf - 如果所有匹配器都匹配才匹配, short circuits (很难懂的一个词,意译是短路,感觉不对,就没有翻译)(像 Java &&)
      • anyOf - 如果任何匹配器匹配就匹配, short circuits (像 Java ||)
      • not - 如果包装的匹配器不匹配器时匹配,反之亦然
    • 对象
      • equalTo - 测试对象相等使用Object.equals方法
      • hasToString - 测试Object.toString方法
      • instanceOf, isCompatibleType - 测试类型
      • notNullValue, nullValue - 测试null
      • sameInstance - 测试对象实例
    • Beans
      • hasProperty - 测试JavaBeans属性
    • 集合
      • array - 测试一个数组元素test an array’s elements against an array of matchers
      • hasEntry, hasKey, hasValue - 测试一个Map包含一个实体,键或者值
      • hasItem, hasItems - 测试一个集合包含一个元素
      • hasItemInArray - 测试一个数组包含一个元素
    • 数字
      • closeTo - 测试浮点值接近给定的值
      • greaterThan, greaterThanOrEqualTo, lessThan, lessThanOrEqualTo - 测试次序
    • 文本
      • equalToIgnoringCase - 测试字符串相等忽略大小写
      • equalToIgnoringWhiteSpace - 测试字符串忽略空白
      • containsString, endsWith, startsWith - 测试字符串匹配


    1.  要用junit中的assertThat来进行断言,记住静态导入
    import static org.hamcrest.MatcherAssert.assertThat;
    import static org.hamcrest.Matchers.*;
    import static org.junit.Assert.*;
    

    2. 测试实例:
     	@Test
     	public void testHamcrest(){
     		// 比较50是否和50相等
     		assertThat(50, equalTo(50));
    		// 50是否大于30并且小于60
    		assertThat("错误",50, allOf(greaterThan(30), lessThan(60)));
    		// 判断字符串是否以.txt结尾
    		assertThat("错误", "abc.txt", endsWith(".txt"));
    
     	}




    特别注意,如果使用junit4.10, 必须把hamcrest的jar包移到junit的jar包之前,否则组合条件allOf会抛出异常


    2. TestSuit

    如果有多个测试操作类,那么一个一个来运行测试就很不方便,所以通过testsuit可以把多个测试类“捆绑”起来,一起测试!
    例如,下面这个工程有三个测试类,TestA, TestB和TestCalculate
    我们可以再建一个类TestSuit,把这些类进行打包,然后同时运行测试。
    package com.fjnu.util;
    
    import org.junit.runner.RunWith;
    import org.junit.runners.Suite;
    import org.junit.runners.Suite.SuiteClasses;
    
    // RunWith表示这个类是一个suite的类
    @RunWith(Suite.class)
    // 说明这个类中包含哪些测试组建
    @SuiteClasses({TestA.class,
    			   TestB.class,
    			   TestCalculate.class})
    public class TestSuit {
    	/*
    	 *  测试原则:
    	 *  1、建议创建一个专门的source folder--->test来编写测试类代码
    	 *  2、测试类的包应该保持和需要测试的类一致
    	 *  3、测试单元中的每个测试方法都必须可以独立执行,没有次序,不能有任何互相依赖
    	 */
    
    }
    
    
    
    
    然后直接运行TestSuit这个类就可以测试所选的测试类了。






  • 相关阅读:
    bzoj3531[Sdoi2014]旅行
    bzoj3212 Pku3468 A Simple Problem with Integers 线段树
    bzoj1858[Scoi2010]序列操作 线段树
    bzoj2243[SDOI2011]染色 树链剖分+线段树
    bzoj3038上帝造题的七分钟2
    bzoj1036[ZJOI2008]树的统计Count 树链剖分+线段树
    bzoj3211花神游历各国 线段树
    bzoj4596[Shoi2016]黑暗前的幻想乡 Matrix定理+容斥原理
    bzoj3129[Sdoi2013]方程 exlucas+容斥原理
    刷题总结——寻宝游戏(bzoj3991 dfs序)
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3141111.html
Copyright © 2020-2023  润新知