1. 程式人生 > >001-JUnit之斷言assert

001-JUnit之斷言assert

所有 配方 test ide evel 語言 測試方法 esp 斷言

一、簡介以及pom

  1. JUnit4.4引入了Hamcrest框架,Hamcest提供了一套匹配符Matcher,這些匹配符更接近自然語言,可讀性高,更加靈活;
  2. 使用全新的斷言語法:assertThat,結合Hamcest提供的匹配符,只用這一個方法,就可以實現所有的測試;

pom引入

技術分享圖片
        <!--單元測試使用-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</
artifactId> <version>4.12</version> <scope>test</scope> </dependency> <dependency> <groupId>org.hamcrest</groupId> <artifactId>hamcrest-library</artifactId> <
version>2.1</version> <scope>test</scope> </dependency> <dependency> <groupId>org.hamcrest</groupId> <artifactId>hamcrest-core</artifactId> <version>2.1</version> <
scope>test</scope> </dependency>
View Code

二、語法簡介

assertThat語法如下:
    assertThat(T actual, Matcher<T> matcher);
    assertThat(String reason, T actual, Matcher<T> matcher);

其中actual為需要測試的變量,matcher為使用Hamcrest的匹配符來表達變量actual期望值的聲明;

示例

assertThat(frank.changeUserInfo(),equalTo("男"));

註意事項

  1. 必須導入JUnit4.4之後的版本才能使用assertThat方法;

  2. 不需要繼承TestCase類,但是需要測試方法前必須加“@Test”

三、assertThat使用

3.1、一般匹配方法

1、要求所有的條件都要通過測試才算成功
assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) );
配符表明如果接下來的所有條件必須都成立測試才通過,相當於“與”(&&)

2、接下來的所有條件只要有一個成立則測試通過
assertThat( testedNumber, anyOf( greaterThan(16), lessThan(8) ) );
註釋:anyOf匹配符表明如果接下來的所有條件只要有一個成立則測試通過,相當於“或”(||)

3、無論什麽條件,永遠為true
assertThat( testedNumber, anything() );
註釋:anything匹配符表明無論什麽條件,永遠為true

4、等於判斷
assertThat( testedString, is( “developerWorks” ) );
註釋: is匹配符表明如果前面待測的object等於後面給出的object,則測試通過

5、取反判斷
assertThat( testedString, not( “developerWorks” ) );
註釋:not匹配符和is匹配符正好相反,表明如果前面待測的object不等於後面給出的object,則測試通過

3.2、字符串相關匹配符

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”則測試通過,註意:字符串中的空格不能被忽略

3.3、數值相關匹配符

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則測試通過

3.4、collection相關匹配符

1、map包含測試
assertThat( mapObject, hasEntry( “key”, “value” ) );
註釋:hasEntry匹配符表明如果測試的Map對象mapObject含有一個鍵值為”key”對應元素值為”value”的Entry項則測試通過

2、叠代對象包含測試
assertThat( iterableObject, hasItem ( “element” ) );
註釋:hasItem匹配符表明如果測試的叠代對象iterableObject含有元素“element”項則測試通過

3、map包含key測試
assertThat( mapObject, hasKey ( “key” ) );
註釋: hasKey匹配符表明如果測試的Map對象mapObject含有鍵值“key”則測試通過

4、map包含value測試
assertThat( mapObject, hasValue ( “key” ) );
註釋:hasValue匹配符表明如果測試的Map對象mapObject含有元素值“value”則測試通過

001-JUnit之斷言assert