其他分享
首页 > 其他分享> > JUnit理解与使用

JUnit理解与使用

作者:互联网

Junit理解与使用

JUnit

JUnit是一个编写可重复测试的简单框架。它是用于单元测试框架的xUnit体系结构的一个实例。

xUnit是一套测试驱动开发的测试框架

JUnit常用注解

@Test: 将一个普通的方法修饰成为一个测试方法

@Test(expeted=XX.class)

@Test(timeout=毫秒)

@BeforeClass: 它会在所有的方法运行前被执行,static修饰

@AfterClass:它会在所有的方法运行结束后被执行,static修饰

@Befor:会在每一个测试方法被运行前执行一次

@After:会在每一个测试方法运行后被执行一次

@Ignore:所修饰的测试方法会被测试运行器忽略 

@RunWith:可以更改测试运行器,通过继承org.junit.runner.Runner这个类来写自己的运行器

JUnit测试套件

测试套件就是组织测试类一起运行

  1. 写一个作为测试套件的入口类(这个类里不包含其他的方法)
  2. 更改测试运行器Suite.class.
  3. 将要测试的类作为数组传入到Suite.SuiteClasses({})

@RunWith(Suite.class) //将测试类改为测试套件类

@Suite.SuiteClasses({TaskTest1.class,TaskTest2.class,TaskTest3.class}) //用数组的形式将测试的类添加到测试套件中

public classSuiteTest{
//要用public修饰,套件测试类要为空。不能有方法。
}

所谓的测试套件就是指一个经过注解改造的测试方法,变为了测试套件的入口,这个类中不包含其他方法,将要测试得类作为数组传入到Suit.SuitClasses()

JUnit的使用

以intellij idea为例,安装JUnit(自带)、JUnitGenerator V2.0插件(自选)

在需要测试的类中,按ctrl+shift+t,呼出choose test for菜单,选择create new test,进入test创建页面,便可进行自定义选择需要测试的类并配置后添加到指定位置

如果安装了JUnitGenerator V2.0插件,可以在类中按alt+insert找到JUnit Test,选择版本,直接生成所有方法的测试代码(防止与maven包冲突,前提需要再File/settings/Other Settings中设置JUnit Generator的生成路径Output Path)

在测试中,便可以根据需要引入对应的类,利用匹配符进行测试

assertThat匹配符

  1. 一般匹配符
    • assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) );
      注释: allOf匹配符表明如果接下来的所有条件必须都成立测试才通过,相当于“与”(&&)
    • assertThat( testedNumber, anyOf( greaterThan(16), lessThan(8) ) );
      注释:anyOf匹配符表明如果接下来的所有条件只要有一个成立则测试通过,相当于“或”(||)
    • assertThat( testedNumber, anything() );
      注释:anything匹配符表明无论什么条件,永远为true
    • assertThat( testedString, is( “developerWorks” ) );
      注释: is匹配符表明如果前面待测的object等于后面给出的object,则测试通过
    • assertThat( testedString, not( “developerWorks” ) );
      注释:not匹配符和is匹配符正好相反,表明如果前面待测的object不等于后面给出的object,则测试通过
  2. 字符串相关匹配符
    • assertThat( testedString, containsString( “developerWorks” ) );
      注释:containsString匹配符表明如果测试的字符串testedString包含子字符串"developerWorks"则测试通过
    • assertThat( testedString, endsWith( “developerWorks” ) );
      注释:endsWith匹配符表明如果测试的字符串testedString以子字符串"developerWorks"结尾则测试通过
    • assertThat( testedString, startsWith( “developerWorks” ) );
      注释:startsWith匹配符表明如果测试的字符串testedString以子字符串"developerWorks"开始则测试通过
    • assertThat( testedValue, equalTo( expectedValue ) );
      注释: equalTo匹配符表明如果测试的testedValue等于expectedValue则测试通过,equalTo可以测试数值之间,字
      符串之间和对象之间是否相等,相当于Object的equals方法
    • assertThat( testedString, equalToIgnoringCase( “developerWorks” ) );
      注释:equalToIgnoringCase匹配符表明如果测试的字符串testedString在忽略大小写的情况下等于"developerWorks"则测试通过
    • assertThat( testedString, equalToIgnoringWhiteSpace( “developerWorks” ) );
      注释:equalToIgnoringWhiteSpace匹配符表明如果测试的字符串testedString在忽略头尾的任意个空格的情况下等于"developerWorks"则测试通过,注意:字符串中的空格不能被忽略
  3. 数值相关匹配符
    • assertThat( testedDouble, closeTo( 20.0, 0.5 ) );
      注释:closeTo匹配符表明如果所测试的浮点型数testedDouble在20.0±0.5范围之内则测试通过
    • assertThat( testedNumber, greaterThan(16.0) );
      注释:greaterThan匹配符表明如果所测试的数值testedNumber大于16.0则测试通过
    • assertThat( testedNumber, lessThan (16.0) );
      注释:lessThan匹配符表明如果所测试的数值testedNumber小于16.0则测试通过
    • assertThat( testedNumber, greaterThanOrEqualTo (16.0) );
      注释: greaterThanOrEqualTo匹配符表明如果所测试的数值testedNumber大于等于16.0则测试通过
    • assertThat( testedNumber, lessThanOrEqualTo (16.0) );
      注释:lessThanOrEqualTo匹配符表明如果所测试的数值testedNumber小于等于16.0则测试通过
  4. collection相关匹配符
    • assertThat( mapObject, hasEntry( “key”, “value” ) );注释:hasEntry匹配符表明如果测试的Map对象mapObject含有一个键值为"key"对应元素值为"value"的Entry项则测试通过
    • assertThat( iterableObject, hasItem ( “element” ) );注释:hasItem匹配符表明如果测试的迭代对象iterableObject含有元素“element”项则测试通过
    • assertThat( mapObject, hasKey ( “key” ) );注释: hasKey匹配符表明如果测试的Map对象mapObject含有键值“key”则测试通过
    • assertThat( mapObject, hasValue ( “key” ) );注释:hasValue匹配符表明如果测试的Map对象mapObject含有元素值“value”则测试通过

标签:assertThat,匹配,注释,测试通过,理解,测试,使用,testedString,JUnit
来源: https://blog.csdn.net/qq_41234902/article/details/96489179