一、前言
assertThat 是 Hamcrest 单元测试框架提供的方法。Hamcrest 提供了对多种语言的支持。
二、字符相关匹配符
- equalTo
断言被测的 testedValue 等于 expectedValue,equalTo 可以断言数值之间,字符串之间和对象之间是否相等,相当于 Object 的equals 方法。assertThat(testedValue, equalTo(expectedValue));
- equalToIgnoringCase
断言被测的字符串 testedString 在忽略大小写的情况下等于 expectedString。assertThat(testedString, equalToIgnoringCase(expectedString));
- equalToIgnoringWhiteSpace
断言被测的字符串 testedString 在忽略头尾的任意个空格的情况下等于 expectedString。(注:字符串中的空格不能被忽略)assertThat(testedString, equalToIgnoringWhiteSpace(expectedString);
- containsString
断言被测的字符串 testedString 包含子字符串 subString。assertThat(testedString, containsString(subString));
- endsWith
断言被测的字符串 testedString 以子字符串 suffix 结尾。assertThat(testedString, endsWith(suffix));
- startsWith
断言被测的字符串t estedString 以子字符串 prefix 开始。assertThat(testedString, startsWith(prefix));
三、一般匹配符
- nullValue()
断言被测 object 的值为 null。assertThat(object,nullValue());
- notNullValue()
断言被测 object 的值不为 null。assertThat(object,notNullValue());
- is
断言被测的 object 等于后面给出匹配表达式。assertThat(testedString, is(equalTo(expectedValue)));
- is匹配符简写应用之一:
is(equalTo(x)) 的简写,断言 testedValue 等于expectedValue。assertThat(testedValue, is(expectedValue));
- is 匹配符简写应用之二:
is(instanceOf(SomeClass.class)) 的简写,断言 testedObject 为 Cheddar 的实例assertThat(testedObject, is(Cheddar.class));
- is匹配符简写应用之一:
- not
与 is 匹配符正好相反,断言被测的 object 不等于后面给出的 object。assertThat(testedString, not(expectedString));
- allOf
断言符合所有条件,相当于“与”(&&)。assertThat(testedNumber, allOf( greaterThan(8), lessThan(16) ) );
- anyOf
断言符合条件之一,相当于“或”(||)。assertThat(testedNumber, anyOf( greaterThan(16), lessThan(8) ) );
- both
两个选项都匹配。assertThat("fab", both(containsString("a")).and(containsString("b")));
- either
匹配其中任意一个匹配项。assertThat("fan", either(containsString("a")).or(containsString("b")));
- instanceOf
匹配对象是属于哪个类。assertThat(order, instanceOf(Order.class));
- isA
作为 instanceOf 简写的方式,作用与 instanceOf 相同。assertThat(user, isA(User.class))
四、数值相关匹配符
- closeTo
断言被测的浮点型数 testedDouble 在 20.0-0.5 ~ 20.0+0.5 范围之内。assertThat(testedDouble, closeTo( 20.0, 0.5 ));
- greaterThan
断言被测的数值 testedNumber 大于 16.0。assertThat(testedNumber, greaterThan(16.0));
- lessThan
断言被测的数值 testedNumber 小于16.0。assertThat(testedNumber, lessThan (16.0));
- greaterThanOrEqualTo
断言被测的数值 testedNumber 大于等于 16.0。assertThat(testedNumber, greaterThanOrEqualTo (16.0));
- lessThanOrEqualTo
断言被测的 testedNumber 小于等于 16.0。assertThat(testedNumber, lessThanOrEqualTo (16.0));
五、集合相关匹配符
- hasEntry
断言被测的 Map 对象 mapObject 含有一个键值为 “key” 对应元素值为 “value” 的 Entry 项。assertThat(mapObject, hasEntry("key", "value" ) );
- hasItem
表明被测的迭代对象 iterableObject 含有元素 element 项则测试通过。assertThat(iterableObject, hasItem (element));
- hasKey
断言被测的 Map 对象 mapObject 含有键值 “key”。assertThat(mapObject, hasKey ("key"));
- hasValue
断言被测的 Map 对象 mapObject 含有元素值 value。assertThat(mapObject, hasValue(value));
- everyItem
匹配现实 Iterable 接口类中的每个元素是否符合要求。assertThat(Arrays.asList("bar", "baz"), everyItem(startsWith("ba")))