JUnit4---Hamcrest匹配器常用方法总结

时间:2023-03-09 09:35:23
JUnit4---Hamcrest匹配器常用方法总结

一.Hamcrest是什么?

Hamcrest is a library of matchers, which can be combined in to create flexible expressions of intent in tests.

Hamcrest 是一个为了测试为目的,且能组合成灵活表达式的匹配器类库。

二.Hamcrest jar包

  • hamcrest-core.jar -- This is the core API to be used by third-party framework providers. This includes the a foundation set of matcher implementations for common operations. This API is stable and will rarely change. You will
    need this library as a minimum.
  • hamcrest-library.jar -- The ever-growing library of Matcher implementations. This will grow between releases.
  • hamcrest-generator.jar -- A tool to allow many Matcher implementations to be combined into a single class so users don't have to remember many classes/packages to import. Generates code.
  • hamcrest-integration.jar -- Provides integration between Hamcrest and other testing tools, including JUnit (3 and 4), TestNG, jMock and EasyMock.

Alternatively, if you don't care:

  • hamcrest-all.jar -- Includes all of the above.
三.常用方法介绍
一般,在项目中导入hamcrest-core.jar, hamcrest-library.jar就能满足使用。
Eclipse新建一个JUnit test case; 测试类导入

import static org.hamcrest.Matchers.*;

测试方法如下:


  1. @Test
  2. public void testHamcrestMatchers() {
  3. // 核心匹配
  4. // allOf: 所有条件都必须满足,相当于&&
  5. assertThat("myname", allOf(startsWith("my"), containsString("name")));
  6. // anyOf: 其中一个满足就通过, 相当于||
  7. assertThat("myname", anyOf(startsWith("na"), containsString("name")));
  8. // both: &&
  9. assertThat("myname", both(containsString("my")).and(containsString("me")));
  10. // either: 两者之一
  11. assertThat("myname", either(containsString("my")).or(containsString("you")));
  12. // everyItem: 每个元素都需满足特定条件
  13. assertThat(Arrays.asList("my", "mine"), everyItem(startsWith("m")));
  14. // hasItem: 是否有这个元素
  15. assertThat(Arrays.asList("my", "mine"), hasItem("my"));
  16. // hasItems: 包含多个元素
  17. assertThat(Arrays.asList("my", "mine", "your"), hasItems("your", "my"));
  18. // is: is(equalTo(x))或is(instanceOf(clazz.class))的简写
  19. assertThat("myname", is("myname"));
  20. assertThat("mynmae", is(String.class));
  21. // anything(): 任何情况下,都匹配正确
  22. assertThat("myname", anything());
  23. // not: 否为真,相当于!
  24. assertThat("myname", is(not("you")));
  25. // nullValue(): 值为空
  26. String str = null;
  27. assertThat(str, is(nullValue()));
  28. // notNullValue(): 值不为空
  29. String str2 = "123";
  30. assertThat(str2, is(notNullValue()));
  31. // 字符串匹配
  32. // containsString:包含字符串
  33. assertThat("myname", containsString("na"));
  34. // stringContainsInOrder: 顺序包含,“my”必须在“me”前面
  35. assertThat("myname", stringContainsInOrder(Arrays.asList("my", "me")));
  36. // endsWith: 后缀
  37. assertThat("myname", endsWith("me"));
  38. // startsWith: 前缀
  39. assertThat("myname", startsWith("my"));
  40. // isEmptyString(): 空字符串
  41. assertThat("", isEmptyString());
  42. // equalTo: 值相等, Object.equals(Object)
  43. assertThat("myname", equalTo("myname"));
  44. assertThat(new String[] {"a", "b"}, equalTo(new String[] {"a", "b"}));
  45. // equalToIgnoringCase: 比较时,忽略大小写
  46. assertThat("myname", equalToIgnoringCase("MYNAME"));
  47. // equalToIgnoringWhiteSpace: 比较时, 首尾空格忽略, 比较时中间用单个空格
  48. assertThat(" my \t name ", equalToIgnoringWhiteSpace(" my name "));
  49. // isOneOf: 是否为其中之一
  50. assertThat("myname", isOneOf("myname", "yourname"));
  51. // isIn: 是否为其成员
  52. assertThat("myname", isIn(new String[]{"myname", "yourname"}));
  53. // toString() 返回值校验
  54. assertThat(333, hasToString(equalTo("333")));
  55. // 数值匹配
  56. // closeTo: [operand-error, operand+error], Double或BigDecimal类型
  57. assertThat(3.14, closeTo(3, 0.5));
  58. assertThat(new BigDecimal("3.14"), is(closeTo(new BigDecimal("3"), new BigDecimal("0.5"))));
  59. // comparesEqualTo: compareTo比较值
  60. assertThat(2, comparesEqualTo(2));
  61. // greaterThan: 大于
  62. assertThat(2, greaterThan(0));
  63. // greaterThanOrEqualTo: 大于等于
  64. assertThat(2, greaterThanOrEqualTo(2));
  65. // lessThan: 小于
  66. assertThat(0, lessThan(2));
  67. // lessThanOrEqualTo: 小于等于
  68. assertThat(0, lessThanOrEqualTo(0));
  69. // 集合匹配
  70. // array: 数组长度相等且对应元素也相等
  71. assertThat(new Integer[]{1, 2, 3}, is(array(equalTo(1), equalTo(2), equalTo(3))));
  72. // hasItemInArray: 数组是否包含特定元素
  73. assertThat(new String[]{"my", "you"}, hasItemInArray(startsWith("y")));
  74. // arrayContainingInAnyOrder, 顺序无关,长度要一致
  75. assertThat(new String[]{"my", "you"}, arrayContainingInAnyOrder("you", "my"));
  76. // arrayContaining: 顺序,长度一致
  77. assertThat(new String[]{"my", "you"}, arrayContaining("my", "you"));
  78. // arrayWithSize: 数组长度
  79. assertThat(new String[]{"my", "you"}, arrayWithSize(2));
  80. // emptyArray: 空数组
  81. assertThat(new String[0], emptyArray());
  82. // hasSize: 集合大小
  83. assertThat(Arrays.asList("my", "you"), hasSize(equalTo(2)));
  84. // empty: 空集合
  85. assertThat(new ArrayList<String>(), is(empty()));
  86. // isIn: 是否为集合成员
  87. assertThat("myname", isIn(Arrays.asList("myname", "yourname")));
  88. // Map匹配
  89. Map<String, String> myMap = new HashMap<String, String>();
  90. myMap.put("name", "john");
  91. // hasEntry: key && value匹配
  92. assertThat(myMap, hasEntry("name", "john"));
  93. // hasKey: key匹配
  94. assertThat(myMap, hasKey(equalTo("name")));
  95. // hasValue: value匹配
  96. assertThat(myMap, hasValue(equalTo("john")));
  97. }

原文地址:https://blog.****.net/neven7/article/details/42489723